| 1 | use std::str::FromStr; |
| 2 | use std::ops::Deref; |
| 3 | use std::fmt; |
| 4 | use std::time::{Duration as StdDuration, SystemTime}; |
| 5 | |
| 6 | use crate::duration::{self, parse_duration, format_duration}; |
| 7 | use crate::date::{self, parse_rfc3339_weak, format_rfc3339}; |
| 8 | |
| 9 | /// A wrapper for duration that has `FromStr` implementation |
| 10 | /// |
| 11 | /// This is useful if you want to use it somewhere where `FromStr` is |
| 12 | /// expected. |
| 13 | /// |
| 14 | /// See `parse_duration` for the description of the format. |
| 15 | /// |
| 16 | /// # Example |
| 17 | /// |
| 18 | /// ``` |
| 19 | /// use std::time::Duration; |
| 20 | /// let x: Duration; |
| 21 | /// x = "12h 5min 2ns" .parse::<humantime::Duration>().unwrap().into(); |
| 22 | /// assert_eq!(x, Duration::new(12*3600 + 5*60, 2)) |
| 23 | /// ``` |
| 24 | /// |
| 25 | #[derive (Debug, PartialEq, Eq, Hash, Clone, Copy)] |
| 26 | pub struct Duration(StdDuration); |
| 27 | |
| 28 | /// A wrapper for SystemTime that has `FromStr` implementation |
| 29 | /// |
| 30 | /// This is useful if you want to use it somewhere where `FromStr` is |
| 31 | /// expected. |
| 32 | /// |
| 33 | /// See `parse_rfc3339_weak` for the description of the format. The "weak" |
| 34 | /// format is used as it's more pemissive for human input as this is the |
| 35 | /// expected use of the type (e.g. command-line parsing). |
| 36 | /// |
| 37 | /// # Example |
| 38 | /// |
| 39 | /// ``` |
| 40 | /// use std::time::SystemTime; |
| 41 | /// let x: SystemTime; |
| 42 | /// x = "2018-02-16T00:31:37Z" .parse::<humantime::Timestamp>().unwrap().into(); |
| 43 | /// assert_eq!(humantime::format_rfc3339(x).to_string(), "2018-02-16T00:31:37Z" ); |
| 44 | /// ``` |
| 45 | /// |
| 46 | #[derive (Debug, PartialEq, Eq, Clone)] |
| 47 | pub struct Timestamp(SystemTime); |
| 48 | |
| 49 | impl AsRef<StdDuration> for Duration { |
| 50 | fn as_ref(&self) -> &StdDuration { &self.0 } |
| 51 | } |
| 52 | |
| 53 | impl Deref for Duration { |
| 54 | type Target = StdDuration; |
| 55 | fn deref(&self) -> &StdDuration { &self.0 } |
| 56 | } |
| 57 | |
| 58 | impl Into<StdDuration> for Duration { |
| 59 | fn into(self) -> StdDuration { self.0 } |
| 60 | } |
| 61 | |
| 62 | impl From<StdDuration> for Duration { |
| 63 | fn from(dur: StdDuration) -> Duration { Duration(dur) } |
| 64 | } |
| 65 | |
| 66 | impl FromStr for Duration { |
| 67 | type Err = duration::Error; |
| 68 | fn from_str(s: &str) -> Result<Duration, Self::Err> { |
| 69 | parse_duration(s).map(op:Duration) |
| 70 | } |
| 71 | } |
| 72 | |
| 73 | impl fmt::Display for Duration { |
| 74 | fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { |
| 75 | format_duration(self.0).fmt(f) |
| 76 | } |
| 77 | } |
| 78 | |
| 79 | impl AsRef<SystemTime> for Timestamp { |
| 80 | fn as_ref(&self) -> &SystemTime { &self.0 } |
| 81 | } |
| 82 | |
| 83 | impl Deref for Timestamp { |
| 84 | type Target = SystemTime; |
| 85 | fn deref(&self) -> &SystemTime { &self.0 } |
| 86 | } |
| 87 | |
| 88 | impl Into<SystemTime> for Timestamp { |
| 89 | fn into(self) -> SystemTime { self.0 } |
| 90 | } |
| 91 | |
| 92 | impl From<SystemTime> for Timestamp { |
| 93 | fn from(dur: SystemTime) -> Timestamp { Timestamp(dur) } |
| 94 | } |
| 95 | |
| 96 | impl FromStr for Timestamp { |
| 97 | type Err = date::Error; |
| 98 | fn from_str(s: &str) -> Result<Timestamp, Self::Err> { |
| 99 | parse_rfc3339_weak(s).map(op:Timestamp) |
| 100 | } |
| 101 | } |
| 102 | |
| 103 | impl fmt::Display for Timestamp { |
| 104 | fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { |
| 105 | format_rfc3339(self.0).fmt(f) |
| 106 | } |
| 107 | } |
| 108 | |