diff options
| author | Kevin Ballard <kevin@sb.org> | 2013-08-18 23:23:29 -0700 |
|---|---|---|
| committer | Kevin Ballard <kevin@sb.org> | 2013-08-19 01:01:11 -0700 |
| commit | ac3bc9cfcc6ac884311f9bed6853e36fd40868f4 (patch) | |
| tree | 6f1a6551a97e855cb2bbf924eb203742e374db4b /src/libstd/num | |
| parent | 8fff3f40f290df5bcd25bcefdc0e19f74d0af0a5 (diff) | |
| download | rust-ac3bc9cfcc6ac884311f9bed6853e36fd40868f4.tar.gz rust-ac3bc9cfcc6ac884311f9bed6853e36fd40868f4.zip | |
Fix mod_floor() for uint primitive types
Diffstat (limited to 'src/libstd/num')
| -rw-r--r-- | src/libstd/num/uint_macros.rs | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/src/libstd/num/uint_macros.rs b/src/libstd/num/uint_macros.rs index 86b5b4ddfc0..f296c7fc92a 100644 --- a/src/libstd/num/uint_macros.rs +++ b/src/libstd/num/uint_macros.rs @@ -227,9 +227,9 @@ impl Integer for $T { /// Unsigned integer modulo operation. Returns the same result as `rem` (`%`). #[inline] - fn mod_floor(&self, other: &$T) -> $T { *self / *other } + fn mod_floor(&self, other: &$T) -> $T { *self % *other } - /// Calculates `div_floor` and `modulo_floor` simultaneously + /// Calculates `div_floor` and `mod_floor` simultaneously #[inline] fn div_mod_floor(&self, other: &$T) -> ($T,$T) { (*self / *other, *self % *other) @@ -459,6 +459,19 @@ mod tests { } #[test] + fn test_div_mod_floor() { + assert_eq!((10 as $T).div_floor(&(3 as $T)), 3 as $T); + assert_eq!((10 as $T).mod_floor(&(3 as $T)), 1 as $T); + assert_eq!((10 as $T).div_mod_floor(&(3 as $T)), (3 as $T, 1 as $T)); + assert_eq!((5 as $T).div_floor(&(5 as $T)), 1 as $T); + assert_eq!((5 as $T).mod_floor(&(5 as $T)), 0 as $T); + assert_eq!((5 as $T).div_mod_floor(&(5 as $T)), (1 as $T, 0 as $T)); + assert_eq!((3 as $T).div_floor(&(7 as $T)), 0 as $T); + assert_eq!((3 as $T).mod_floor(&(7 as $T)), 3 as $T); + assert_eq!((3 as $T).div_mod_floor(&(7 as $T)), (0 as $T, 3 as $T)); + } + + #[test] fn test_gcd() { assert_eq!((10 as $T).gcd(&2), 2 as $T); assert_eq!((10 as $T).gcd(&3), 1 as $T); |
