about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorKevin Ballard <kevin@sb.org>2013-08-18 23:23:29 -0700
committerKevin Ballard <kevin@sb.org>2013-08-19 01:01:11 -0700
commitac3bc9cfcc6ac884311f9bed6853e36fd40868f4 (patch)
tree6f1a6551a97e855cb2bbf924eb203742e374db4b /src/libstd
parent8fff3f40f290df5bcd25bcefdc0e19f74d0af0a5 (diff)
downloadrust-ac3bc9cfcc6ac884311f9bed6853e36fd40868f4.tar.gz
rust-ac3bc9cfcc6ac884311f9bed6853e36fd40868f4.zip
Fix mod_floor() for uint primitive types
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/num/uint_macros.rs17
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);