Trait slot_range_helper::Add

1.0.0 · source ·
pub trait Add<Rhs = Self> {
    type Output;

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

The addition operator +.

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

Examples

Addable points

use std::ops::Add;

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

impl Add for Point {
    type Output = Self;

    fn add(self, other: Self) -> Self {
        Self {
            x: self.x + other.x,
            y: self.y + other.y,
        }
    }
}

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

Implementing Add with generics

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

use std::ops::Add;

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

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

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

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

Required Associated Types§

source

type Output

The resulting type after applying the + operator.

Required Methods§

source

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

Performs the + operation.

Example
assert_eq!(12 + 1, 13);

Implementors§

source§

impl Add<&f32> for &f32

§

type Output = <f32 as Add<f32>>::Output

source§

impl Add<&f32> for f32

§

type Output = <f32 as Add<f32>>::Output

source§

impl Add<&f64> for &f64

§

type Output = <f64 as Add<f64>>::Output

source§

impl Add<&f64> for f64

§

type Output = <f64 as Add<f64>>::Output

source§

impl Add<&i8> for &i8

§

type Output = <i8 as Add<i8>>::Output

source§

impl Add<&i8> for i8

§

type Output = <i8 as Add<i8>>::Output

source§

impl Add<&i16> for &i16

§

type Output = <i16 as Add<i16>>::Output

source§

impl Add<&i16> for i16

§

type Output = <i16 as Add<i16>>::Output

source§

impl Add<&i32> for &i32

§

type Output = <i32 as Add<i32>>::Output

source§

impl Add<&i32> for i32

§

type Output = <i32 as Add<i32>>::Output

source§

impl Add<&i64> for &i64

§

type Output = <i64 as Add<i64>>::Output

source§

impl Add<&i64> for i64

§

type Output = <i64 as Add<i64>>::Output

source§

impl Add<&i128> for &i128

§

type Output = <i128 as Add<i128>>::Output

source§

impl Add<&i128> for i128

§

type Output = <i128 as Add<i128>>::Output

source§

impl Add<&isize> for &isize

§

type Output = <isize as Add<isize>>::Output

source§

impl Add<&isize> for isize

§

type Output = <isize as Add<isize>>::Output

source§

impl Add<&str> for String

Implements the + operator for concatenating two strings.

This consumes the String on the left-hand side and re-uses its buffer (growing it if necessary). This is done to avoid allocating a new String and copying the entire contents on every operation, which would lead to O(n^2) running time when building an n-byte string by repeated concatenation.

The string on the right-hand side is only borrowed; its contents are copied into the returned String.

Examples

Concatenating two Strings takes the first by value and borrows the second:

let a = String::from("hello");
let b = String::from(" world");
let c = a + &b;
// `a` is moved and can no longer be used here.

If you want to keep using the first String, you can clone it and append to the clone instead:

let a = String::from("hello");
let b = String::from(" world");
let c = a.clone() + &b;
// `a` is still valid here.

Concatenating &str slices can be done by converting the first to a String:

let a = "hello";
let b = " world";
let c = a.to_string() + b;
source§

impl Add<&u8> for &u8

§

type Output = <u8 as Add<u8>>::Output

source§

impl Add<&u8> for u8

§

type Output = <u8 as Add<u8>>::Output

source§

impl Add<&u16> for &u16

§

type Output = <u16 as Add<u16>>::Output

source§

impl Add<&u16> for u16

§

type Output = <u16 as Add<u16>>::Output

source§

impl Add<&u32> for &u32

§

type Output = <u32 as Add<u32>>::Output

source§

impl Add<&u32> for u32

§

type Output = <u32 as Add<u32>>::Output

source§

impl Add<&u64> for &u64

§

type Output = <u64 as Add<u64>>::Output

source§

impl Add<&u64> for u64

§

type Output = <u64 as Add<u64>>::Output

source§

impl Add<&u128> for &u128

§

type Output = <u128 as Add<u128>>::Output

source§

impl Add<&u128> for u128

§

type Output = <u128 as Add<u128>>::Output

source§

impl Add<&usize> for &usize

§

type Output = <usize as Add<usize>>::Output

source§

impl Add<&usize> for usize

§

type Output = <usize as Add<usize>>::Output

source§

impl Add<&Saturating<i8>> for &Saturating<i8>

source§

impl Add<&Saturating<i8>> for Saturating<i8>

source§

impl Add<&Saturating<i16>> for &Saturating<i16>

source§

impl Add<&Saturating<i16>> for Saturating<i16>

source§

impl Add<&Saturating<i32>> for &Saturating<i32>

source§

impl Add<&Saturating<i32>> for Saturating<i32>

source§

impl Add<&Saturating<i64>> for &Saturating<i64>

source§

impl Add<&Saturating<i64>> for Saturating<i64>

source§

impl Add<&Saturating<i128>> for &Saturating<i128>

source§

impl Add<&Saturating<i128>> for Saturating<i128>

source§

impl Add<&Saturating<isize>> for &Saturating<isize>

source§

impl Add<&Saturating<isize>> for Saturating<isize>

source§

impl Add<&Saturating<u8>> for &Saturating<u8>

source§

impl Add<&Saturating<u8>> for Saturating<u8>

source§

impl Add<&Saturating<u16>> for &Saturating<u16>

source§

impl Add<&Saturating<u16>> for Saturating<u16>

source§

impl Add<&Saturating<u32>> for &Saturating<u32>

source§

impl Add<&Saturating<u32>> for Saturating<u32>

source§

impl Add<&Saturating<u64>> for &Saturating<u64>

source§

impl Add<&Saturating<u64>> for Saturating<u64>

source§

impl Add<&Saturating<u128>> for &Saturating<u128>

source§

impl Add<&Saturating<u128>> for Saturating<u128>

source§

impl Add<&Saturating<usize>> for &Saturating<usize>

source§

impl Add<&Saturating<usize>> for Saturating<usize>

1.14.0 · source§

impl Add<&Wrapping<i8>> for &Wrapping<i8>

1.14.0 · source§

impl Add<&Wrapping<i8>> for Wrapping<i8>

1.14.0 · source§

impl Add<&Wrapping<i16>> for &Wrapping<i16>

1.14.0 · source§

impl Add<&Wrapping<i16>> for Wrapping<i16>

1.14.0 · source§

impl Add<&Wrapping<i32>> for &Wrapping<i32>

1.14.0 · source§

impl Add<&Wrapping<i32>> for Wrapping<i32>

1.14.0 · source§

impl Add<&Wrapping<i64>> for &Wrapping<i64>

1.14.0 · source§

impl Add<&Wrapping<i64>> for Wrapping<i64>

1.14.0 · source§

impl Add<&Wrapping<i128>> for &Wrapping<i128>

1.14.0 · source§

impl Add<&Wrapping<i128>> for Wrapping<i128>

1.14.0 · source§

impl Add<&Wrapping<isize>> for &Wrapping<isize>

1.14.0 · source§

impl Add<&Wrapping<isize>> for Wrapping<isize>

1.14.0 · source§

impl Add<&Wrapping<u8>> for &Wrapping<u8>

1.14.0 · source§

impl Add<&Wrapping<u8>> for Wrapping<u8>

1.14.0 · source§

impl Add<&Wrapping<u16>> for &Wrapping<u16>

1.14.0 · source§

impl Add<&Wrapping<u16>> for Wrapping<u16>

1.14.0 · source§

impl Add<&Wrapping<u32>> for &Wrapping<u32>

1.14.0 · source§

impl Add<&Wrapping<u32>> for Wrapping<u32>

1.14.0 · source§

impl Add<&Wrapping<u64>> for &Wrapping<u64>

1.14.0 · source§

impl Add<&Wrapping<u64>> for Wrapping<u64>

1.14.0 · source§

impl Add<&Wrapping<u128>> for &Wrapping<u128>

1.14.0 · source§

impl Add<&Wrapping<u128>> for Wrapping<u128>

1.14.0 · source§

impl Add<&Wrapping<usize>> for &Wrapping<usize>

1.14.0 · source§

impl Add<&Wrapping<usize>> for Wrapping<usize>

source§

impl Add<f32> for f32

§

type Output = f32

source§

impl Add<f64> for f64

§

type Output = f64

source§

impl Add<i8> for i8

§

type Output = i8

source§

impl Add<i8> for BigInt

source§

impl Add<i16> for i16

§

type Output = i16

source§

impl Add<i16> for BigInt

source§

impl Add<i32> for i32

§

type Output = i32

source§

impl Add<i32> for BigInt

source§

impl Add<i64> for i64

§

type Output = i64

source§

impl Add<i64> for BigInt

source§

impl Add<i128> for i128

§

type Output = i128

source§

impl Add<i128> for BigInt

source§

impl Add<isize> for isize

source§

impl Add<isize> for BigInt

source§

impl Add<u8> for u8

§

type Output = u8

source§

impl Add<u8> for BigInt

source§

impl Add<u8> for num_bigint::biguint::BigUint

source§

impl Add<u16> for u16

§

type Output = u16

source§

impl Add<u16> for BigInt

source§

impl Add<u16> for num_bigint::biguint::BigUint

source§

impl Add<u32> for u32

§

type Output = u32

source§

impl Add<u32> for BigInt

source§

impl Add<u32> for num_bigint::biguint::BigUint

source§

impl Add<u64> for u64

§

type Output = u64

source§

impl Add<u64> for BigInt

source§

impl Add<u64> for num_bigint::biguint::BigUint

source§

impl Add<u128> for u128

§

type Output = u128

source§

impl Add<u128> for BigInt

source§

impl Add<u128> for num_bigint::biguint::BigUint

source§

impl Add<usize> for usize

source§

impl Add<usize> for BigInt

source§

impl Add<usize> for num_bigint::biguint::BigUint

source§

impl Add<Months> for NaiveDate

source§

impl Add<Months> for NaiveDateTime

source§

impl Add<Days> for NaiveDate

source§

impl Add<Days> for NaiveDateTime

source§

impl Add<FixedOffset> for NaiveDateTime

source§

impl Add<FixedOffset> for NaiveTime

source§

impl Add<Ieee32> for Ieee32

source§

impl Add<Ieee64> for Ieee64

source§

impl Add<EdwardsPoint> for curve25519_dalek::edwards::EdwardsPoint

source§

impl Add<EdwardsPoint> for curve25519_dalek::edwards::EdwardsPoint

source§

impl Add<RistrettoPoint> for curve25519_dalek::ristretto::RistrettoPoint

source§

impl Add<RistrettoPoint> for curve25519_dalek::ristretto::RistrettoPoint

source§

impl Add<Scalar> for curve25519_dalek::scalar::Scalar

source§

impl Add<Scalar> for curve25519_dalek::scalar::Scalar

source§

impl Add<Field> for Field

source§

impl Add<Scalar> for libsecp256k1_core::scalar::Scalar

source§

impl Add<BigInt> for i8

source§

impl Add<BigInt> for i16

source§

impl Add<BigInt> for i32

source§

impl Add<BigInt> for i64

source§

impl Add<BigInt> for i128

source§

impl Add<BigInt> for isize

source§

impl Add<BigInt> for u8

source§

impl Add<BigInt> for u16

source§

impl Add<BigInt> for u32

source§

impl Add<BigInt> for u64

source§

impl Add<BigInt> for u128

source§

impl Add<BigInt> for usize

source§

impl Add<BigInt> for BigInt

source§

impl Add<BigUint> for u8

source§

impl Add<BigUint> for u16

source§

impl Add<BigUint> for u32

source§

impl Add<BigUint> for u64

source§

impl Add<BigUint> for u128

source§

impl Add<BigUint> for usize

source§

impl Add<BigUint> for num_bigint::biguint::BigUint

source§

impl Add<u32x4_generic> for u32x4_generic

source§

impl Add<u64x2_generic> for u64x2_generic

source§

impl Add<u128x1_generic> for u128x1_generic

source§

impl Add<BigUint> for sp_arithmetic::biguint::BigUint

source§

impl Add<FixedI64> for FixedI64

source§

impl Add<FixedI128> for FixedI128

source§

impl Add<FixedU64> for FixedU64

source§

impl Add<FixedU128> for FixedU128

source§

impl Add<PerU16> for PerU16

source§

impl Add<Perbill> for Perbill

source§

impl Add<Percent> for Percent

source§

impl Add<Permill> for Permill

source§

impl Add<Perquintill> for Perquintill

source§

impl Add<Weight> for Weight

source§

impl Add<Duration> for NaiveDate

An addition of Duration to NaiveDate discards the fractional days, rounding to the closest integral number of days towards Duration::zero().

Panics on underflow or overflow. Use NaiveDate::checked_add_signed to detect that.

Example

use chrono::{Duration, NaiveDate};

let from_ymd = NaiveDate::from_ymd;

assert_eq!(from_ymd(2014, 1, 1) + Duration::zero(),             from_ymd(2014, 1, 1));
assert_eq!(from_ymd(2014, 1, 1) + Duration::seconds(86399),     from_ymd(2014, 1, 1));
assert_eq!(from_ymd(2014, 1, 1) + Duration::seconds(-86399),    from_ymd(2014, 1, 1));
assert_eq!(from_ymd(2014, 1, 1) + Duration::days(1),            from_ymd(2014, 1, 2));
assert_eq!(from_ymd(2014, 1, 1) + Duration::days(-1),           from_ymd(2013, 12, 31));
assert_eq!(from_ymd(2014, 1, 1) + Duration::days(364),          from_ymd(2014, 12, 31));
assert_eq!(from_ymd(2014, 1, 1) + Duration::days(365*4 + 1),    from_ymd(2018, 1, 1));
assert_eq!(from_ymd(2014, 1, 1) + Duration::days(365*400 + 97), from_ymd(2414, 1, 1));
source§

impl Add<Duration> for NaiveDateTime

An addition of Duration to NaiveDateTime yields another NaiveDateTime.

As a part of Chrono’s leap second handling, the addition assumes that there is no leap second ever, except when the NaiveDateTime itself represents a leap second in which case the assumption becomes that there is exactly a single leap second ever.

Panics on underflow or overflow. Use NaiveDateTime::checked_add_signed to detect that.

Example

use chrono::{Duration, NaiveDate};

let from_ymd = NaiveDate::from_ymd;

let d = from_ymd(2016, 7, 8);
let hms = |h, m, s| d.and_hms_opt(h, m, s).unwrap();
assert_eq!(hms(3, 5, 7) + Duration::zero(),             hms(3, 5, 7));
assert_eq!(hms(3, 5, 7) + Duration::seconds(1),         hms(3, 5, 8));
assert_eq!(hms(3, 5, 7) + Duration::seconds(-1),        hms(3, 5, 6));
assert_eq!(hms(3, 5, 7) + Duration::seconds(3600 + 60), hms(4, 6, 7));
assert_eq!(hms(3, 5, 7) + Duration::seconds(86_400),
           from_ymd(2016, 7, 9).and_hms_opt(3, 5, 7).unwrap());
assert_eq!(hms(3, 5, 7) + Duration::days(365),
           from_ymd(2017, 7, 8).and_hms_opt(3, 5, 7).unwrap());

let hmsm = |h, m, s, milli| d.and_hms_milli_opt(h, m, s, milli).unwrap();
assert_eq!(hmsm(3, 5, 7, 980) + Duration::milliseconds(450), hmsm(3, 5, 8, 430));

Leap seconds are handled, but the addition assumes that it is the only leap second happened.

let leap = hmsm(3, 5, 59, 1_300);
assert_eq!(leap + Duration::zero(),             hmsm(3, 5, 59, 1_300));
assert_eq!(leap + Duration::milliseconds(-500), hmsm(3, 5, 59, 800));
assert_eq!(leap + Duration::milliseconds(500),  hmsm(3, 5, 59, 1_800));
assert_eq!(leap + Duration::milliseconds(800),  hmsm(3, 6, 0, 100));
assert_eq!(leap + Duration::seconds(10),        hmsm(3, 6, 9, 300));
assert_eq!(leap + Duration::seconds(-10),       hmsm(3, 5, 50, 300));
assert_eq!(leap + Duration::days(1),
           from_ymd(2016, 7, 9).and_hms_milli_opt(3, 5, 59, 300).unwrap());
source§

impl Add<Duration> for NaiveTime

An addition of Duration to NaiveTime wraps around and never overflows or underflows. In particular the addition ignores integral number of days.

As a part of Chrono’s leap second handling, the addition assumes that there is no leap second ever, except when the NaiveTime itself represents a leap second in which case the assumption becomes that there is exactly a single leap second ever.

Example

use chrono::{Duration, NaiveTime};

let from_hmsm = NaiveTime::from_hms_milli;

assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::zero(),                  from_hmsm(3, 5, 7, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::seconds(1),              from_hmsm(3, 5, 8, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::seconds(-1),             from_hmsm(3, 5, 6, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::seconds(60 + 4),         from_hmsm(3, 6, 11, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::seconds(7*60*60 - 6*60), from_hmsm(9, 59, 7, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::milliseconds(80),        from_hmsm(3, 5, 7, 80));
assert_eq!(from_hmsm(3, 5, 7, 950) + Duration::milliseconds(280),     from_hmsm(3, 5, 8, 230));
assert_eq!(from_hmsm(3, 5, 7, 950) + Duration::milliseconds(-980),    from_hmsm(3, 5, 6, 970));

The addition wraps around.

assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::seconds(22*60*60), from_hmsm(1, 5, 7, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::seconds(-8*60*60), from_hmsm(19, 5, 7, 0));
assert_eq!(from_hmsm(3, 5, 7, 0) + Duration::days(800),         from_hmsm(3, 5, 7, 0));

Leap seconds are handled, but the addition assumes that it is the only leap second happened.

let leap = from_hmsm(3, 5, 59, 1_300);
assert_eq!(leap + Duration::zero(),             from_hmsm(3, 5, 59, 1_300));
assert_eq!(leap + Duration::milliseconds(-500), from_hmsm(3, 5, 59, 800));
assert_eq!(leap + Duration::milliseconds(500),  from_hmsm(3, 5, 59, 1_800));
assert_eq!(leap + Duration::milliseconds(800),  from_hmsm(3, 6, 0, 100));
assert_eq!(leap + Duration::seconds(10),        from_hmsm(3, 6, 9, 300));
assert_eq!(leap + Duration::seconds(-10),       from_hmsm(3, 5, 50, 300));
assert_eq!(leap + Duration::days(1),            from_hmsm(3, 5, 59, 300));
source§

impl Add<Duration> for time::duration::Duration

source§

impl Add<Duration> for SteadyTime

source§

impl Add<Duration> for Timespec

source§

impl Add<Duration> for Tm

§

type Output = Tm

source§

impl Add<ATerm> for ATerm

source§

impl Add<B0> for UTerm

UTerm + B0 = UTerm

source§

impl Add<B1> for UTerm

UTerm + B1 = UInt<UTerm, B1>

source§

impl Add<Assume> for Assume

source§

impl Add<Saturating<i8>> for Saturating<i8>

source§

impl Add<Saturating<i16>> for Saturating<i16>

source§

impl Add<Saturating<i32>> for Saturating<i32>

source§

impl Add<Saturating<i64>> for Saturating<i64>

source§

impl Add<Saturating<i128>> for Saturating<i128>

source§

impl Add<Saturating<isize>> for Saturating<isize>

source§

impl Add<Saturating<u8>> for Saturating<u8>

source§

impl Add<Saturating<u16>> for Saturating<u16>

source§

impl Add<Saturating<u32>> for Saturating<u32>

source§

impl Add<Saturating<u64>> for Saturating<u64>

source§

impl Add<Saturating<u128>> for Saturating<u128>

source§

impl Add<Saturating<usize>> for Saturating<usize>

source§

impl Add<Wrapping<i8>> for Wrapping<i8>

source§

impl Add<Wrapping<i16>> for Wrapping<i16>

source§

impl Add<Wrapping<i32>> for Wrapping<i32>

source§

impl Add<Wrapping<i64>> for Wrapping<i64>

source§

impl Add<Wrapping<i128>> for Wrapping<i128>

source§

impl Add<Wrapping<isize>> for Wrapping<isize>

source§

impl Add<Wrapping<u8>> for Wrapping<u8>

source§

impl Add<Wrapping<u16>> for Wrapping<u16>

source§

impl Add<Wrapping<u32>> for Wrapping<u32>

source§

impl Add<Wrapping<u64>> for Wrapping<u64>

source§

impl Add<Wrapping<u128>> for Wrapping<u128>

source§

impl Add<Wrapping<usize>> for Wrapping<usize>

1.3.0 · source§

impl Add<Duration> for core::time::Duration

1.8.0 · source§

impl Add<Duration> for Instant

1.8.0 · source§

impl Add<Duration> for SystemTime

§

impl Add<u32x4> for u32x4

§

type Output = u32x4

§

impl Add<u64x2> for u64x2

§

type Output = u64x2

source§

impl<'a> Add<&'a i8> for BigInt

source§

impl<'a> Add<&'a i16> for BigInt

source§

impl<'a> Add<&'a i32> for BigInt

source§

impl<'a> Add<&'a i64> for BigInt

source§

impl<'a> Add<&'a i128> for BigInt

source§

impl<'a> Add<&'a isize> for BigInt

1.14.0 · source§

impl<'a> Add<&'a str> for Cow<'a, str>

§

type Output = Cow<'a, str>

source§

impl<'a> Add<&'a u8> for BigInt

source§

impl<'a> Add<&'a u8> for num_bigint::biguint::BigUint

source§

impl<'a> Add<&'a u16> for BigInt

source§

impl<'a> Add<&'a u16> for num_bigint::biguint::BigUint

source§

impl<'a> Add<&'a u32> for BigInt

source§

impl<'a> Add<&'a u32> for num_bigint::biguint::BigUint

source§

impl<'a> Add<&'a u64> for BigInt

source§

impl<'a> Add<&'a u64> for num_bigint::biguint::BigUint

source§

impl<'a> Add<&'a u128> for BigInt

source§

impl<'a> Add<&'a u128> for num_bigint::biguint::BigUint

source§

impl<'a> Add<&'a usize> for BigInt

source§

impl<'a> Add<&'a usize> for num_bigint::biguint::BigUint

source§

impl<'a> Add<&'a BigInt> for i8

source§

impl<'a> Add<&'a BigInt> for i16

source§

impl<'a> Add<&'a BigInt> for i32

source§

impl<'a> Add<&'a BigInt> for i64

source§

impl<'a> Add<&'a BigInt> for i128

source§

impl<'a> Add<&'a BigInt> for isize

source§

impl<'a> Add<&'a BigInt> for u8

source§

impl<'a> Add<&'a BigInt> for u16

source§

impl<'a> Add<&'a BigInt> for u32

source§

impl<'a> Add<&'a BigInt> for u64

source§

impl<'a> Add<&'a BigInt> for u128

source§

impl<'a> Add<&'a BigInt> for usize

source§

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

source§

impl<'a> Add<&'a BigUint> for u8

source§

impl<'a> Add<&'a BigUint> for u16

source§

impl<'a> Add<&'a BigUint> for u32

source§

impl<'a> Add<&'a BigUint> for u64

source§

impl<'a> Add<&'a BigUint> for u128

source§

impl<'a> Add<&'a BigUint> for usize

source§

impl<'a> Add<&'a BigUint> for num_bigint::biguint::BigUint

1.14.0 · source§

impl<'a> Add<Cow<'a, str>> for Cow<'a, str>

§

type Output = Cow<'a, str>

source§

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

§

type Output = <f32 as Add<f32>>::Output

source§

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

§

type Output = <f64 as Add<f64>>::Output

source§

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

§

type Output = <i8 as Add<i8>>::Output

source§

impl<'a> Add<i8> for &'a BigInt

source§

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

§

type Output = <i16 as Add<i16>>::Output

source§

impl<'a> Add<i16> for &'a BigInt

source§

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

§

type Output = <i32 as Add<i32>>::Output

source§

impl<'a> Add<i32> for &'a BigInt

source§

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

§

type Output = <i64 as Add<i64>>::Output

source§

impl<'a> Add<i64> for &'a BigInt

source§

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

§

type Output = <i128 as Add<i128>>::Output

source§

impl<'a> Add<i128> for &'a BigInt

source§

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

§

type Output = <isize as Add<isize>>::Output

source§

impl<'a> Add<isize> for &'a BigInt

source§

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

§

type Output = <u8 as Add<u8>>::Output

source§

impl<'a> Add<u8> for &'a BigInt

source§

impl<'a> Add<u8> for &'a num_bigint::biguint::BigUint

source§

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

§

type Output = <u16 as Add<u16>>::Output

source§

impl<'a> Add<u16> for &'a BigInt

source§

impl<'a> Add<u16> for &'a num_bigint::biguint::BigUint

source§

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

§

type Output = <u32 as Add<u32>>::Output

source§

impl<'a> Add<u32> for &'a BigInt

source§

impl<'a> Add<u32> for &'a num_bigint::biguint::BigUint

source§

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

§

type Output = <u64 as Add<u64>>::Output

source§

impl<'a> Add<u64> for &'a BigInt

source§

impl<'a> Add<u64> for &'a num_bigint::biguint::BigUint

source§

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

§

type Output = <u128 as Add<u128>>::Output

source§

impl<'a> Add<u128> for &'a BigInt

source§

impl<'a> Add<u128> for &'a num_bigint::biguint::BigUint

source§

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

§

type Output = <usize as Add<usize>>::Output

source§

impl<'a> Add<usize> for &'a BigInt

source§

impl<'a> Add<usize> for &'a num_bigint::biguint::BigUint

source§

impl<'a> Add<EdwardsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

source§

impl<'a> Add<EdwardsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

source§

impl<'a> Add<RistrettoPoint> for &'a curve25519_dalek::ristretto::RistrettoPoint

source§

impl<'a> Add<RistrettoPoint> for &'a curve25519_dalek::ristretto::RistrettoPoint

source§

impl<'a> Add<Scalar> for &'a curve25519_dalek::scalar::Scalar

source§

impl<'a> Add<Scalar> for &'a curve25519_dalek::scalar::Scalar

source§

impl<'a> Add<BigInt> for &'a i8

source§

impl<'a> Add<BigInt> for &'a i16

source§

impl<'a> Add<BigInt> for &'a i32

source§

impl<'a> Add<BigInt> for &'a i64

source§

impl<'a> Add<BigInt> for &'a i128

source§

impl<'a> Add<BigInt> for &'a isize

source§

impl<'a> Add<BigInt> for &'a u8

source§

impl<'a> Add<BigInt> for &'a u16

source§

impl<'a> Add<BigInt> for &'a u32

source§

impl<'a> Add<BigInt> for &'a u64

source§

impl<'a> Add<BigInt> for &'a u128

source§

impl<'a> Add<BigInt> for &'a usize

source§

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

source§

impl<'a> Add<BigUint> for &'a u8

source§

impl<'a> Add<BigUint> for &'a u16

source§

impl<'a> Add<BigUint> for &'a u32

source§

impl<'a> Add<BigUint> for &'a u64

source§

impl<'a> Add<BigUint> for &'a u128

source§

impl<'a> Add<BigUint> for &'a usize

source§

impl<'a> Add<BigUint> for &'a num_bigint::biguint::BigUint

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

1.14.0 · source§

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

source§

impl<'a, 'b> Add<&'a Field> for &'b Field

source§

impl<'a, 'b> Add<&'a Scalar> for &'b libsecp256k1_core::scalar::Scalar

source§

impl<'a, 'b> Add<&'a BigInt> for &'b i8

source§

impl<'a, 'b> Add<&'a BigInt> for &'b i16

source§

impl<'a, 'b> Add<&'a BigInt> for &'b i32

source§

impl<'a, 'b> Add<&'a BigInt> for &'b i64

source§

impl<'a, 'b> Add<&'a BigInt> for &'b i128

source§

impl<'a, 'b> Add<&'a BigInt> for &'b isize

source§

impl<'a, 'b> Add<&'a BigInt> for &'b u8

source§

impl<'a, 'b> Add<&'a BigInt> for &'b u16

source§

impl<'a, 'b> Add<&'a BigInt> for &'b u32

source§

impl<'a, 'b> Add<&'a BigInt> for &'b u64

source§

impl<'a, 'b> Add<&'a BigInt> for &'b u128

source§

impl<'a, 'b> Add<&'a BigInt> for &'b usize

source§

impl<'a, 'b> Add<&'a BigUint> for &'b u8

source§

impl<'a, 'b> Add<&'a BigUint> for &'b u16

source§

impl<'a, 'b> Add<&'a BigUint> for &'b u32

source§

impl<'a, 'b> Add<&'a BigUint> for &'b u64

source§

impl<'a, 'b> Add<&'a BigUint> for &'b u128

source§

impl<'a, 'b> Add<&'a BigUint> for &'b usize

source§

impl<'a, 'b> Add<&'b i8> for &'a BigInt

source§

impl<'a, 'b> Add<&'b i16> for &'a BigInt

source§

impl<'a, 'b> Add<&'b i32> for &'a BigInt

source§

impl<'a, 'b> Add<&'b i64> for &'a BigInt

source§

impl<'a, 'b> Add<&'b i128> for &'a BigInt

source§

impl<'a, 'b> Add<&'b isize> for &'a BigInt

source§

impl<'a, 'b> Add<&'b u8> for &'a BigInt

source§

impl<'a, 'b> Add<&'b u8> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b u16> for &'a BigInt

source§

impl<'a, 'b> Add<&'b u16> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b u32> for &'a BigInt

source§

impl<'a, 'b> Add<&'b u32> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b u64> for &'a BigInt

source§

impl<'a, 'b> Add<&'b u64> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b u128> for &'a BigInt

source§

impl<'a, 'b> Add<&'b u128> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b usize> for &'a BigInt

source§

impl<'a, 'b> Add<&'b usize> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b EdwardsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

source§

impl<'a, 'b> Add<&'b EdwardsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

source§

impl<'a, 'b> Add<&'b RistrettoPoint> for &'a curve25519_dalek::ristretto::RistrettoPoint

source§

impl<'a, 'b> Add<&'b RistrettoPoint> for &'a curve25519_dalek::ristretto::RistrettoPoint

source§

impl<'a, 'b> Add<&'b Scalar> for &'a curve25519_dalek::scalar::Scalar

source§

impl<'a, 'b> Add<&'b Scalar> for &'a curve25519_dalek::scalar::Scalar

source§

impl<'a, 'b> Add<&'b BigInt> for &'a BigInt

source§

impl<'a, 'b> Add<&'b BigUint> for &'a num_bigint::biguint::BigUint

source§

impl<'a, 'b> Add<&'b AffineNielsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

§

type Output = CompletedPoint

source§

impl<'a, 'b> Add<&'b AffineNielsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

§

type Output = CompletedPoint

source§

impl<'a, 'b> Add<&'b ProjectiveNielsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

§

type Output = CompletedPoint

source§

impl<'a, 'b> Add<&'b ProjectiveNielsPoint> for &'a curve25519_dalek::edwards::EdwardsPoint

§

type Output = CompletedPoint

source§

impl<'a, 'b, T> Add<&'b Ratio<T>> for &'a Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<'a, 'b, T> Add<&'b T> for &'a Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<'a, T> Add<&'a Ratio<T>> for Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<'a, T> Add<&'a T> for Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<'a, T> Add<Ratio<T>> for &'a Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<'a, T> Add<T> for &'a Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<'a, T> Add<T> for &'a U128where T: Into<U128>,

§

type Output = U128

source§

impl<'a, T> Add<T> for &'a U256where T: Into<U256>,

§

type Output = U256

source§

impl<'a, T> Add<T> for &'a U512where T: Into<U512>,

§

type Output = U512

source§

impl<'b> Add<&'b EdwardsPoint> for curve25519_dalek::edwards::EdwardsPoint

source§

impl<'b> Add<&'b EdwardsPoint> for curve25519_dalek::edwards::EdwardsPoint

source§

impl<'b> Add<&'b RistrettoPoint> for curve25519_dalek::ristretto::RistrettoPoint

source§

impl<'b> Add<&'b RistrettoPoint> for curve25519_dalek::ristretto::RistrettoPoint

source§

impl<'b> Add<&'b Scalar> for curve25519_dalek::scalar::Scalar

source§

impl<'b> Add<&'b Scalar> for curve25519_dalek::scalar::Scalar

source§

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

§

type Output = Simd<T, LANES>

source§

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

§

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

source§

impl<I> Add<I> for Z0where I: Integer,

Z0 + I = I

§

type Output = I

source§

impl<T> Add<Ratio<T>> for Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<T> Add<T> for Byteswhere T: Into<Bytes>,

source§

impl<T> Add<T> for memory_units::target::Pageswhere T: Into<Pages>,

source§

impl<T> Add<T> for memory_units::target::Wordswhere T: Into<Words>,

source§

impl<T> Add<T> for memory_units::wasm32::Pageswhere T: Into<Pages>,

source§

impl<T> Add<T> for memory_units::wasm32::Wordswhere T: Into<Words>,

source§

impl<T> Add<T> for Ratio<T>where T: Clone + Integer,

§

type Output = Ratio<T>

source§

impl<T> Add<T> for U128where T: Into<U128>,

§

type Output = U128

source§

impl<T> Add<T> for U256where T: Into<U256>,

§

type Output = U256

source§

impl<T> Add<T> for U512where T: Into<U512>,

§

type Output = U512

source§

impl<T> Add<T> for F32where T: Into<F32>,

§

type Output = F32

source§

impl<T> Add<T> for F64where T: Into<F64>,

§

type Output = F64

source§

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

§

type Output = Simd<T, LANES>

source§

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

§

type Output = Simd<T, LANES>

source§

impl<Tz> Add<Months> for DateTime<Tz>where Tz: TimeZone,

§

type Output = DateTime<Tz>

source§

impl<Tz> Add<Days> for DateTime<Tz>where Tz: TimeZone,

§

type Output = DateTime<Tz>

source§

impl<Tz> Add<FixedOffset> for DateTime<Tz>where Tz: TimeZone,

§

type Output = DateTime<Tz>

source§

impl<Tz> Add<Duration> for Date<Tz>where Tz: TimeZone,

§

type Output = Date<Tz>

source§

impl<Tz> Add<Duration> for DateTime<Tz>where Tz: TimeZone,

§

type Output = DateTime<Tz>

source§

impl<U> Add<B1> for UInt<U, B0>where U: Unsigned,

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

§

type Output = UInt<U, B1>

source§

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

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

§

type Output = UInt<<U as Add<B1>>::Output, B0>

source§

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

NInt + Z0 = NInt

§

type Output = NInt<U>

source§

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

PInt + Z0 = PInt

§

type Output = PInt<U>

source§

impl<U> Add<U> for UTermwhere U: Unsigned,

UTerm + U = U

§

type Output = U

source§

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

U + B0 = U

§

type Output = UInt<U, B>

source§

impl<U, B> Add<UTerm> for UInt<U, B>where U: Unsigned, B: Bit,

UInt<U, B> + UTerm = UInt<U, B>

§

type Output = UInt<U, B>

source§

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

N(Ul) + N(Ur) = N(Ul + Ur)

§

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

source§

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

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

§

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

source§

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

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

§

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

source§

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

P(Ul) + P(Ur) = P(Ul + Ur)

§

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

source§

impl<Ul, Ur> Add<UInt<Ur, B0>> for UInt<Ul, B0>where Ul: Unsigned + Add<Ur>, Ur: Unsigned,

UInt<Ul, B0> + UInt<Ur, B0> = UInt<Ul + Ur, B0>

§

type Output = UInt<<Ul as Add<Ur>>::Output, B0>

source§

impl<Ul, Ur> Add<UInt<Ur, B0>> for UInt<Ul, B1>where Ul: Unsigned + Add<Ur>, Ur: Unsigned,

UInt<Ul, B1> + UInt<Ur, B0> = UInt<Ul + Ur, B1>

§

type Output = UInt<<Ul as Add<Ur>>::Output, B1>

source§

impl<Ul, Ur> Add<UInt<Ur, B1>> for UInt<Ul, B0>where Ul: Unsigned + Add<Ur>, Ur: Unsigned,

UInt<Ul, B0> + UInt<Ur, B1> = UInt<Ul + Ur, B1>

§

type Output = UInt<<Ul as Add<Ur>>::Output, B1>

source§

impl<Ul, Ur> Add<UInt<Ur, B1>> for UInt<Ul, B1>where Ul: Unsigned + Add<Ur>, Ur: Unsigned, <Ul as Add<Ur>>::Output: Add<B1>,

UInt<Ul, B1> + UInt<Ur, B1> = UInt<(Ul + Ur) + B1, B0>

§

type Output = UInt<<<Ul as Add<Ur>>::Output as Add<B1>>::Output, B0>

source§

impl<const N: usize> Add<Simd<f32, N>> for Simd<f32, N>where f32: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<f32, N>

source§

impl<const N: usize> Add<Simd<f64, N>> for Simd<f64, N>where f64: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<f64, N>

source§

impl<const N: usize> Add<Simd<i8, N>> for Simd<i8, N>where i8: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<i8, N>

source§

impl<const N: usize> Add<Simd<i16, N>> for Simd<i16, N>where i16: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<i16, N>

source§

impl<const N: usize> Add<Simd<i32, N>> for Simd<i32, N>where i32: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<i32, N>

source§

impl<const N: usize> Add<Simd<i64, N>> for Simd<i64, N>where i64: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<i64, N>

source§

impl<const N: usize> Add<Simd<isize, N>> for Simd<isize, N>where isize: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<isize, N>

source§

impl<const N: usize> Add<Simd<u8, N>> for Simd<u8, N>where u8: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<u8, N>

source§

impl<const N: usize> Add<Simd<u16, N>> for Simd<u16, N>where u16: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<u16, N>

source§

impl<const N: usize> Add<Simd<u32, N>> for Simd<u32, N>where u32: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<u32, N>

source§

impl<const N: usize> Add<Simd<u64, N>> for Simd<u64, N>where u64: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<u64, N>

source§

impl<const N: usize> Add<Simd<usize, N>> for Simd<usize, N>where usize: SimdElement, LaneCount<N>: SupportedLaneCount,

§

type Output = Simd<usize, N>