Serde Millis ============ [Documentation](https://docs.rs/serde_millis) | [Github](https://github.com/tailhook/serde-millis) | [Crate](https://crates.io/crates/serde_millis) A serde wrapper, that can be used to serialize timestamps and durations as milliseconds. It's often useful together with `serde_json` to communicate with Javascript. Example ------- ```rust #[macro_use] extern crate serde_derive; extern crate serde; extern crate serde_millis; use std::time::{Duration, SystemTime, Instant}; #[derive(Serialize, Deserialize)] struct Timestamps { #[serde(with = "serde_millis")] time: SystemTime, #[serde(with = "serde_millis")] latency: Duration, // Instant is serialized relative to the current time, or in // other words by formula (but works for future instants too): // // ts = SystemTime::now() - (Instant::now() - target_instant) // #[serde(with = "serde_millis")] timestamp: Instant, } ``` License ======= Licensed under either of * Apache License, Version 2.0, (./LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0) * MIT license (./LICENSE-MIT or http://opensource.org/licenses/MIT) at your option. Contribution ------------ Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.