mirror of
https://github.com/house-of-vanity/tmux-helper.git
synced 2026-02-04 01:37:57 +00:00
Add time feature with custom format.
This commit is contained in:
@@ -7,3 +7,4 @@ edition = "2018"
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
sys-info = "*"
|
sys-info = "*"
|
||||||
dbus = "*"
|
dbus = "*"
|
||||||
|
chrono = "*"
|
||||||
|
|||||||
27
src/main.rs
27
src/main.rs
@@ -1,5 +1,8 @@
|
|||||||
|
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 dbus::{arg, blocking::Connection};
|
use dbus::{arg, blocking::Connection};
|
||||||
use std::{env, fs, time::Duration};
|
use std::{env, fs, time::Duration};
|
||||||
use sys_info;
|
use sys_info;
|
||||||
@@ -153,9 +156,24 @@ fn format_time(sec: i64) -> String {
|
|||||||
result.to_string()
|
result.to_string()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_time(utc: bool, mut format: &str) {
|
||||||
|
// Format reference: https://docs.rs/chrono/0.4.10/chrono/format/strftime/index.html
|
||||||
|
if format.len() == 0 {
|
||||||
|
format = "%H:%M";
|
||||||
|
}
|
||||||
|
if utc {
|
||||||
|
let local_time = Local::now();
|
||||||
|
let utc_time = DateTime::<Utc>::from_utc(local_time.naive_utc(), Utc);
|
||||||
|
println!("{}", utc_time.format(format));
|
||||||
|
} else {
|
||||||
|
let local_time = Local::now();
|
||||||
|
println!("{}", local_time.format(format));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let args: Vec<String> = env::args().collect();
|
let args: Vec<String> = env::args().collect();
|
||||||
let help_text: &str = "Available commands -mb, -cb";
|
let help_text: &str = "Available commands -mb, -cb, -tl <TIME FORMAT>, -tu <TIME FORMAT>, -p";
|
||||||
match args.len() {
|
match args.len() {
|
||||||
1 => {
|
1 => {
|
||||||
panic!(help_text);
|
panic!(help_text);
|
||||||
@@ -163,6 +181,8 @@ fn main() {
|
|||||||
2 => match args[1].as_ref() {
|
2 => match args[1].as_ref() {
|
||||||
"-cb" => cpu_load_bar(15),
|
"-cb" => cpu_load_bar(15),
|
||||||
"-mb" => mem_load_bar(15),
|
"-mb" => mem_load_bar(15),
|
||||||
|
"-tl" => get_time(false, ""),
|
||||||
|
"-tu" => get_time(true, ""),
|
||||||
"-p" => match player_info(get_player().unwrap()) {
|
"-p" => match player_info(get_player().unwrap()) {
|
||||||
Ok(mut track_info) => {
|
Ok(mut track_info) => {
|
||||||
let mut title_len = 30;
|
let mut title_len = 30;
|
||||||
@@ -225,6 +245,11 @@ fn main() {
|
|||||||
},
|
},
|
||||||
_ => panic!(help_text),
|
_ => panic!(help_text),
|
||||||
},
|
},
|
||||||
|
3 => match args[1].as_ref() {
|
||||||
|
"-tl" => get_time(false, args[2].as_ref()),
|
||||||
|
"-tu" => get_time(true, args[2].as_ref()),
|
||||||
|
_ => panic!(help_text),
|
||||||
|
},
|
||||||
_ => {
|
_ => {
|
||||||
panic!(help_text);
|
panic!(help_text);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user