diff options
| author | Jorge Aparicio <japaricious@gmail.com> | 2014-12-01 14:32:36 -0500 |
|---|---|---|
| committer | Jorge Aparicio <japaricious@gmail.com> | 2014-12-13 20:15:39 -0500 |
| commit | 9126a24e423a8339230f1dde7e36f79faaeaa9d3 (patch) | |
| tree | aa4e83413b0fa1daf8106a5328077de86597623d /src/libstd | |
| parent | 32168faf9f7a9e634647b86c1a671ae68dbe9c9d (diff) | |
| download | rust-9126a24e423a8339230f1dde7e36f79faaeaa9d3.tar.gz rust-9126a24e423a8339230f1dde7e36f79faaeaa9d3.zip | |
libstd: convert `Duration` binops to by value
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/time/duration.rs | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/libstd/time/duration.rs b/src/libstd/time/duration.rs index 34a3d6aa275..f98cebd9675 100644 --- a/src/libstd/time/duration.rs +++ b/src/libstd/time/duration.rs @@ -276,6 +276,8 @@ impl Neg<Duration> for Duration { } } +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Add<Duration,Duration> for Duration { fn add(&self, rhs: &Duration) -> Duration { let mut secs = self.secs + rhs.secs; @@ -288,6 +290,21 @@ impl Add<Duration,Duration> for Duration { } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Add<Duration, Duration> for Duration { + fn add(self, rhs: Duration) -> Duration { + let mut secs = self.secs + rhs.secs; + let mut nanos = self.nanos + rhs.nanos; + if nanos >= NANOS_PER_SEC { + nanos -= NANOS_PER_SEC; + secs += 1; + } + Duration { secs: secs, nanos: nanos } + } +} + +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Sub<Duration,Duration> for Duration { fn sub(&self, rhs: &Duration) -> Duration { let mut secs = self.secs - rhs.secs; @@ -300,6 +317,21 @@ impl Sub<Duration,Duration> for Duration { } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Sub<Duration, Duration> for Duration { + fn sub(self, rhs: Duration) -> Duration { + let mut secs = self.secs - rhs.secs; + let mut nanos = self.nanos - rhs.nanos; + if nanos < 0 { + nanos += NANOS_PER_SEC; + secs -= 1; + } + Duration { secs: secs, nanos: nanos } + } +} + +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Mul<i32,Duration> for Duration { fn mul(&self, rhs: &i32) -> Duration { // Multiply nanoseconds as i64, because it cannot overflow that way. @@ -310,6 +342,19 @@ impl Mul<i32,Duration> for Duration { } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Mul<i32, Duration> for Duration { + fn mul(self, rhs: i32) -> Duration { + // Multiply nanoseconds as i64, because it cannot overflow that way. + let total_nanos = self.nanos as i64 * rhs as i64; + let (extra_secs, nanos) = div_mod_floor_64(total_nanos, NANOS_PER_SEC as i64); + let secs = self.secs * rhs as i64 + extra_secs; + Duration { secs: secs, nanos: nanos as i32 } + } +} + +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Div<i32,Duration> for Duration { fn div(&self, rhs: &i32) -> Duration { let mut secs = self.secs / *rhs as i64; @@ -328,6 +373,25 @@ impl Div<i32,Duration> for Duration { } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Div<i32, Duration> for Duration { + fn div(self, rhs: i32) -> Duration { + let mut secs = self.secs / rhs as i64; + let carry = self.secs - secs * rhs as i64; + let extra_nanos = carry * NANOS_PER_SEC as i64 / rhs as i64; + let mut nanos = self.nanos / rhs + extra_nanos as i32; + if nanos >= NANOS_PER_SEC { + nanos -= NANOS_PER_SEC; + secs += 1; + } + if nanos < 0 { + nanos += NANOS_PER_SEC; + secs -= 1; + } + Duration { secs: secs, nanos: nanos } + } +} + impl fmt::Show for Duration { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { // technically speaking, negative duration is not valid ISO 8601, |
