From 07bd9ca2780752bcf06f625ee41541900de16282 Mon Sep 17 00:00:00 2001 From: Ludovic Chopin Date: Thu, 28 Jul 2022 17:31:27 +0200 Subject: [PATCH] Add 'from_reader' for LoadAverage --- src/lib.rs | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 160ad52f..0e490951 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -568,10 +568,16 @@ pub struct LoadAverage { impl LoadAverage { /// Reads load average info from `/proc/loadavg` pub fn new() -> ProcResult { - let mut f = FileWrapper::open("/proc/loadavg")?; - let mut s = String::new(); - f.read_to_string(&mut s)?; - let mut s = s.split_whitespace(); + LoadAverage::from_reader(FileWrapper::open("/proc/loadavg")?) + } + + /// Get LoadAverage from a custom Read instead of the default `/proc/loadavg`. + pub fn from_reader(r: R) -> ProcResult { + let mut reader = BufReader::new(r); + let mut line = String::new(); + + reader.read_to_string(&mut line)?; + let mut s = line.split_whitespace(); let one = expect!(f32::from_str(expect!(s.next()))); let five = expect!(f32::from_str(expect!(s.next())));