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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
pub trait WrappingDivRemEuclid<Divisor = Self> {
type Output;
/// Returns quotient and remainder of wrapping Euclidean division.
/// ```
/// use traiter::numbers::WrappingDivRemEuclid;
/// // signed integers
/// assert_eq!(
/// WrappingDivRemEuclid::wrapping_div_rem_euclid(-3i8, 3i8),
/// (-1i8, 0i8)
/// );
/// assert_eq!(
/// WrappingDivRemEuclid::wrapping_div_rem_euclid(-3i8, 2i8),
/// (-2i8, 1i8)
/// );
/// assert_eq!(
/// WrappingDivRemEuclid::wrapping_div_rem_euclid(i8::MIN, -1i8),
/// (i8::MIN, 0i8)
/// );
/// // unsigned integers
/// assert_eq!(
/// WrappingDivRemEuclid::wrapping_div_rem_euclid(3u8, 3u8),
/// (1u8, 0u8)
/// );
/// assert_eq!(
/// WrappingDivRemEuclid::wrapping_div_rem_euclid(3u8, 2u8),
/// (1u8, 1u8)
/// );
/// assert_eq!(
/// WrappingDivRemEuclid::wrapping_div_rem_euclid(3u8, 1u8),
/// (3u8, 0u8)
/// );
/// ```
fn wrapping_div_rem_euclid(self, divisor: Divisor) -> Self::Output;
}
macro_rules! integer_wrapping_div_rem_euclid_impl {
($($integer:ty)*) => ($(
impl WrappingDivRemEuclid for $integer {
type Output = (Self, Self);
#[inline(always)]
fn wrapping_div_rem_euclid(self, divisor: Self) -> Self::Output {
(
<$integer>::wrapping_div_euclid(self, divisor),
<$integer>::wrapping_rem_euclid(self, divisor),
)
}
}
)*)
}
integer_wrapping_div_rem_euclid_impl!(
i8 i16 i32 i64 i128 isize u8 u16 u32 u64 u128 usize
);