diff options
Diffstat (limited to 'third_party/rust/chrono/src/div.rs')
-rw-r--r-- | third_party/rust/chrono/src/div.rs | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/third_party/rust/chrono/src/div.rs b/third_party/rust/chrono/src/div.rs new file mode 100644 index 0000000000..64b8e4bce4 --- /dev/null +++ b/third_party/rust/chrono/src/div.rs @@ -0,0 +1,41 @@ +// This is a part of Chrono. +// Portions Copyright 2013-2014 The Rust Project Developers. +// See README.md and LICENSE.txt for details. + +//! Integer division utilities. (Shamelessly copied from [num](https://github.com/rust-lang/num/)) + +// Algorithm from [Daan Leijen. _Division and Modulus for Computer Scientists_, +// December 2001](http://research.microsoft.com/pubs/151917/divmodnote-letter.pdf) + +pub use num_integer::{div_floor, div_mod_floor, div_rem, mod_floor}; + +#[cfg(test)] +mod tests { + use super::{div_mod_floor, mod_floor}; + + #[test] + fn test_mod_floor() { + assert_eq!(mod_floor(8, 3), 2); + assert_eq!(mod_floor(8, -3), -1); + assert_eq!(mod_floor(-8, 3), 1); + assert_eq!(mod_floor(-8, -3), -2); + + assert_eq!(mod_floor(1, 2), 1); + assert_eq!(mod_floor(1, -2), -1); + assert_eq!(mod_floor(-1, 2), 1); + assert_eq!(mod_floor(-1, -2), -1); + } + + #[test] + fn test_div_mod_floor() { + assert_eq!(div_mod_floor(8, 3), (2, 2)); + assert_eq!(div_mod_floor(8, -3), (-3, -1)); + assert_eq!(div_mod_floor(-8, 3), (-3, 1)); + assert_eq!(div_mod_floor(-8, -3), (2, -2)); + + assert_eq!(div_mod_floor(1, 2), (0, 1)); + assert_eq!(div_mod_floor(1, -2), (-1, -1)); + assert_eq!(div_mod_floor(-1, 2), (-1, 1)); + assert_eq!(div_mod_floor(-1, -2), (0, -1)); + } +} |