swaybar_info/src/proc.rs

89 lines
2.4 KiB
Rust
Raw Normal View History

use std::fs::File;
use std::io;
use std::io::prelude::*;
pub fn get_meminfo() -> io::Result<String> {
let mut meminfo_string = String::new();
{
let mut meminfo: File = File::open("/proc/meminfo")?;
meminfo.read_to_string(&mut meminfo_string)?;
}
let mut is_total_giga = false;
let mut total: u32 = 0;
let mut available: u32 = 0;
for line in meminfo_string.lines() {
if line.starts_with("MemTotal:") {
let line_parts = line
.split_whitespace()
.map(|s| s.to_owned())
.collect::<Vec<String>>();
total = line_parts[1]
.parse()
.map_err(|_| io::Error::new(io::ErrorKind::Other, "MemTotal: parse error"))?;
} else if line.starts_with("MemAvailable:") {
let line_parts = line
.split_whitespace()
.map(|s| s.to_owned())
.collect::<Vec<String>>();
available = line_parts[1]
.parse()
.map_err(|_| io::Error::new(io::ErrorKind::Other, "MemAvailable: parse error"))?;
}
}
let mut used = total - available;
let mut is_used_giga = false;
if total == 0 {
Ok("0".into())
} else {
if total > 1024 {
total /= 1024;
is_total_giga = true;
}
if used > 1024 {
used /= 1024;
is_used_giga = true;
}
let mut output = format!("{} ", used);
if is_used_giga {
output.push_str("GiB / ");
} else {
output.push_str("KiB / ");
}
output.push_str(&format!("{} ", total));
if is_total_giga {
output.push_str("GiB");
} else {
output.push_str("KiB");
}
Ok(output)
}
}
2022-07-09 08:04:49 +00:00
pub fn get_loadavg() -> io::Result<String> {
let mut loadavg_string = String::new();
{
let mut loadavg_file: File = File::open("/proc/loadavg")?;
loadavg_file.read_to_string(&mut loadavg_string)?;
}
let loadavg_parts: Vec<&str> = loadavg_string.split_whitespace().collect();
if loadavg_parts.len() < 3 {
return Err(io::Error::new(
io::ErrorKind::Other,
"loadavg: failed to parse",
));
}
Ok(format!(
"{} {} {}",
loadavg_parts[0], loadavg_parts[1], loadavg_parts[2]
))
}