Trait Sub

1.0.0 · Source
pub trait Sub<Rhs = Self> {
    type Output;

    // Required method
    fn sub(self, rhs: Rhs) -> Self::Output;
}
Expand description

The subtraction operator -.

Note that Rhs is Self by default, but this is not mandatory. For example, std::time::SystemTime implements Sub<Duration>, which permits operations of the form SystemTime = SystemTime - Duration.

§Examples

§Subtractable points

use std::ops::Sub;

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

impl Sub for Point {
    type Output = Self;

    fn sub(self, other: Self) -> Self::Output {
        Self {
            x: self.x - other.x,
            y: self.y - other.y,
        }
    }
}

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

§Implementing Sub with generics

Here is an example of the same Point struct implementing the Sub trait using generics.

use std::ops::Sub;

#[derive(Debug, PartialEq)]
struct Point<T> {
    x: T,
    y: T,
}

// Notice that the implementation uses the associated type `Output`.
impl<T: Sub<Output = T>> Sub for Point<T> {
    type Output = Self;

    fn sub(self, other: Self) -> Self::Output {
        Point {
            x: self.x - other.x,
            y: self.y - other.y,
        }
    }
}

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

Required Associated Types§

1.0.0 · Source

type Output

The resulting type after applying the - operator.

Required Methods§

1.0.0 · Source

fn sub(self, rhs: Rhs) -> Self::Output

Performs the - operation.

§Example
assert_eq!(12 - 1, 11);

Implementors§

1.0.0 · Source§

impl Sub for f16

1.0.0 · Source§

impl Sub for f32

1.0.0 · Source§

impl Sub for f64

1.0.0 · Source§

impl Sub for f128

1.0.0 · Source§

impl Sub for i8

1.0.0 · Source§

impl Sub for i16

1.0.0 · Source§

impl Sub for i32

1.0.0 · Source§

impl Sub for i64

1.0.0 · Source§

impl Sub for i128

1.0.0 · Source§

impl Sub for isize

1.0.0 · Source§

impl Sub for u8

1.0.0 · Source§

impl Sub for u16

1.0.0 · Source§

impl Sub for u32

1.0.0 · Source§

impl Sub for u64

1.0.0 · Source§

impl Sub for u128

1.0.0 · Source§

impl Sub for usize

Source§

impl Sub for Assume

Source§

impl Sub for Decimal

Source§

impl Sub for EnabledModules

Source§

impl Sub for EventFlags

Source§

impl Sub for I192

Source§

impl Sub for I256

Source§

impl Sub for I320

Source§

impl Sub for I384

Source§

impl Sub for I448

Source§

impl Sub for I512

Source§

impl Sub for I768

Source§

impl Sub for LockFlags

Source§

impl Sub for PreciseDecimal

Source§

impl Sub for U192

Source§

impl Sub for U256

Source§

impl Sub for U320

Source§

impl Sub for U384

Source§

impl Sub for U448

Source§

impl Sub for U512

Source§

impl Sub for U768

Source§

impl Sub for VaultFreezeFlags

1.74.0 · Source§

impl Sub for Saturating<i8>

1.74.0 · Source§

impl Sub for Saturating<i16>

1.74.0 · Source§

impl Sub for Saturating<i32>

1.74.0 · Source§

impl Sub for Saturating<i64>

1.74.0 · Source§

impl Sub for Saturating<i128>

1.74.0 · Source§

impl Sub for Saturating<isize>

1.74.0 · Source§

impl Sub for Saturating<u8>

1.74.0 · Source§

impl Sub for Saturating<u16>

1.74.0 · Source§

impl Sub for Saturating<u32>

1.74.0 · Source§

impl Sub for Saturating<u64>

1.74.0 · Source§

impl Sub for Saturating<u128>

1.74.0 · Source§

impl Sub for Saturating<usize>

1.0.0 · Source§

impl Sub for Wrapping<i8>

1.0.0 · Source§

impl Sub for Wrapping<i16>

1.0.0 · Source§

impl Sub for Wrapping<i32>

1.0.0 · Source§

impl Sub for Wrapping<i64>

1.0.0 · Source§

impl Sub for Wrapping<i128>

1.0.0 · Source§

impl Sub for Wrapping<isize>

1.0.0 · Source§

impl Sub for Wrapping<u8>

1.0.0 · Source§

impl Sub for Wrapping<u16>

1.0.0 · Source§

impl Sub for Wrapping<u32>

1.0.0 · Source§

impl Sub for Wrapping<u64>

1.0.0 · Source§

impl Sub for Wrapping<u128>

1.0.0 · Source§

impl Sub for Wrapping<usize>

1.3.0 · Source§

impl Sub for Duration

1.8.0 · Source§

impl Sub for Instant

Source§

impl Sub for Effects

§Examples

let effects = (anstyle::Effects::BOLD | anstyle::Effects::UNDERLINE) - anstyle::Effects::BOLD;
assert_eq!(format!("{:?}", effects), "Effects(UNDERLINE)");
Source§

impl Sub for EdwardsPoint

Source§

impl Sub for RistrettoPoint

Source§

impl Sub for Scalar

Source§

impl Sub for BigInt

Source§

impl Sub for BigUint

Source§

impl Sub for RefTypes

Source§

impl Sub for CreateFlags

Source§

impl Sub for ReadFlags

Source§

impl Sub for WatchFlags

Source§

impl Sub for Access

Source§

impl Sub for AtFlags

Source§

impl Sub for FallocateFlags

Source§

impl Sub for MemfdFlags

Source§

impl Sub for Mode

Source§

impl Sub for OFlags

Source§

impl Sub for RenameFlags

Source§

impl Sub for ResolveFlags

Source§

impl Sub for SealFlags

Source§

impl Sub for StatVfsMountFlags

Source§

impl Sub for DupFlags

Source§

impl Sub for FdFlags

Source§

impl Sub for ReadWriteFlags

Source§

impl Sub for IFlags

Source§

impl Sub for StatxAttributes

Source§

impl Sub for StatxFlags

Source§

impl Sub for XattrFlags

Source§

impl Sub for Timespec

Source§

impl Sub for ATerm

Source§

impl Sub for Z0

Z0 - Z0 = Z0

Source§

impl Sub for UTerm

UTerm - UTerm = UTerm

1.0.0 · Source§

impl Sub<&f16> for &f16

1.0.0 · Source§

impl Sub<&f16> for f16

1.0.0 · Source§

impl Sub<&f32> for &f32

1.0.0 · Source§

impl Sub<&f32> for f32

1.0.0 · Source§

impl Sub<&f64> for &f64

1.0.0 · Source§

impl Sub<&f64> for f64

1.0.0 · Source§

impl Sub<&f128> for &f128

1.0.0 · Source§

impl Sub<&f128> for f128

1.0.0 · Source§

impl Sub<&i8> for &i8

Source§

impl Sub<&i8> for &BigInt

1.0.0 · Source§

impl Sub<&i8> for i8

Source§

impl Sub<&i8> for BigInt

1.0.0 · Source§

impl Sub<&i16> for &i16

Source§

impl Sub<&i16> for &BigInt

1.0.0 · Source§

impl Sub<&i16> for i16

Source§

impl Sub<&i16> for BigInt

1.0.0 · Source§

impl Sub<&i32> for &i32

Source§

impl Sub<&i32> for &BigInt

1.0.0 · Source§

impl Sub<&i32> for i32

Source§

impl Sub<&i32> for BigInt

1.0.0 · Source§

impl Sub<&i64> for &i64

Source§

impl Sub<&i64> for &BigInt

1.0.0 · Source§

impl Sub<&i64> for i64

Source§

impl Sub<&i64> for BigInt

1.0.0 · Source§

impl Sub<&i128> for &i128

Source§

impl Sub<&i128> for &BigInt

1.0.0 · Source§

impl Sub<&i128> for i128

Source§

impl Sub<&i128> for BigInt

1.0.0 · Source§

impl Sub<&isize> for &isize

Source§

impl Sub<&isize> for &BigInt

1.0.0 · Source§

impl Sub<&isize> for isize

Source§

impl Sub<&isize> for BigInt

1.0.0 · Source§

impl Sub<&u8> for &u8

Source§

impl Sub<&u8> for &BigInt

Source§

impl Sub<&u8> for &BigUint

1.0.0 · Source§

impl Sub<&u8> for u8

Source§

impl Sub<&u8> for BigInt

Source§

impl Sub<&u8> for BigUint

1.0.0 · Source§

impl Sub<&u16> for &u16

Source§

impl Sub<&u16> for &BigInt

Source§

impl Sub<&u16> for &BigUint

1.0.0 · Source§

impl Sub<&u16> for u16

Source§

impl Sub<&u16> for BigInt

Source§

impl Sub<&u16> for BigUint

1.0.0 · Source§

impl Sub<&u32> for &u32

Source§

impl Sub<&u32> for &BigInt

Source§

impl Sub<&u32> for &BigUint

1.0.0 · Source§

impl Sub<&u32> for u32

Source§

impl Sub<&u32> for BigInt

Source§

impl Sub<&u32> for BigUint

1.0.0 · Source§

impl Sub<&u64> for &u64

Source§

impl Sub<&u64> for &BigInt

Source§

impl Sub<&u64> for &BigUint

1.0.0 · Source§

impl Sub<&u64> for u64

Source§

impl Sub<&u64> for BigInt

Source§

impl Sub<&u64> for BigUint

1.0.0 · Source§

impl Sub<&u128> for &u128

Source§

impl Sub<&u128> for &BigInt

Source§

impl Sub<&u128> for &BigUint

1.0.0 · Source§

impl Sub<&u128> for u128

Source§

impl Sub<&u128> for BigInt

Source§

impl Sub<&u128> for BigUint

1.0.0 · Source§

impl Sub<&usize> for &usize

Source§

impl Sub<&usize> for &BigInt

Source§

impl Sub<&usize> for &BigUint

1.0.0 · Source§

impl Sub<&usize> for usize

Source§

impl Sub<&usize> for BigInt

Source§

impl Sub<&usize> for BigUint

Source§

impl Sub<&I192> for &I192

Source§

impl Sub<&I192> for I192

Source§

impl Sub<&I256> for &I256

Source§

impl Sub<&I256> for I256

Source§

impl Sub<&I320> for &I320

Source§

impl Sub<&I320> for I320

Source§

impl Sub<&I384> for &I384

Source§

impl Sub<&I384> for I384

Source§

impl Sub<&I448> for &I448

Source§

impl Sub<&I448> for I448

Source§

impl Sub<&I512> for &I512

Source§

impl Sub<&I512> for I512

Source§

impl Sub<&I768> for &I768

Source§

impl Sub<&I768> for I768

Source§

impl Sub<&U192> for &U192

Source§

impl Sub<&U192> for U192

Source§

impl Sub<&U256> for &U256

Source§

impl Sub<&U256> for U256

Source§

impl Sub<&U320> for &U320

Source§

impl Sub<&U320> for U320

Source§

impl Sub<&U384> for &U384

Source§

impl Sub<&U384> for U384

Source§

impl Sub<&U448> for &U448

Source§

impl Sub<&U448> for U448

Source§

impl Sub<&U512> for &U512

Source§

impl Sub<&U512> for U512

Source§

impl Sub<&U768> for &U768

Source§

impl Sub<&U768> for U768

1.74.0 · Source§

impl Sub<&Saturating<i8>> for &Saturating<i8>

1.74.0 · Source§

impl Sub<&Saturating<i8>> for Saturating<i8>

1.74.0 · Source§

impl Sub<&Saturating<i16>> for &Saturating<i16>

1.74.0 · Source§

impl Sub<&Saturating<i16>> for Saturating<i16>

1.74.0 · Source§

impl Sub<&Saturating<i32>> for &Saturating<i32>

1.74.0 · Source§

impl Sub<&Saturating<i32>> for Saturating<i32>

1.74.0 · Source§

impl Sub<&Saturating<i64>> for &Saturating<i64>

1.74.0 · Source§

impl Sub<&Saturating<i64>> for Saturating<i64>

1.74.0 · Source§

impl Sub<&Saturating<i128>> for &Saturating<i128>

1.74.0 · Source§

impl Sub<&Saturating<i128>> for Saturating<i128>

1.74.0 · Source§

impl Sub<&Saturating<isize>> for &Saturating<isize>

1.74.0 · Source§

impl Sub<&Saturating<isize>> for Saturating<isize>

1.74.0 · Source§

impl Sub<&Saturating<u8>> for &Saturating<u8>

1.74.0 · Source§

impl Sub<&Saturating<u8>> for Saturating<u8>

1.74.0 · Source§

impl Sub<&Saturating<u16>> for &Saturating<u16>

1.74.0 · Source§

impl Sub<&Saturating<u16>> for Saturating<u16>

1.74.0 · Source§

impl Sub<&Saturating<u32>> for &Saturating<u32>

1.74.0 · Source§

impl Sub<&Saturating<u32>> for Saturating<u32>

1.74.0 · Source§

impl Sub<&Saturating<u64>> for &Saturating<u64>

1.74.0 · Source§

impl Sub<&Saturating<u64>> for Saturating<u64>

1.74.0 · Source§

impl Sub<&Saturating<u128>> for &Saturating<u128>

1.74.0 · Source§

impl Sub<&Saturating<u128>> for Saturating<u128>

1.74.0 · Source§

impl Sub<&Saturating<usize>> for &Saturating<usize>

1.74.0 · Source§

impl Sub<&Saturating<usize>> for Saturating<usize>

1.14.0 · Source§

impl Sub<&Wrapping<i8>> for &Wrapping<i8>

1.14.0 · Source§

impl Sub<&Wrapping<i8>> for Wrapping<i8>

1.14.0 · Source§

impl Sub<&Wrapping<i16>> for &Wrapping<i16>

1.14.0 · Source§

impl Sub<&Wrapping<i16>> for Wrapping<i16>

1.14.0 · Source§

impl Sub<&Wrapping<i32>> for &Wrapping<i32>

1.14.0 · Source§

impl Sub<&Wrapping<i32>> for Wrapping<i32>

1.14.0 · Source§

impl Sub<&Wrapping<i64>> for &Wrapping<i64>

1.14.0 · Source§

impl Sub<&Wrapping<i64>> for Wrapping<i64>

1.14.0 · Source§

impl Sub<&Wrapping<i128>> for &Wrapping<i128>

1.14.0 · Source§

impl Sub<&Wrapping<i128>> for Wrapping<i128>

1.14.0 · Source§

impl Sub<&Wrapping<isize>> for &Wrapping<isize>

1.14.0 · Source§

impl Sub<&Wrapping<isize>> for Wrapping<isize>

1.14.0 · Source§

impl Sub<&Wrapping<u8>> for &Wrapping<u8>

1.14.0 · Source§

impl Sub<&Wrapping<u8>> for Wrapping<u8>

1.14.0 · Source§

impl Sub<&Wrapping<u16>> for &Wrapping<u16>

1.14.0 · Source§

impl Sub<&Wrapping<u16>> for Wrapping<u16>

1.14.0 · Source§

impl Sub<&Wrapping<u32>> for &Wrapping<u32>

1.14.0 · Source§

impl Sub<&Wrapping<u32>> for Wrapping<u32>

1.14.0 · Source§

impl Sub<&Wrapping<u64>> for &Wrapping<u64>

1.14.0 · Source§

impl Sub<&Wrapping<u64>> for Wrapping<u64>

1.14.0 · Source§

impl Sub<&Wrapping<u128>> for &Wrapping<u128>

1.14.0 · Source§

impl Sub<&Wrapping<u128>> for Wrapping<u128>

1.14.0 · Source§

impl Sub<&Wrapping<usize>> for &Wrapping<usize>

1.14.0 · Source§

impl Sub<&Wrapping<usize>> for Wrapping<usize>

Source§

impl Sub<&BigInt> for &i8

Source§

impl Sub<&BigInt> for &i16

Source§

impl Sub<&BigInt> for &i32

Source§

impl Sub<&BigInt> for &i64

Source§

impl Sub<&BigInt> for &i128

Source§

impl Sub<&BigInt> for &isize

Source§

impl Sub<&BigInt> for &u8

Source§

impl Sub<&BigInt> for &u16

Source§

impl Sub<&BigInt> for &u32

Source§

impl Sub<&BigInt> for &u64

Source§

impl Sub<&BigInt> for &u128

Source§

impl Sub<&BigInt> for &usize

Source§

impl Sub<&BigInt> for &BigInt

Source§

impl Sub<&BigInt> for i8

Source§

impl Sub<&BigInt> for i16

Source§

impl Sub<&BigInt> for i32

Source§

impl Sub<&BigInt> for i64

Source§

impl Sub<&BigInt> for i128

Source§

impl Sub<&BigInt> for isize

Source§

impl Sub<&BigInt> for u8

Source§

impl Sub<&BigInt> for u16

Source§

impl Sub<&BigInt> for u32

Source§

impl Sub<&BigInt> for u64

Source§

impl Sub<&BigInt> for u128

Source§

impl Sub<&BigInt> for usize

Source§

impl Sub<&BigInt> for BigInt

Source§

impl Sub<&BigUint> for &u8

Source§

impl Sub<&BigUint> for &u16

Source§

impl Sub<&BigUint> for &u32

Source§

impl Sub<&BigUint> for &u64

Source§

impl Sub<&BigUint> for &u128

Source§

impl Sub<&BigUint> for &usize

Source§

impl Sub<&BigUint> for &BigUint

Source§

impl Sub<&BigUint> for u8

Source§

impl Sub<&BigUint> for u16

Source§

impl Sub<&BigUint> for u32

Source§

impl Sub<&BigUint> for u64

Source§

impl Sub<&BigUint> for u128

Source§

impl Sub<&BigUint> for usize

Source§

impl Sub<&BigUint> for BigUint

Source§

impl Sub<i8> for &BigInt

Source§

impl Sub<i8> for Decimal

Source§

impl Sub<i8> for PreciseDecimal

Source§

impl Sub<i8> for BigInt

Source§

impl Sub<i16> for &BigInt

Source§

impl Sub<i16> for Decimal

Source§

impl Sub<i16> for PreciseDecimal

Source§

impl Sub<i16> for BigInt

Source§

impl Sub<i32> for &BigInt

Source§

impl Sub<i32> for Decimal

Source§

impl Sub<i32> for PreciseDecimal

Source§

impl Sub<i32> for BigInt

Source§

impl Sub<i64> for &BigInt

Source§

impl Sub<i64> for Decimal

Source§

impl Sub<i64> for PreciseDecimal

Source§

impl Sub<i64> for BigInt

Source§

impl Sub<i128> for &BigInt

Source§

impl Sub<i128> for Decimal

Source§

impl Sub<i128> for PreciseDecimal

Source§

impl Sub<i128> for BigInt

Source§

impl Sub<isize> for &BigInt

Source§

impl Sub<isize> for Decimal

Source§

impl Sub<isize> for PreciseDecimal

Source§

impl Sub<isize> for BigInt

Source§

impl Sub<u8> for &BigInt

Source§

impl Sub<u8> for &BigUint

Source§

impl Sub<u8> for Decimal

Source§

impl Sub<u8> for PreciseDecimal

Source§

impl Sub<u8> for BigInt

Source§

impl Sub<u8> for BigUint

Source§

impl Sub<u16> for &BigInt

Source§

impl Sub<u16> for &BigUint

Source§

impl Sub<u16> for Decimal

Source§

impl Sub<u16> for PreciseDecimal

Source§

impl Sub<u16> for BigInt

Source§

impl Sub<u16> for BigUint

Source§

impl Sub<u32> for &BigInt

Source§

impl Sub<u32> for &BigUint

Source§

impl Sub<u32> for Decimal

Source§

impl Sub<u32> for PreciseDecimal

Source§

impl Sub<u32> for BigInt

Source§

impl Sub<u32> for BigUint

Source§

impl Sub<u64> for &BigInt

Source§

impl Sub<u64> for &BigUint

Source§

impl Sub<u64> for Decimal

Source§

impl Sub<u64> for PreciseDecimal

Source§

impl Sub<u64> for BigInt

Source§

impl Sub<u64> for BigUint

Source§

impl Sub<u128> for &BigInt

Source§

impl Sub<u128> for &BigUint

Source§

impl Sub<u128> for Decimal

Source§

impl Sub<u128> for PreciseDecimal

Source§

impl Sub<u128> for BigInt

Source§

impl Sub<u128> for BigUint

Source§

impl Sub<usize> for &BigInt

Source§

impl Sub<usize> for &BigUint

Source§

impl Sub<usize> for Decimal

Source§

impl Sub<usize> for PreciseDecimal

Source§

impl Sub<usize> for BigInt

Source§

impl Sub<usize> for BigUint

Source§

impl Sub<Decimal> for i8

Source§

impl Sub<Decimal> for i16

Source§

impl Sub<Decimal> for i32

Source§

impl Sub<Decimal> for i64

Source§

impl Sub<Decimal> for i128

Source§

impl Sub<Decimal> for isize

Source§

impl Sub<Decimal> for u8

Source§

impl Sub<Decimal> for u16

Source§

impl Sub<Decimal> for u32

Source§

impl Sub<Decimal> for u64

Source§

impl Sub<Decimal> for u128

Source§

impl Sub<Decimal> for usize

Source§

impl Sub<Decimal> for I192

Source§

impl Sub<Decimal> for I256

Source§

impl Sub<Decimal> for I320

Source§

impl Sub<Decimal> for I448

Source§

impl Sub<Decimal> for I512

Source§

impl Sub<Decimal> for PreciseDecimal

Source§

impl Sub<Decimal> for U192

Source§

impl Sub<Decimal> for U256

Source§

impl Sub<Decimal> for U320

Source§

impl Sub<Decimal> for U448

Source§

impl Sub<Decimal> for U512

Source§

impl Sub<I192> for Decimal

Source§

impl Sub<I192> for PreciseDecimal

Source§

impl Sub<I256> for Decimal

Source§

impl Sub<I256> for PreciseDecimal

Source§

impl Sub<I320> for Decimal

Source§

impl Sub<I320> for PreciseDecimal

Source§

impl Sub<I448> for Decimal

Source§

impl Sub<I448> for PreciseDecimal

Source§

impl Sub<I512> for Decimal

Source§

impl Sub<I512> for PreciseDecimal

Source§

impl Sub<PreciseDecimal> for i8

Source§

impl Sub<PreciseDecimal> for i16

Source§

impl Sub<PreciseDecimal> for i32

Source§

impl Sub<PreciseDecimal> for i64

Source§

impl Sub<PreciseDecimal> for i128

Source§

impl Sub<PreciseDecimal> for isize

Source§

impl Sub<PreciseDecimal> for u8

Source§

impl Sub<PreciseDecimal> for u16

Source§

impl Sub<PreciseDecimal> for u32

Source§

impl Sub<PreciseDecimal> for u64

Source§

impl Sub<PreciseDecimal> for u128

Source§

impl Sub<PreciseDecimal> for usize

Source§

impl Sub<PreciseDecimal> for Decimal

Source§

impl Sub<PreciseDecimal> for I192

Source§

impl Sub<PreciseDecimal> for I256

Source§

impl Sub<PreciseDecimal> for I320

Source§

impl Sub<PreciseDecimal> for I448

Source§

impl Sub<PreciseDecimal> for I512

Source§

impl Sub<PreciseDecimal> for U192

Source§

impl Sub<PreciseDecimal> for U256

Source§

impl Sub<PreciseDecimal> for U320

Source§

impl Sub<PreciseDecimal> for U448

Source§

impl Sub<PreciseDecimal> for U512

Source§

impl Sub<U192> for Decimal

Source§

impl Sub<U192> for PreciseDecimal

Source§

impl Sub<U256> for Decimal

Source§

impl Sub<U256> for PreciseDecimal

Source§

impl Sub<U320> for Decimal

Source§

impl Sub<U320> for PreciseDecimal

Source§

impl Sub<U448> for Decimal

Source§

impl Sub<U448> for PreciseDecimal

Source§

impl Sub<U512> for Decimal

Source§

impl Sub<U512> for PreciseDecimal

1.8.0 · Source§

impl Sub<Duration> for Instant

1.8.0 · Source§

impl Sub<Duration> for SystemTime

Source§

impl Sub<Effects> for Style

§Examples

let style = anstyle::Style::new().bold().underline() - anstyle::Effects::BOLD.into();
Source§

impl Sub<BigInt> for &i8

Source§

impl Sub<BigInt> for &i16

Source§

impl Sub<BigInt> for &i32

Source§

impl Sub<BigInt> for &i64

Source§

impl Sub<BigInt> for &i128

Source§

impl Sub<BigInt> for &isize

Source§

impl Sub<BigInt> for &u8

Source§

impl Sub<BigInt> for &u16

Source§

impl Sub<BigInt> for &u32

Source§

impl Sub<BigInt> for &u64

Source§

impl Sub<BigInt> for &u128

Source§

impl Sub<BigInt> for &usize

Source§

impl Sub<BigInt> for &BigInt

Source§

impl Sub<BigInt> for i8

Source§

impl Sub<BigInt> for i16

Source§

impl Sub<BigInt> for i32

Source§

impl Sub<BigInt> for i64

Source§

impl Sub<BigInt> for i128

Source§

impl Sub<BigInt> for isize

Source§

impl Sub<BigInt> for u8

Source§

impl Sub<BigInt> for u16

Source§

impl Sub<BigInt> for u32

Source§

impl Sub<BigInt> for u64

Source§

impl Sub<BigInt> for u128

Source§

impl Sub<BigInt> for usize

Source§

impl Sub<BigUint> for &u8

Source§

impl Sub<BigUint> for &u16

Source§

impl Sub<BigUint> for &u32

Source§

impl Sub<BigUint> for &u64

Source§

impl Sub<BigUint> for &u128

Source§

impl Sub<BigUint> for &usize

Source§

impl Sub<BigUint> for &BigUint

Source§

impl Sub<BigUint> for u8

Source§

impl Sub<BigUint> for u16

Source§

impl Sub<BigUint> for u32

Source§

impl Sub<BigUint> for u64

Source§

impl Sub<BigUint> for u128

Source§

impl Sub<BigUint> for usize

Source§

impl Sub<B0> for UTerm

UTerm - B0 = Term

Source§

impl Sub<B1> for UInt<UTerm, B1>

UInt<UTerm, B1> - B1 = UTerm

1.0.0 · Source§

impl<'a> Sub<f16> for &'a f16

1.0.0 · Source§

impl<'a> Sub<f32> for &'a f32

1.0.0 · Source§

impl<'a> Sub<f64> for &'a f64

1.0.0 · Source§

impl<'a> Sub<f128> for &'a f128

1.0.0 · Source§

impl<'a> Sub<i8> for &'a i8

1.0.0 · Source§

impl<'a> Sub<i16> for &'a i16

1.0.0 · Source§

impl<'a> Sub<i32> for &'a i32

1.0.0 · Source§

impl<'a> Sub<i64> for &'a i64

1.0.0 · Source§

impl<'a> Sub<i128> for &'a i128

1.0.0 · Source§

impl<'a> Sub<isize> for &'a isize

1.0.0 · Source§

impl<'a> Sub<u8> for &'a u8

1.0.0 · Source§

impl<'a> Sub<u16> for &'a u16

1.0.0 · Source§

impl<'a> Sub<u32> for &'a u32

1.0.0 · Source§

impl<'a> Sub<u64> for &'a u64

1.0.0 · Source§

impl<'a> Sub<u128> for &'a u128

1.0.0 · Source§

impl<'a> Sub<usize> for &'a usize

Source§

impl<'a> Sub<I192> for &'a I192

Source§

impl<'a> Sub<I256> for &'a I256

Source§

impl<'a> Sub<I320> for &'a I320

Source§

impl<'a> Sub<I384> for &'a I384

Source§

impl<'a> Sub<I448> for &'a I448

Source§

impl<'a> Sub<I512> for &'a I512

Source§

impl<'a> Sub<I768> for &'a I768

Source§

impl<'a> Sub<U192> for &'a U192

Source§

impl<'a> Sub<U256> for &'a U256

Source§

impl<'a> Sub<U320> for &'a U320

Source§

impl<'a> Sub<U384> for &'a U384

Source§

impl<'a> Sub<U448> for &'a U448

Source§

impl<'a> Sub<U512> for &'a U512

Source§

impl<'a> Sub<U768> for &'a U768

1.74.0 · Source§

impl<'a> Sub<Saturating<i8>> for &'a Saturating<i8>

1.74.0 · Source§

impl<'a> Sub<Saturating<i16>> for &'a Saturating<i16>

1.74.0 · Source§

impl<'a> Sub<Saturating<i32>> for &'a Saturating<i32>

1.74.0 · Source§

impl<'a> Sub<Saturating<i64>> for &'a Saturating<i64>

1.74.0 · Source§

impl<'a> Sub<Saturating<i128>> for &'a Saturating<i128>

1.74.0 · Source§

impl<'a> Sub<Saturating<isize>> for &'a Saturating<isize>

1.74.0 · Source§

impl<'a> Sub<Saturating<u8>> for &'a Saturating<u8>

1.74.0 · Source§

impl<'a> Sub<Saturating<u16>> for &'a Saturating<u16>

1.74.0 · Source§

impl<'a> Sub<Saturating<u32>> for &'a Saturating<u32>

1.74.0 · Source§

impl<'a> Sub<Saturating<u64>> for &'a Saturating<u64>

1.74.0 · Source§

impl<'a> Sub<Saturating<u128>> for &'a Saturating<u128>

1.74.0 · Source§

impl<'a> Sub<Saturating<usize>> for &'a Saturating<usize>

1.14.0 · Source§

impl<'a> Sub<Wrapping<i8>> for &'a Wrapping<i8>

1.14.0 · Source§

impl<'a> Sub<Wrapping<i16>> for &'a Wrapping<i16>

1.14.0 · Source§

impl<'a> Sub<Wrapping<i32>> for &'a Wrapping<i32>

1.14.0 · Source§

impl<'a> Sub<Wrapping<i64>> for &'a Wrapping<i64>

1.14.0 · Source§

impl<'a> Sub<Wrapping<i128>> for &'a Wrapping<i128>

1.14.0 · Source§

impl<'a> Sub<Wrapping<isize>> for &'a Wrapping<isize>

1.14.0 · Source§

impl<'a> Sub<Wrapping<u8>> for &'a Wrapping<u8>

1.14.0 · Source§

impl<'a> Sub<Wrapping<u16>> for &'a Wrapping<u16>

1.14.0 · Source§

impl<'a> Sub<Wrapping<u32>> for &'a Wrapping<u32>

1.14.0 · Source§

impl<'a> Sub<Wrapping<u64>> for &'a Wrapping<u64>

1.14.0 · Source§

impl<'a> Sub<Wrapping<u128>> for &'a Wrapping<u128>

1.14.0 · Source§

impl<'a> Sub<Wrapping<usize>> for &'a Wrapping<usize>

Source§

impl<'a> Sub<EdwardsPoint> for &'a EdwardsPoint

Source§

impl<'a> Sub<RistrettoPoint> for &'a RistrettoPoint

Source§

impl<'a> Sub<Scalar> for &'a Scalar

Source§

impl<'a, 'b> Sub<&'b EdwardsPoint> for &'a EdwardsPoint

Source§

impl<'a, 'b> Sub<&'b RistrettoPoint> for &'a RistrettoPoint

Source§

impl<'a, 'b> Sub<&'b Scalar> for &'a Scalar

Source§

impl<'a, 'b> Sub<&'b AffineNielsPoint> for &'a EdwardsPoint

Source§

type Output = CompletedPoint

Source§

impl<'a, 'b> Sub<&'b ProjectiveNielsPoint> for &'a EdwardsPoint

Source§

type Output = CompletedPoint

Source§

impl<'a, T> Sub for &'a Set<T>
where T: Eq + Hash + Ord + Clone + 'a,

Source§

impl<'b> Sub<&'b EdwardsPoint> for EdwardsPoint

Source§

impl<'b> Sub<&'b RistrettoPoint> for RistrettoPoint

Source§

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

Source§

impl<'lhs, 'rhs, T, const N: usize> Sub<&'rhs Simd<T, N>> for &'lhs Simd<T, N>
where T: SimdElement, Simd<T, N>: Sub<Output = Simd<T, N>>, LaneCount<N>: SupportedLaneCount,

Source§

type Output = Simd<T, N>

Source§

impl<T> Sub<T> for F32
where T: Into<F32>,

Source§

impl<T> Sub<T> for F64
where T: Into<F64>,

1.0.0 · Source§

impl<T, A> Sub<&BTreeSet<T, A>> for &BTreeSet<T, A>
where T: Ord + Clone, A: Allocator + Clone,

Source§

impl<T, S1, S2> Sub<&IndexSet<T, S2>> for &scrypto_test::prelude::indexmap::IndexSet<T, S1>
where T: Eq + Hash + Clone, S1: BuildHasher + Default, S2: BuildHasher,

Source§

type Output = IndexSet<T, S1>

Source§

impl<T, S1, S2> Sub<&IndexSet<T, S2>> for &indexmap::set::IndexSet<T, S1>
where T: Eq + Hash + Clone, S1: BuildHasher + Default, S2: BuildHasher,

Source§

type Output = IndexSet<T, S1>

1.0.0 · Source§

impl<T, S> Sub<&HashSet<T, S>> for &scrypto_test::prelude::hash_set::ext_HashSet<T, S>
where T: Eq + Hash + Clone, S: BuildHasher + Default,

Source§

type Output = HashSet<T, S>

Source§

impl<T, S> Sub<&HashSet<T, S>> for &hashbrown::set::HashSet<T, S>
where T: Eq + Hash + Clone, S: BuildHasher + Default,

Source§

type Output = HashSet<T, S>

Source§

impl<T, S, A> Sub<&HashSet<T, S, A>> for &hashbrown::set::HashSet<T, S, A>
where T: Eq + Hash + Clone, S: BuildHasher + Default, A: Allocator + Default,

Source§

type Output = HashSet<T, S, A>

Source§

impl<T, const N: usize> Sub<&Simd<T, N>> for Simd<T, N>
where T: SimdElement, Simd<T, N>: Sub<Output = Simd<T, N>>, LaneCount<N>: SupportedLaneCount,

Source§

type Output = Simd<T, N>

Source§

impl<T, const N: usize> Sub<Simd<T, N>> for &Simd<T, N>
where T: SimdElement, Simd<T, N>: Sub<Output = Simd<T, N>>, LaneCount<N>: SupportedLaneCount,

Source§

type Output = Simd<T, N>

Source§

impl<U> Sub<B1> for UInt<U, B0>
where U: Unsigned + Sub<B1>, <U as Sub<B1>>::Output: Unsigned,

UInt<U, B0> - B1 = UInt<U - B1, B1>

Source§

type Output = UInt<<U as Sub<B1>>::Output, B1>

Source§

impl<U> Sub<NInt<U>> for Z0
where U: Unsigned + NonZero,

Z0 - N = P

Source§

impl<U> Sub<PInt<U>> for Z0
where U: Unsigned + NonZero,

Z0 - P = N

Source§

impl<U> Sub<Z0> for NInt<U>
where U: Unsigned + NonZero,

NInt - Z0 = NInt

Source§

impl<U> Sub<Z0> for PInt<U>
where U: Unsigned + NonZero,

PInt - Z0 = PInt

Source§

impl<U, B> Sub<B0> for UInt<U, B>
where U: Unsigned, B: Bit,

UInt - B0 = UInt

Source§

type Output = UInt<U, B>

Source§

impl<U, B> Sub<B1> for UInt<UInt<U, B>, B1>
where U: Unsigned, B: Bit,

UInt<U, B1> - B1 = UInt<U, B0>

Source§

type Output = UInt<UInt<U, B>, B0>

Source§

impl<Ul, Bl, Ur> Sub<Ur> for UInt<Ul, Bl>
where Ul: Unsigned, Bl: Bit, Ur: Unsigned, UInt<Ul, Bl>: PrivateSub<Ur>, <UInt<Ul, Bl> as PrivateSub<Ur>>::Output: Trim,

Subtracting unsigned integers. We just do our PrivateSub and then Trim the output.

Source§

type Output = <<UInt<Ul, Bl> as PrivateSub<Ur>>::Output as Trim>::Output

Source§

impl<Ul, Ur> Sub<NInt<Ur>> for NInt<Ul>
where Ul: Unsigned + NonZero, Ur: Unsigned + NonZero + Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>,

N(Ul) - N(Ur): We resolve this with our PrivateAdd

Source§

type Output = <Ur as PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>>::Output

Source§

impl<Ul, Ur> Sub<NInt<Ur>> for PInt<Ul>
where Ul: Unsigned + NonZero + Add<Ur>, Ur: Unsigned + NonZero, <Ul as Add<Ur>>::Output: Unsigned + NonZero,

P(Ul) - N(Ur) = P(Ul + Ur)

Source§

type Output = PInt<<Ul as Add<Ur>>::Output>

Source§

impl<Ul, Ur> Sub<PInt<Ur>> for NInt<Ul>
where Ul: Unsigned + NonZero + Add<Ur>, Ur: Unsigned + NonZero, <Ul as Add<Ur>>::Output: Unsigned + NonZero,

N(Ul) - P(Ur) = N(Ul + Ur)

Source§

type Output = NInt<<Ul as Add<Ur>>::Output>

Source§

impl<Ul, Ur> Sub<PInt<Ur>> for PInt<Ul>
where Ul: Unsigned + NonZero + Cmp<Ur> + PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>, Ur: Unsigned + NonZero,

P(Ul) - P(Ur): We resolve this with our PrivateAdd

Source§

type Output = <Ul as PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>>::Output

Source§

impl<Vl, Al, Vr, Ar> Sub<TArr<Vr, Ar>> for TArr<Vl, Al>
where Vl: Sub<Vr>, Al: Sub<Ar>,

Source§

type Output = TArr<<Vl as Sub<Vr>>::Output, <Al as Sub<Ar>>::Output>

Source§

impl<const N: usize> Sub for Simd<f32, N>

Source§

impl<const N: usize> Sub for Simd<f64, N>

Source§

impl<const N: usize> Sub for Simd<i8, N>

Source§

impl<const N: usize> Sub for Simd<i16, N>

Source§

impl<const N: usize> Sub for Simd<i32, N>

Source§

impl<const N: usize> Sub for Simd<i64, N>

Source§

impl<const N: usize> Sub for Simd<isize, N>

Source§

impl<const N: usize> Sub for Simd<u8, N>

Source§

impl<const N: usize> Sub for Simd<u16, N>

Source§

impl<const N: usize> Sub for Simd<u32, N>

Source§

impl<const N: usize> Sub for Simd<u64, N>

Source§

impl<const N: usize> Sub for Simd<usize, N>

Source§

impl<const N: usize> Sub for BInt<N>

Source§

impl<const N: usize> Sub for BIntD8<N>

Source§

impl<const N: usize> Sub for BIntD16<N>

Source§

impl<const N: usize> Sub for BIntD32<N>

Source§

impl<const N: usize> Sub for BUint<N>

Source§

impl<const N: usize> Sub for BUintD8<N>

Source§

impl<const N: usize> Sub for BUintD16<N>

Source§

impl<const N: usize> Sub for BUintD32<N>

Source§

impl<const N: usize> Sub<&BInt<N>> for &BInt<N>

Source§

impl<const N: usize> Sub<&BInt<N>> for BInt<N>

Source§

impl<const N: usize> Sub<&BIntD8<N>> for &BIntD8<N>

Source§

impl<const N: usize> Sub<&BIntD8<N>> for BIntD8<N>

Source§

impl<const N: usize> Sub<&BIntD16<N>> for &BIntD16<N>

Source§

impl<const N: usize> Sub<&BIntD16<N>> for BIntD16<N>

Source§

impl<const N: usize> Sub<&BIntD32<N>> for &BIntD32<N>

Source§

impl<const N: usize> Sub<&BIntD32<N>> for BIntD32<N>

Source§

impl<const N: usize> Sub<&BUint<N>> for &BUint<N>

Source§

impl<const N: usize> Sub<&BUint<N>> for BUint<N>

Source§

impl<const N: usize> Sub<&BUintD8<N>> for &BUintD8<N>

Source§

impl<const N: usize> Sub<&BUintD8<N>> for BUintD8<N>

Source§

impl<const N: usize> Sub<&BUintD16<N>> for &BUintD16<N>

Source§

impl<const N: usize> Sub<&BUintD16<N>> for BUintD16<N>

Source§

impl<const N: usize> Sub<&BUintD32<N>> for &BUintD32<N>

Source§

impl<const N: usize> Sub<&BUintD32<N>> for BUintD32<N>

Source§

impl<const N: usize> Sub<BInt<N>> for &BInt<N>

Source§

impl<const N: usize> Sub<BIntD8<N>> for &BIntD8<N>

Source§

impl<const N: usize> Sub<BIntD16<N>> for &BIntD16<N>

Source§

impl<const N: usize> Sub<BIntD32<N>> for &BIntD32<N>

Source§

impl<const N: usize> Sub<BUint<N>> for &BUint<N>

Source§

impl<const N: usize> Sub<BUintD8<N>> for &BUintD8<N>

Source§

impl<const N: usize> Sub<BUintD16<N>> for &BUintD16<N>

Source§

impl<const N: usize> Sub<BUintD32<N>> for &BUintD32<N>