impemented todo
This commit is contained in:
63
src/main.rs
63
src/main.rs
@@ -1,4 +1,4 @@
|
|||||||
use chrono::{Local, NaiveTime};
|
use chrono::{Local, NaiveDateTime, NaiveTime};
|
||||||
use std::process;
|
use std::process;
|
||||||
use std::process::Command;
|
use std::process::Command;
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
@@ -42,20 +42,13 @@ enum Status {
|
|||||||
Crit,
|
Crit,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_status(events: Vec<String>, w: i64, c: i64) -> Result<Status, String> {
|
fn get_status(events: Vec<NaiveDateTime>, w: i64, c: i64) -> Result<Status, String> {
|
||||||
let now = Local::now().time();
|
let now = Local::now();
|
||||||
let mut event_remaining: i64 = 24 * 60;
|
let mut event_remaining: i64 = 24 * 60;
|
||||||
let mut state = Status::Idle;
|
let mut state = Status::Idle;
|
||||||
|
|
||||||
for e in events.iter() {
|
for e in events.iter() {
|
||||||
let e_start = match NaiveTime::parse_from_str(e, "%H:%M") {
|
let diff = *e - now.naive_local();
|
||||||
Ok(s) => s,
|
|
||||||
Err(f) => {
|
|
||||||
let message = format!("error parsing time value: {}", f);
|
|
||||||
return Err(message);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
let diff = e_start - now;
|
|
||||||
if (diff.num_minutes() < event_remaining) && (diff.num_minutes() >= 0) {
|
if (diff.num_minutes() < event_remaining) && (diff.num_minutes() >= 0) {
|
||||||
event_remaining = diff.num_minutes()
|
event_remaining = diff.num_minutes()
|
||||||
}
|
}
|
||||||
@@ -123,10 +116,18 @@ fn main() {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut events: Vec<String> = Vec::new();
|
let today = Local::today();
|
||||||
|
let mut events: Vec<NaiveDateTime> = Vec::new();
|
||||||
if dayline.trim() == "Today" {
|
if dayline.trim() == "Today" {
|
||||||
for e in out_iter {
|
for e in out_iter {
|
||||||
events.push(e.to_string());
|
let event_start = match NaiveTime::parse_from_str(e, "%H:%M") {
|
||||||
|
Ok(s) => s,
|
||||||
|
Err(f) => {
|
||||||
|
eprintln!("Error parsing event start time: {}", f);
|
||||||
|
process::exit(1);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
events.push(today.and_time(event_start).unwrap().naive_local());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let count = events.len();
|
let count = events.len();
|
||||||
@@ -143,9 +144,7 @@ fn main() {
|
|||||||
args.icon, state, count
|
args.icon, state, count
|
||||||
);
|
);
|
||||||
} else if args.todo {
|
} else if args.todo {
|
||||||
let cmd = Command::new("todo")
|
let cmd = Command::new("todo").arg("--porcelain").output();
|
||||||
.arg("--porcelain")
|
|
||||||
.output();
|
|
||||||
|
|
||||||
let stdout = match cmd {
|
let stdout = match cmd {
|
||||||
Ok(o) => o.stdout,
|
Ok(o) => o.stdout,
|
||||||
@@ -163,28 +162,34 @@ fn main() {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut parsed = match json::parse(&output){
|
let mut parsed = match json::parse(&output) {
|
||||||
Ok(p) => p,
|
Ok(p) => p,
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
eprintln!("parsing JSON failed: {}", e);
|
eprintln!("parsing JSON failed: {}", e);
|
||||||
process::exit(1);
|
process::exit(1);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let count = parsed.len();
|
let count = parsed.len();
|
||||||
println!("{:#?}", count);
|
//println!("{:#?}", count);
|
||||||
|
|
||||||
let mut tasks: Vec<String> = Vec::new();
|
let mut tasks: Vec<NaiveDateTime> = Vec::new();
|
||||||
for due in parsed.members() {
|
for due in parsed.members() {
|
||||||
tasks.push(due.as_str().unwrap().to_string());
|
tasks.push(
|
||||||
|
NaiveDateTime::from_timestamp(due["due"].as_i64().unwrap(), 0)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
/*
|
let state =
|
||||||
for i in parsed {
|
match get_status(tasks, args.threshold_warn, args.threshold_crit) {
|
||||||
i.foo();
|
Ok(s) => s,
|
||||||
}
|
Err(e) => {
|
||||||
*/
|
eprintln!("{}", e);
|
||||||
|
process::exit(1);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
println!(
|
||||||
|
"{{ \"icon\": \"{}\", \"state\": \"{:?}\", \"text\": \"{}\" }}",
|
||||||
|
args.icon, state, count
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user