1.0.0[][src]Trait nom::lib::std::ops::Rem

#[lang = "rem"]
pub trait Rem<RHS = Self> { type Output = Self;
#[must_use]
fn rem(self, rhs: RHS) -> Self::Output; }

The remainder operator %.

Note that RHS is Self by default, but this is not mandatory.

Examples

This example implements Rem on a SplitSlice object. After Rem is implemented, one can use the % operator to find out what the remaining elements of the slice would be after splitting it into equal slices of a given length.

use std::ops::Rem;

#[derive(PartialEq, Debug)]
struct SplitSlice<'a, T: 'a> {
    slice: &'a [T],
}

impl<'a, T> Rem<usize> for SplitSlice<'a, T> {
    type Output = SplitSlice<'a, T>;

    fn rem(self, modulus: usize) -> Self {
        let len = self.slice.len();
        let rem = len % modulus;
        let start = len - rem;
        SplitSlice {slice: &self.slice[start..]}
    }
}

// If we were to divide &[0, 1, 2, 3, 4, 5, 6, 7] into slices of size 3,
// the remainder would be &[6, 7].
assert_eq!(SplitSlice { slice: &[0, 1, 2, 3, 4, 5, 6, 7] } % 3,
           SplitSlice { slice: &[6, 7] });

Associated Types

The resulting type after applying the % operator.

Required Methods

Performs the % operation.

Implementations on Foreign Types

impl<'a> Rem<u128> for &'a u128
[src]

impl<'a> Rem<&'a Wrapping<i8>> for Wrapping<i8>
[src]

impl<'a> Rem<u32> for &'a u32
[src]

impl<'a> Rem<&'a f64> for f64
[src]

impl Rem<Wrapping<u8>> for Wrapping<u8>
[src]

impl Rem<isize> for isize
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a, 'b> Rem<&'a Wrapping<i8>> for &'b Wrapping<i8>
[src]

impl<'a, 'b> Rem<&'a f64> for &'b f64
[src]

impl<'a> Rem<&'a u8> for u8
[src]

impl<'a> Rem<&'a u16> for u16
[src]

impl Rem<u64> for u64
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a, 'b> Rem<&'a f32> for &'b f32
[src]

impl<'a, 'b> Rem<&'a Wrapping<u64>> for &'b Wrapping<u64>
[src]

impl<'a> Rem<&'a u128> for u128
[src]

impl<'a> Rem<i64> for &'a i64
[src]

impl<'a, 'b> Rem<&'a u128> for &'b u128
[src]

impl<'a, 'b> Rem<&'a Wrapping<i32>> for &'b Wrapping<i32>
[src]

impl Rem<Wrapping<i64>> for Wrapping<i64>
[src]

impl Rem<f64> for f64
[src]

impl Rem<u32> for u32
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a> Rem<&'a Wrapping<i128>> for Wrapping<i128>
[src]

impl<'a, 'b> Rem<&'a u32> for &'b u32
[src]

impl Rem<Wrapping<u128>> for Wrapping<u128>
[src]

impl<'a> Rem<i16> for &'a i16
[src]

impl<'a> Rem<Wrapping<i64>> for &'a Wrapping<i64>
[src]

impl<'a, 'b> Rem<&'a Wrapping<isize>> for &'b Wrapping<isize>
[src]

impl<'a> Rem<Wrapping<u128>> for &'a Wrapping<u128>
[src]

impl<'a, 'b> Rem<&'a isize> for &'b isize
[src]

impl Rem<Wrapping<i8>> for Wrapping<i8>
[src]

impl<'a> Rem<&'a i16> for i16
[src]

impl<'a> Rem<Wrapping<i128>> for &'a Wrapping<i128>
[src]

impl Rem<u8> for u8
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a> Rem<i32> for &'a i32
[src]

impl Rem<Wrapping<isize>> for Wrapping<isize>
[src]

impl<'a> Rem<&'a Wrapping<u128>> for Wrapping<u128>
[src]

impl<'a> Rem<&'a i128> for i128
[src]

impl Rem<Wrapping<u64>> for Wrapping<u64>
[src]

impl Rem<Wrapping<i128>> for Wrapping<i128>
[src]

impl<'a> Rem<&'a u64> for u64
[src]

impl<'a> Rem<Wrapping<i32>> for &'a Wrapping<i32>
[src]

impl<'a, 'b> Rem<&'a i8> for &'b i8
[src]

impl Rem<i64> for i64
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a> Rem<&'a i64> for i64
[src]

impl Rem<usize> for usize
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a> Rem<&'a Wrapping<i64>> for Wrapping<i64>
[src]

impl<'a> Rem<Wrapping<usize>> for &'a Wrapping<usize>
[src]

impl<'a, 'b> Rem<&'a i128> for &'b i128
[src]

impl<'a, 'b> Rem<&'a Wrapping<u128>> for &'b Wrapping<u128>
[src]

impl<'a> Rem<u16> for &'a u16
[src]

impl<'a> Rem<Wrapping<i16>> for &'a Wrapping<i16>
[src]

impl<'a> Rem<&'a u32> for u32
[src]

impl<'a> Rem<&'a Wrapping<i32>> for Wrapping<i32>
[src]

impl Rem<i16> for i16
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a> Rem<Wrapping<isize>> for &'a Wrapping<isize>
[src]

impl<'a, 'b> Rem<&'a Wrapping<i128>> for &'b Wrapping<i128>
[src]

impl<'a, 'b> Rem<&'a Wrapping<i16>> for &'b Wrapping<i16>
[src]

impl<'a> Rem<Wrapping<u32>> for &'a Wrapping<u32>
[src]

impl<'a> Rem<&'a Wrapping<usize>> for Wrapping<usize>
[src]

impl Rem<Wrapping<usize>> for Wrapping<usize>
[src]

impl<'a, 'b> Rem<&'a Wrapping<usize>> for &'b Wrapping<usize>
[src]

impl Rem<i8> for i8
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl Rem<Wrapping<u16>> for Wrapping<u16>
[src]

impl Rem<i32> for i32
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a, 'b> Rem<&'a i64> for &'b i64
[src]

impl<'a, 'b> Rem<&'a usize> for &'b usize
[src]

impl<'a, 'b> Rem<&'a i16> for &'b i16
[src]

impl<'a> Rem<&'a isize> for isize
[src]

impl Rem<Wrapping<u32>> for Wrapping<u32>
[src]

impl<'a, 'b> Rem<&'a Wrapping<u8>> for &'b Wrapping<u8>
[src]

impl<'a, 'b> Rem<&'a u64> for &'b u64
[src]

impl<'a> Rem<&'a usize> for usize
[src]

impl Rem<i128> for i128
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a> Rem<f64> for &'a f64
[src]

impl<'a> Rem<Wrapping<i8>> for &'a Wrapping<i8>
[src]

impl<'a> Rem<usize> for &'a usize
[src]

impl Rem<f32> for f32
[src]

impl<'a> Rem<&'a Wrapping<u32>> for Wrapping<u32>
[src]

impl<'a> Rem<u8> for &'a u8
[src]

impl Rem<Wrapping<i16>> for Wrapping<i16>
[src]

impl<'a> Rem<i8> for &'a i8
[src]

impl Rem<u128> for u128
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a, 'b> Rem<&'a u8> for &'b u8
[src]

impl<'a, 'b> Rem<&'a Wrapping<u32>> for &'b Wrapping<u32>
[src]

impl<'a> Rem<&'a Wrapping<u64>> for Wrapping<u64>
[src]

impl<'a, 'b> Rem<&'a u16> for &'b u16
[src]

impl<'a> Rem<i128> for &'a i128
[src]

impl<'a> Rem<&'a Wrapping<i16>> for Wrapping<i16>
[src]

impl<'a> Rem<isize> for &'a isize
[src]

impl<'a> Rem<&'a Wrapping<isize>> for Wrapping<isize>
[src]

impl<'a> Rem<&'a i8> for i8
[src]

impl<'a> Rem<u64> for &'a u64
[src]

impl<'a> Rem<&'a f32> for f32
[src]

impl<'a> Rem<&'a i32> for i32
[src]

impl<'a> Rem<f32> for &'a f32
[src]

impl<'a> Rem<&'a Wrapping<u8>> for Wrapping<u8>
[src]

impl<'a> Rem<Wrapping<u8>> for &'a Wrapping<u8>
[src]

impl<'a> Rem<Wrapping<u64>> for &'a Wrapping<u64>
[src]

impl<'a, 'b> Rem<&'a Wrapping<u16>> for &'b Wrapping<u16>
[src]

impl<'a, 'b> Rem<&'a Wrapping<i64>> for &'b Wrapping<i64>
[src]

impl<'a> Rem<Wrapping<u16>> for &'a Wrapping<u16>
[src]

impl<'a> Rem<&'a Wrapping<u16>> for Wrapping<u16>
[src]

impl Rem<Wrapping<i32>> for Wrapping<i32>
[src]

impl Rem<u16> for u16
[src]

This operation satisfies n % d == n - (n / d) * d. The result has the same sign as the left operand.

impl<'a, 'b> Rem<&'a i32> for &'b i32
[src]

Implementors