Trait sp_std::ops::SubAssign

1.8.0 · source · []
pub trait SubAssign<Rhs = Self> {
    fn sub_assign(&mut self, rhs: Rhs);
}
Expand description

The subtraction assignment operator -=.

Examples

This example creates a Point struct that implements the SubAssign trait, and then demonstrates sub-assigning to a mutable Point.

use std::ops::SubAssign;

#[derive(Debug, Copy, Clone, PartialEq)]
struct Point {
    x: i32,
    y: i32,
}

impl SubAssign for Point {
    fn sub_assign(&mut self, other: Self) {
        *self = Self {
            x: self.x - other.x,
            y: self.y - other.y,
        };
    }
}

let mut point = Point { x: 3, y: 3 };
point -= Point { x: 2, y: 3 };
assert_eq!(point, Point {x: 1, y: 0});

Required methods

Performs the -= operation.

Example
let mut x: u32 = 12;
x -= 1;
assert_eq!(x, 11);

Implementations on Foreign Types

Implementors

impl<'b> SubAssign<&'b Scalar> for Scalar

impl<T: Into<Ready>> SubAssign<T> for Ready

impl<'b, T, R1, C1, R2, C2, SA, SB> SubAssign<&'b Matrix<T, R2, C2, SB>> for Matrix<T, R1, C1, SA> where
    R1: Dim,
    C1: Dim,
    R2: Dim,
    C2: Dim,
    T: Scalar + ClosedSub,
    SA: StorageMut<T, R1, C1>,
    SB: Storage<T, R2, C2>,
    ShapeConstraint: SameNumberOfRows<R1, R2> + SameNumberOfColumns<C1, C2>, 

impl<T, R1, C1, R2, C2, SA, SB> SubAssign<Matrix<T, R2, C2, SB>> for Matrix<T, R1, C1, SA> where
    R1: Dim,
    C1: Dim,
    R2: Dim,
    C2: Dim,
    T: Scalar + ClosedSub,
    SA: StorageMut<T, R1, C1>,
    SB: Storage<T, R2, C2>,
    ShapeConstraint: SameNumberOfRows<R1, R2> + SameNumberOfColumns<C1, C2>, 

impl<'b, T, D2: Dim, SB, const D1: usize> SubAssign<&'b Matrix<T, D2, Const<1_usize>, SB>> for Point<T, D1> where
    T: Scalar + ClosedSub,
    SB: Storage<T, D2>,
    ShapeConstraint: SameNumberOfRows<Const<D1>, D2>, 

impl<T, D2: Dim, SB, const D1: usize> SubAssign<Matrix<T, D2, Const<1_usize>, SB>> for Point<T, D1> where
    T: Scalar + ClosedSub,
    SB: Storage<T, D2>,
    ShapeConstraint: SameNumberOfRows<Const<D1>, D2>, 

impl<'b, T: SimdRealField> SubAssign<&'b Quaternion<T>> for Quaternion<T> where
    T::Element: SimdRealField

impl<T: SimdRealField> SubAssign<Quaternion<T>> for Quaternion<T> where
    T::Element: SimdRealField

impl<'b, T: SimdRealField> SubAssign<&'b DualQuaternion<T>> for DualQuaternion<T> where
    T::Element: SimdRealField

impl<'a> SubAssign<&'a BigInt> for BigInt

impl SubAssign<u8> for BigInt

impl SubAssign<u16> for BigInt

impl SubAssign<i8> for BigInt

impl SubAssign<i16> for BigInt

impl SubAssign<u32> for BigInt

impl SubAssign<u64> for BigInt

impl SubAssign<i32> for BigInt

impl SubAssign<i64> for BigInt

impl<'a> SubAssign<&'a BigUint> for BigUint

impl SubAssign<u8> for BigUint

impl<T: Clone + NumAssign> SubAssign<Complex<T>> for Complex<T>

impl<T: Clone + NumAssign> SubAssign<T> for Complex<T>

impl<'a, T: Clone + NumAssign> SubAssign<&'a Complex<T>> for Complex<T>

impl<'a, T: Clone + NumAssign> SubAssign<&'a T> for Complex<T>

impl<T: Clone + Integer + NumAssign> SubAssign<Ratio<T>> for Ratio<T>

impl<T: Clone + Integer + NumAssign> SubAssign<T> for Ratio<T>

impl<'a, T: Clone + Integer + NumAssign> SubAssign<&'a Ratio<T>> for Ratio<T>

impl<'a, T: Clone + Integer + NumAssign> SubAssign<&'a T> for Ratio<T>

impl SubAssign<U128> for U128

impl SubAssign<U256> for U256

impl SubAssign<U512> for U512