From 46565f04abea99314e537ce70a58efebf809d8e1 Mon Sep 17 00:00:00 2001 From: Nick Cameron Date: Wed, 22 Jan 2020 18:51:47 +0000 Subject: [PATCH 1/2] Fix io issue with modern Linux versions Signed-off-by: Nick Cameron --- src/io.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/io.rs b/src/io.rs index 05bdc3356..ae6debd56 100644 --- a/src/io.rs +++ b/src/io.rs @@ -68,7 +68,7 @@ impl IOLoad { .split_whitespace() .map(|w| w.parse().unwrap_or_default()) .collect::>(); - if parts.len() != 11 { + if parts.len() < 11 { continue; } let load = IOLoad { From 1a93ed25f93b69432218d2c3b8071f6890fc0d64 Mon Sep 17 00:00:00 2001 From: Nick Cameron Date: Wed, 22 Jan 2020 18:52:12 +0000 Subject: [PATCH 2/2] Add get_vendor_id function Signed-off-by: Nick Cameron --- src/linux/mod.rs | 2 +- src/linux/processor.rs | 13 +++++++++++++ src/mac/mod.rs | 2 +- src/mac/processor.rs | 6 ++++++ src/sysinfo.rs | 2 +- src/unknown/mod.rs | 2 +- src/unknown/processor.rs | 5 +++++ src/windows/mod.rs | 2 +- src/windows/processor.rs | 6 ++++++ 9 files changed, 35 insertions(+), 5 deletions(-) diff --git a/src/linux/mod.rs b/src/linux/mod.rs index 913a1c977..6ce307c97 100644 --- a/src/linux/mod.rs +++ b/src/linux/mod.rs @@ -15,5 +15,5 @@ pub use self::component::Component; pub use self::disk::{Disk, DiskType}; pub use self::network::NetworkData; pub use self::process::{Process, ProcessStatus}; -pub use self::processor::{get_avg_load, get_cpu_frequency, Processor}; +pub use self::processor::{get_avg_load, get_cpu_frequency, get_vendor_id, Processor}; pub use self::system::System; diff --git a/src/linux/processor.rs b/src/linux/processor.rs index 94d6e10c9..3fc0273d3 100644 --- a/src/linux/processor.rs +++ b/src/linux/processor.rs @@ -277,6 +277,19 @@ pub fn get_cpu_frequency() -> u64 { .unwrap_or_default() } +/// Returns the brand/vendor string for the first CPU (which should be the same for all CPUs). +pub fn get_vendor_id() -> String { + let mut s = String::new(); + if let Err(_) = File::open("/proc/cpuinfo").and_then(|mut f| f.read_to_string(&mut s)) { + return String::new(); + } + + s.split('\n').find(|line| line.starts_with("vendor_id\t")) + .and_then(|line| line.split(':').last()) + .map(|s| s.trim().to_owned()) + .unwrap_or_default() +} + /// get_avg_load returns the system load average value. pub fn get_avg_load() -> LoadAvg { let mut s = String::new(); diff --git a/src/mac/mod.rs b/src/mac/mod.rs index 4cccbc57b..7bc9da3d0 100644 --- a/src/mac/mod.rs +++ b/src/mac/mod.rs @@ -16,5 +16,5 @@ pub use self::component::Component; pub use self::disk::{Disk, DiskType}; pub use self::network::NetworkData; pub use self::process::{Process, ProcessStatus}; -pub use self::processor::{get_avg_load, get_cpu_frequency, Processor}; +pub use self::processor::{get_avg_load, get_cpu_frequency, get_vendor_id, Processor}; pub use self::system::System; diff --git a/src/mac/processor.rs b/src/mac/processor.rs index 5ff7e2fc6..62db4fb29 100644 --- a/src/mac/processor.rs +++ b/src/mac/processor.rs @@ -116,6 +116,12 @@ pub fn get_cpu_frequency() -> u64 { speed } +/// Returns the brand/vendor string for the first CPU (which should be the same for all CPUs). +pub fn get_vendor_id() -> String { + // TODO: support Mac + "".to_owned() +} + /// get_avg_load returns the system load average value. pub fn get_avg_load() -> LoadAvg { let loads = vec![0f64; 3]; diff --git a/src/sysinfo.rs b/src/sysinfo.rs index b8e9629c1..554cbd0e0 100644 --- a/src/sysinfo.rs +++ b/src/sysinfo.rs @@ -88,7 +88,7 @@ pub use net::NICLoad; pub use num_cpus::{get as get_logical_cores, get_physical as get_physical_cores}; pub use sys::{ - get_avg_load, get_cpu_frequency, Component, Disk, DiskType, NetworkData, Process, + get_avg_load, get_cpu_frequency, get_vendor_id, Component, Disk, DiskType, NetworkData, Process, ProcessStatus, Processor, System, }; pub use traits::{ComponentExt, DiskExt, NetworkExt, ProcessExt, ProcessorExt, SystemExt}; diff --git a/src/unknown/mod.rs b/src/unknown/mod.rs index 913a1c977..6ce307c97 100644 --- a/src/unknown/mod.rs +++ b/src/unknown/mod.rs @@ -15,5 +15,5 @@ pub use self::component::Component; pub use self::disk::{Disk, DiskType}; pub use self::network::NetworkData; pub use self::process::{Process, ProcessStatus}; -pub use self::processor::{get_avg_load, get_cpu_frequency, Processor}; +pub use self::processor::{get_avg_load, get_cpu_frequency, get_vendor_id, Processor}; pub use self::system::System; diff --git a/src/unknown/processor.rs b/src/unknown/processor.rs index cfe09dfd8..7c719064f 100644 --- a/src/unknown/processor.rs +++ b/src/unknown/processor.rs @@ -26,6 +26,11 @@ pub fn get_cpu_frequency() -> u64 { 0 } +/// Returns the brand/vendor string for the first CPU (which should be the same for all CPUs). +pub fn get_vendor_id() -> String { + "".to_owned() +} + /// get_avg_load returns the system load average value. pub fn get_avg_load() -> LoadAvg { LoadAvg::default() diff --git a/src/windows/mod.rs b/src/windows/mod.rs index 1191e49c4..f6bbda86f 100644 --- a/src/windows/mod.rs +++ b/src/windows/mod.rs @@ -34,5 +34,5 @@ pub use self::component::Component; pub use self::disk::{Disk, DiskType}; pub use self::network::NetworkData; pub use self::process::{Process, ProcessStatus}; -pub use self::processor::{get_avg_load, get_cpu_frequency, Processor}; +pub use self::processor::{get_avg_load, get_cpu_frequency, get_vendor_id, Processor}; pub use self::system::System; diff --git a/src/windows/processor.rs b/src/windows/processor.rs index 5b99f23eb..5e79aa70f 100644 --- a/src/windows/processor.rs +++ b/src/windows/processor.rs @@ -294,6 +294,12 @@ pub fn get_cpu_frequency() -> u64 { 0 } +/// Returns the brand/vendor string for the first CPU (which should be the same for all CPUs). +pub fn get_vendor_id() -> String { + // TODO: support windows + "".to_owned() +} + /// get_avg_load returns the system load average value. pub fn get_avg_load() -> LoadAvg { LoadAvg::default()