1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
pub trait DivRemEuclid<Divisor = Self> {
type Output;
/// Returns quotient and remainder of euclidean division.
/// ```
/// use traiter::numbers::DivRemEuclid;
/// // signed integers
/// assert_eq!(DivRemEuclid::div_rem_euclid(-3i8, 3i8), (-1i8, 0i8));
/// assert_eq!(DivRemEuclid::div_rem_euclid(-3i8, 2i8), (-2i8, 1i8));
/// assert_eq!(DivRemEuclid::div_rem_euclid(-3i8, 1i8), (-3i8, 0i8));
/// // unsigned integers
/// assert_eq!(DivRemEuclid::div_rem_euclid(3u8, 3u8), (1u8, 0u8));
/// assert_eq!(DivRemEuclid::div_rem_euclid(3u8, 2u8), (1u8, 1u8));
/// assert_eq!(DivRemEuclid::div_rem_euclid(3u8, 1u8), (3u8, 0u8));
/// ```
fn div_rem_euclid(self, divisor: Divisor) -> Self::Output;
}
macro_rules! integer_div_rem_euclid_impl {
($($integer:ty)*) => ($(
impl DivRemEuclid for $integer {
type Output = (Self, Self);
#[inline(always)]
fn div_rem_euclid(self, divisor: Self) -> Self::Output {
(
<$integer>::div_euclid(self, divisor),
<$integer>::rem_euclid(self, divisor),
)
}
}
)*)
}
integer_div_rem_euclid_impl!(
i8 i16 i32 i64 i128 isize u8 u16 u32 u64 u128 usize
);