diff options
| author | Joris Guyonvarch | 2025-05-02 11:22:40 +0200 | 
|---|---|---|
| committer | Joris Guyonvarch | 2025-05-02 11:22:40 +0200 | 
| commit | 7e56ec0f49ff30c750f5c44b65fb13442352ca89 (patch) | |
| tree | 81c2c03ba4bab9e22210d4fee426f1352a742acb /src | |
| parent | 99f483927b1b8dd96be5846f338d37a37ab667ec (diff) | |
Replace --list-today by --date today
Allow also using:
- --date yesterday
- --date tomorrow
- --date YYYY-MM-DD
Diffstat (limited to 'src')
| -rw-r--r-- | src/cli/mod.rs | 17 | ||||
| -rw-r--r-- | src/main.rs | 20 | 
2 files changed, 23 insertions, 14 deletions
| diff --git a/src/cli/mod.rs b/src/cli/mod.rs index 3674a08..aa54c08 100644 --- a/src/cli/mod.rs +++ b/src/cli/mod.rs @@ -1,13 +1,22 @@  use anyhow::Result; -use chrono::{Local, NaiveDate, NaiveDateTime, TimeZone}; +use chrono::{Local, NaiveDate, NaiveDateTime, TimeDelta, TimeZone};  use rusqlite::Connection; +use std::ops::{Add, Sub};  use crate::model::event::Event;  use crate::{db, model::event}; -pub fn today(conn: &Connection) -> Result<String> { -    let today = Local::now().date_naive(); -    let events = between_inclusive(conn, today, today)?; +pub fn parse_date(s: String) -> Option<NaiveDate> { +    match s.as_str() { +        "yesterday" => Some(Local::now().sub(TimeDelta::days(1)).date_naive()), +        "today" => Some(Local::now().date_naive()), +        "tomorrow" => Some(Local::now().add(TimeDelta::days(1)).date_naive()), +        _ => NaiveDate::parse_from_str(&s, "%Y-%m-%d").ok(), +    } +} + +pub fn started_at_date(conn: &Connection, date: NaiveDate) -> Result<String> { +    let events = between_inclusive(conn, date, date)?;      Ok(format_events(events))  } diff --git a/src/main.rs b/src/main.rs index 8eafd77..e61a771 100644 --- a/src/main.rs +++ b/src/main.rs @@ -14,11 +14,11 @@ struct Opt {      #[clap(long = "database", default_value = "database.sqlite3")]      db_path: String, -    /// List today’s events as plain text -    #[clap(long = "list-today")] -    list_today: bool, +    /// Started at events as plain text +    #[clap(long = "date")] +    date: Option<String>, -    /// Start between <timestamp..timestamp> events as plain text +    /// Started between <timestamp..timestamp> events as plain text      #[clap(long = "start-between")]      start_between: Option<String>,  } @@ -26,17 +26,17 @@ struct Opt {  fn main() -> Result<()> {      let Opt {          db_path, -        list_today, +        date,          start_between,      } = Opt::parse();      let conn = db::init(&db_path)?; -    if list_today { -        print!("{}", cli::today(&conn)?); -    } else { -        match start_between.and_then(cli::parse_timestamp_range) { + +    match date.and_then(cli::parse_date) { +        Some(date) => print!("{}", cli::started_at_date(&conn, date)?), +        None => match start_between.and_then(cli::parse_timestamp_range) {              Some((from, to)) => print!("{}", cli::start_between(&conn, from, to)?),              None => gui::run(conn), -        } +        },      };      Ok(())  } | 
