datetime_default/lib.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
//! # DateTime NewType set for default time
//!
//! [](https://crates.io/crates/datetime-default)
//! [](https://github.com/Naereen/StrapDown.js/blob/master/LICENSE)
//!
//! When you want to use `#[derive(Default)]` to a struct, you may want the current time to be the default for `DateTime`.
//! For this purpose, we have provided NewType that overrides the default value.
//!
//! ## Features
//! ### DateTimeDefaultNow
//! DateTime with current time as default.
//!
//! ```should_panic
//! use chrono::{Local, TimeZone};
//! use datetime_default::DateTimeDefaultNow;
//!
//! assert_eq!(
//! DateTimeDefaultNow::<Local>::default(),
//! Local.datetime_from_str("2022/10/10 23:40:11.695164300", "%Y/%m/%d %H:%M:%S%.9f").unwrap()
//! );
//! ```
//!
//! ### DateTimeDefaultUnix
//! DateTime with UNIX epoch as default.
//!
//! ```
//! use chrono::{Utc, TimeZone};
//! use datetime_default::DateTimeDefaultUnix;
//!
//! assert_eq!(
//! DateTimeDefaultUnix::<Utc>::default(),
//! Utc.datetime_from_str("1970/1/1 00:00:00", "%Y/%m/%d %H:%M:%S").unwrap()
//! );
//! ```
//!
//! ### Default Datetime with TimeZone
//!
//! ```
//! use chrono::{DateTime, FixedOffset, TimeZone};
//! use datetime_default::DateTimeDefaultUnix;
//!
//! assert_eq!(
//! DateTimeDefaultUnix::<FixedOffset, 9>::default(),
//! DateTime::parse_from_rfc3339("1970-01-01T09:00:00+09:00").unwrap()
//! );
//! ```
//!
mod const_assert;
mod datetime_default;
mod datetime_default_now;
mod datetime_default_unix;
mod features;
pub use datetime_default_now::DateTimeDefaultNow;
pub use datetime_default_unix::DateTimeDefaultUnix;