2 Commits
0.2.0 ... 0.2.1

Author SHA1 Message Date
AB
b1e418a633 Cleanup cpu_load_bar func. Using lib. 2020-04-11 16:35:55 +03:00
Alexandr Bogomyakov
8e569078de Minor fixes. 2020-04-10 17:20:02 +03:00

View File

@@ -2,18 +2,18 @@ extern crate chrono;
extern crate dbus; extern crate dbus;
use crate::dbus::blocking::stdintf::org_freedesktop_dbus::Properties; use crate::dbus::blocking::stdintf::org_freedesktop_dbus::Properties;
use chrono::{DateTime, FixedOffset, Local, Utc}; use chrono::{DateTime, Local, Utc};
use dbus::{arg, blocking::Connection}; use dbus::{arg, blocking::Connection};
use std::{env, fs, time::Duration}; use std::{env, time::Duration};
use sys_info; use sys_info;
const LOW: &str = "#[fg=colour2]"; const LOW: &str = "#[fg=colour119]";
const MID: &str = "#[fg=colour3]"; const MID: &str = "#[fg=colour220]";
const HIGH: &str = "#[fg=colour1]"; const HIGH: &str = "#[fg=colour197]";
const END: &str = "#[fg=colour7]"; const END: &str = "#[fg=colour153]";
const TRACK_NAME: &str = "#[fg=colour3]"; const TRACK_NAME: &str = "#[fg=colour46]";
const TRACK_ARTIST: &str = "#[fg=colour3]"; const TRACK_ARTIST: &str = "#[fg=colour46]";
const TRACK_TIME: &str = "#[bg=colour252 fg=colour235 bold]"; const TRACK_TIME: &str = "#[fg=colour153]";
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
struct TrackInfo { struct TrackInfo {
@@ -24,10 +24,6 @@ struct TrackInfo {
status: String, status: String,
} }
fn read_file(file_path: &str) -> String {
fs::read_to_string(file_path).expect("Cant read file.")
}
fn to_bar(value: i32, max: i32, low: f32, mid: f32) { fn to_bar(value: i32, max: i32, low: f32, mid: f32) {
let mut bar = "".to_string(); let mut bar = "".to_string();
let bar_sym = "".to_string(); let bar_sym = "".to_string();
@@ -59,18 +55,21 @@ fn mem_load_bar(bar_len: i32) {
let len = let len =
((memory.total - memory.avail) as f32 / (memory.total as f32) * bar_len as f32) as i32; ((memory.total - memory.avail) as f32 / (memory.total as f32) * bar_len as f32) as i32;
to_bar(len, bar_len, 0.7, 0.9); to_bar(len, bar_len, 0.7, 0.9);
print!("{:.0} MiB", memory.avail / 1024); print!("{:.0} MiB#[default]", memory.avail / 1024);
} }
fn cpu_load_bar(bar_len: i32) { fn cpu_load_bar(bar_len: i32) {
let load = read_file("/proc/loadavg"); let cpu_count = match sys_info::cpu_num() {
let load_data = load.split_whitespace().collect::<Vec<&str>>(); Ok(c) => c,
let _cpu_count = read_file("/proc/cpuinfo"); Err(e) => panic!("{:?}", e),
let cpu_count = _cpu_count.matches("model name").count(); };
let one: f32 = load_data[0].parse().unwrap(); let la_one: f32 = match sys_info::loadavg() {
let len: f32 = one as f32 / cpu_count as f32 * bar_len as f32; Ok(l) => l.one as f32,
Err(e) => panic!("{:?}", e),
};
let len: f32 = la_one as f32 / cpu_count as f32 * bar_len as f32;
to_bar(len as i32, bar_len, 0.3, 0.7); to_bar(len as i32, bar_len, 0.3, 0.7);
print!("{:.2} LA1", one); print!("{:.2} LA1#[default]", la_one);
} }
fn get_player() -> Result<Vec<String>, Box<dyn std::error::Error>> { fn get_player() -> Result<Vec<String>, Box<dyn std::error::Error>> {
@@ -226,7 +225,7 @@ fn main() {
track_info.title = title; track_info.title = title;
} }
println!( println!(
"#[none]#[bold]{}{}{}#[none]{}{}{}{} {}[{}/{}] {} {}", "#[none]#[bold]{}{}{}#[none]{}{}{}{} {}[{}/{}] {} {}#[default]",
TRACK_NAME, TRACK_NAME,
track_info.title, track_info.title,
END, END,