#date-time #date-parser #time-parser #plain-text #time #parser #text-parser

kairos

A library on top of chrono to calculate times and dates ergonomically

8 releases (4 breaking)

0.4.0 Feb 10, 2024
0.3.0 Nov 9, 2018
0.2.0 May 28, 2018
0.1.1 May 28, 2018
0.0.0 Sep 2, 2017

#149 in Date and time

39 downloads per month
Used in 6 crates (5 directly)

MPL-2.0 license

220KB
5K SLoC

Kairos

Calculate times with chrono "plain text like" in Rust.

From Wikipedia:

Kairos (καιρός) is an Ancient Greek word meaning the right, critical or opportune moment.

This library offers an abstraction over the awesome chrono crate to calculate dates almost like one would write plain text:

use kairos::timetype::TimeType as TT;

// get the end of the month of the day 5 days ago
let _ = (TT::today() - TT::weeks(1) + TT::days(2)).end_of_month();

// alternative to above
let _ = (TT::today() - TT::days(5)).end_of_month();

// NOTE: The following features are not yet included

// get a vector of dates for the next 4 weeks, starting today
let _ = TT::today()
    .every(TT::week(1))
    .take(4);

// get an iterator of dates for the next year, in a weekly fashion, starting
// today but skipping october
let _ = TT::today()
    .every(TT::week(1))
    .skip(Month::October)
    .until(Mark::END_OF_YEAR);

// and finally, a complex one

let _ = (TT::today() - TT::years(1))       // exactly one year ago
  .every(Day::Monday)                      // and then every Monday
  .skip(Month::October)                    // but not in october
  .skip(|date| date.is(Mark::MONTH_START)) // and not if the day is the 1st of a month
  .until(Mark::Moment(today()));           // until today

Parsing User-Input

kairos ships a user input parser, so you can include kairos in your commandline applications.

Have a look at the example CLI utility or the language documentation.

License

MPL 2.0

Dependencies

~2–3MB
~54K SLoC