referrerpolicy=no-referrer-when-downgrade

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§

1.0.0 · source

type Output

The resulting type after applying the + operator.

Required Methods§

1.0.0 · source

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

Performs the + operation.

§Example
assert_eq!(12 + 1, 13);

Implementors§

1.0.0 · source§

impl Add for f16

§

type Output = f16

1.0.0 · source§

impl Add for f32

§

type Output = f32

1.0.0 · source§

impl Add for f64

§

type Output = f64

1.0.0 · source§

impl Add for f128

§

type Output = f128

1.0.0 · source§

impl Add for i8

§

type Output = i8

1.0.0 · source§

impl Add for i16

§

type Output = i16

1.0.0 · source§

impl Add for i32

§

type Output = i32

1.0.0 · source§

impl Add for i64

§

type Output = i64

1.0.0 · source§

impl Add for i128

§

type Output = i128

1.0.0 · source§

impl Add for isize

1.0.0 · source§

impl Add for u8

§

type Output = u8

1.0.0 · source§

impl Add for u16

§

type Output = u16

1.0.0 · source§

impl Add for u32

§

type Output = u32

1.0.0 · source§

impl Add for u64

§

type Output = u64

1.0.0 · source§

impl Add for u128

§

type Output = u128

1.0.0 · source§

impl Add for usize

source§

impl Add for Assume

1.74.0 · source§

impl Add for Saturating<i8>

1.74.0 · source§

impl Add for Saturating<i16>

1.74.0 · source§

impl Add for Saturating<i32>

1.74.0 · source§

impl Add for Saturating<i64>

1.74.0 · source§

impl Add for Saturating<i128>

1.74.0 · source§

impl Add for Saturating<isize>

1.74.0 · source§

impl Add for Saturating<u8>

1.74.0 · source§

impl Add for Saturating<u16>

1.74.0 · source§

impl Add for Saturating<u32>

1.74.0 · source§

impl Add for Saturating<u64>

1.74.0 · source§

impl Add for Saturating<u128>

1.74.0 · source§

impl Add for Saturating<usize>

1.0.0 · source§

impl Add for Wrapping<i8>

1.0.0 · source§

impl Add for Wrapping<i16>

1.0.0 · source§

impl Add for Wrapping<i32>

1.0.0 · source§

impl Add for Wrapping<i64>

1.0.0 · source§

impl Add for Wrapping<i128>

1.0.0 · source§

impl Add for Wrapping<isize>

1.0.0 · source§

impl Add for Wrapping<u8>

1.0.0 · source§

impl Add for Wrapping<u16>

1.0.0 · source§

impl Add for Wrapping<u32>

1.0.0 · source§

impl Add for Wrapping<u64>

1.0.0 · source§

impl Add for Wrapping<u128>

1.0.0 · source§

impl Add for Wrapping<usize>

1.3.0 · source§

impl Add for core::time::Duration

source§

impl Add for chrono::duration::Duration

source§

impl Add for BigInt

source§

impl Add for num_bigint::biguint::BigUint

source§

impl Add for ATerm

§

impl Add for BigUint

§

type Output = BigUint

§

impl Add for Duration

§

type Output = Duration

§

impl Add for EdwardsPoint

§

type Output = EdwardsPoint

§

impl Add for Field

§

type Output = Field

§

impl Add for FixedI64

§

type Output = FixedI64

§

impl Add for FixedI128

§

type Output = FixedI128

§

impl Add for FixedU64

§

type Output = FixedU64

§

impl Add for FixedU128

§

type Output = FixedU128

§

impl Add for Ieee32

§

type Output = Ieee32

§

impl Add for Ieee64

§

type Output = Ieee64

§

impl Add for PerU16

§

type Output = PerU16

§

impl Add for Perbill

§

type Output = Perbill

§

impl Add for Percent

§

type Output = Percent

§

impl Add for Permill

§

type Output = Permill

§

impl Add for Perquintill

§

type Output = Perquintill

§

impl Add for Rgb

§

type Output = Rgb

§

impl Add for RistrettoPoint

§

type Output = RistrettoPoint

§

impl Add for Scalar

§

type Output = Scalar

§

impl Add for Scalar

§

type Output = Scalar

§

impl Add for Weight

§

type Output = Weight

1.0.0 · source§

impl Add<&f16> for &f16

§

type Output = <f16 as Add>::Output

1.0.0 · source§

impl Add<&f16> for f16

§

type Output = <f16 as Add>::Output

1.0.0 · source§

impl Add<&f32> for &f32

§

type Output = <f32 as Add>::Output

1.0.0 · source§

impl Add<&f32> for f32

§

type Output = <f32 as Add>::Output

1.0.0 · source§

impl Add<&f64> for &f64

§

type Output = <f64 as Add>::Output

1.0.0 · source§

impl Add<&f64> for f64

§

type Output = <f64 as Add>::Output

1.0.0 · source§

impl Add<&f128> for &f128

§

type Output = <f128 as Add>::Output

1.0.0 · source§

impl Add<&f128> for f128

§

type Output = <f128 as Add>::Output

1.0.0 · source§

impl Add<&i8> for &i8

§

type Output = <i8 as Add>::Output

source§

impl Add<&i8> for &BigInt

1.0.0 · source§

impl Add<&i8> for i8

§

type Output = <i8 as Add>::Output

source§

impl Add<&i8> for BigInt

1.0.0 · source§

impl Add<&i16> for &i16

§

type Output = <i16 as Add>::Output

source§

impl Add<&i16> for &BigInt

1.0.0 · source§

impl Add<&i16> for i16

§

type Output = <i16 as Add>::Output

source§

impl Add<&i16> for BigInt

1.0.0 · source§

impl Add<&i32> for &i32

§

type Output = <i32 as Add>::Output

source§

impl Add<&i32> for &BigInt

1.0.0 · source§

impl Add<&i32> for i32

§

type Output = <i32 as Add>::Output

source§

impl Add<&i32> for BigInt

1.0.0 · source§

impl Add<&i64> for &i64

§

type Output = <i64 as Add>::Output

source§

impl Add<&i64> for &BigInt

1.0.0 · source§

impl Add<&i64> for i64

§

type Output = <i64 as Add>::Output

source§

impl Add<&i64> for BigInt

1.0.0 · source§

impl Add<&i128> for &i128

§

type Output = <i128 as Add>::Output

source§

impl Add<&i128> for &BigInt

1.0.0 · source§

impl Add<&i128> for i128

§

type Output = <i128 as Add>::Output

source§

impl Add<&i128> for BigInt

1.0.0 · source§

impl Add<&isize> for &isize

§

type Output = <isize as Add>::Output

source§

impl Add<&isize> for &BigInt

1.0.0 · source§

impl Add<&isize> for isize

§

type Output = <isize as Add>::Output

source§

impl Add<&isize> for BigInt

1.0.0 · 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;
1.0.0 · source§

impl Add<&u8> for &u8

§

type Output = <u8 as Add>::Output

source§

impl Add<&u8> for &BigInt

source§

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

1.0.0 · source§

impl Add<&u8> for u8

§

type Output = <u8 as Add>::Output

source§

impl Add<&u8> for BigInt

source§

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

1.0.0 · source§

impl Add<&u16> for &u16

§

type Output = <u16 as Add>::Output

source§

impl Add<&u16> for &BigInt

source§

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

1.0.0 · source§

impl Add<&u16> for u16

§

type Output = <u16 as Add>::Output

source§

impl Add<&u16> for BigInt

source§

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

1.0.0 · source§

impl Add<&u32> for &u32

§

type Output = <u32 as Add>::Output

source§

impl Add<&u32> for &BigInt

source§

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

1.0.0 · source§

impl Add<&u32> for u32

§

type Output = <u32 as Add>::Output

source§

impl Add<&u32> for BigInt

source§

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

1.0.0 · source§

impl Add<&u64> for &u64

§

type Output = <u64 as Add>::Output

source§

impl Add<&u64> for &BigInt

source§

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

1.0.0 · source§

impl Add<&u64> for u64

§

type Output = <u64 as Add>::Output

source§

impl Add<&u64> for BigInt

source§

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

1.0.0 · source§

impl Add<&u128> for &u128

§

type Output = <u128 as Add>::Output

source§

impl Add<&u128> for &BigInt

source§

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

1.0.0 · source§

impl Add<&u128> for u128

§

type Output = <u128 as Add>::Output

source§

impl Add<&u128> for BigInt

source§

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

1.0.0 · source§

impl Add<&usize> for &usize

§

type Output = <usize as Add>::Output

source§

impl Add<&usize> for &BigInt

source§

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

1.0.0 · source§

impl Add<&usize> for usize

§

type Output = <usize as Add>::Output

source§

impl Add<&usize> for BigInt

source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.14.0 · source§

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

§

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

1.14.0 · source§

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

§

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

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>

§

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

1.14.0 · source§

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

§

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

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<&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<&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<&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

§

impl Add<&Rgb> for &Rgb

§

type Output = Rgb

§

impl Add<&Rgb> for Rgb

§

type Output = Rgb

source§

impl Add<i8> for &BigInt

source§

impl Add<i8> for BigInt

source§

impl Add<i16> for &BigInt

source§

impl Add<i16> for BigInt

source§

impl Add<i32> for &BigInt

source§

impl Add<i32> for BigInt

source§

impl Add<i64> for &BigInt

source§

impl Add<i64> for BigInt

source§

impl Add<i128> for &BigInt

source§

impl Add<i128> for BigInt

source§

impl Add<isize> for &BigInt

source§

impl Add<isize> for BigInt

source§

impl Add<u8> for &BigInt

source§

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

source§

impl Add<u8> for BigInt

source§

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

source§

impl Add<u16> for &BigInt

source§

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

source§

impl Add<u16> for BigInt

source§

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

source§

impl Add<u32> for &BigInt

source§

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

source§

impl Add<u32> for BigInt

source§

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

source§

impl Add<u64> for &BigInt

source§

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

source§

impl Add<u64> for BigInt

source§

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

source§

impl Add<u128> for &BigInt

source§

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

source§

impl Add<u128> for BigInt

source§

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

source§

impl Add<usize> for &BigInt

source§

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

source§

impl Add<usize> for BigInt

source§

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

1.8.0 · source§

impl Add<Duration> for std::time::Instant

1.8.0 · source§

impl Add<Duration> for SystemTime

source§

impl Add<Duration> for NaiveDateTime

source§

impl Add<Duration> for NaiveTime

§

impl Add<Duration> for Date

§

type Output = Date

§

impl Add<Duration> for Duration

§

type Output = Duration

§

impl Add<Duration> for Instant

§

type Output = Instant

§

impl Add<Duration> for OffsetDateTime

§

type Output = OffsetDateTime

§

impl Add<Duration> for PrimitiveDateTime

§

type Output = PrimitiveDateTime

§

impl Add<Duration> for Time

§

type Output = Time

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 = |y, m, d| NaiveDate::from_ymd_opt(y, m, d).unwrap();

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

Panics if the resulting date would be out of range. Use NaiveDateTime::checked_add_signed to detect that.

§Example

use chrono::{Duration, NaiveDate};

let from_ymd = |y, m, d| NaiveDate::from_ymd_opt(y, m, d).unwrap();

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 = |h, m, s, milli| { NaiveTime::from_hms_milli_opt(h, m, s, milli).unwrap() };

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<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<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<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<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<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<B0> for UTerm

UTerm + B0 = UTerm

source§

impl Add<B1> for UTerm

UTerm + B1 = UInt<UTerm, B1>

§

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

§

type Output = Duration

§

impl Add<Duration> for std::time::Instant

§

impl Add<Duration> for SystemTime

§

impl Add<Duration> for Date

§

type Output = Date

§

impl Add<Duration> for Instant

§

type Output = Instant

§

impl Add<Duration> for OffsetDateTime

§

type Output = OffsetDateTime

§

impl Add<Duration> for PrimitiveDateTime

§

type Output = PrimitiveDateTime

§

impl Add<Duration> for Time

§

type Output = Time

§

impl Add<Rgb> for &Rgb

§

type Output = Rgb

1.14.0 · source§

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

§

type Output = Cow<'a, str>

1.14.0 · source§

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

§

type Output = Cow<'a, str>

1.0.0 · source§

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

§

type Output = <f16 as Add>::Output

1.0.0 · source§

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

§

type Output = <f32 as Add>::Output

1.0.0 · source§

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

§

type Output = <f64 as Add>::Output

1.0.0 · source§

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

§

type Output = <f128 as Add>::Output

1.0.0 · source§

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

§

type Output = <i8 as Add>::Output

1.0.0 · source§

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

§

type Output = <i16 as Add>::Output

1.0.0 · source§

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

§

type Output = <i32 as Add>::Output

1.0.0 · source§

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

§

type Output = <i64 as Add>::Output

1.0.0 · source§

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

§

type Output = <i128 as Add>::Output

1.0.0 · source§

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

§

type Output = <isize as Add>::Output

1.0.0 · source§

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

§

type Output = <u8 as Add>::Output

1.0.0 · source§

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

§

type Output = <u16 as Add>::Output

1.0.0 · source§

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

§

type Output = <u32 as Add>::Output

1.0.0 · source§

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

§

type Output = <u64 as Add>::Output

1.0.0 · source§

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

§

type Output = <u128 as Add>::Output

1.0.0 · source§

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

§

type Output = <usize as Add>::Output

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.74.0 · source§

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

1.14.0 · source§

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

§

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

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>

§

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

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>

§

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

§

type Output = EdwardsPoint

§

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

§

type Output = RistrettoPoint

§

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

§

type Output = Scalar

§

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

§

type Output = Field

§

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

§

type Output = Scalar

§

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

§

type Output = CompletedPoint

§

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

§

type Output = EdwardsPoint

§

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

§

type Output = CompletedPoint

§

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

§

type Output = RistrettoPoint

§

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

§

type Output = Scalar

§

impl<'a, 'b, F> Add<&'a DenseMultilinearExtension<F>> for &'b DenseMultilinearExtension<F>
where F: Field,

§

type Output = DenseMultilinearExtension<F>

§

impl<'a, 'b, F> Add<&'a DensePolynomial<F>> for &'b DensePolynomial<F>
where F: Field,

§

type Output = DensePolynomial<F>

§

impl<'a, 'b, F> Add<&'a SparseMultilinearExtension<F>> for &'b SparseMultilinearExtension<F>
where F: Field,

§

type Output = SparseMultilinearExtension<F>

§

impl<'a, 'b, F> Add<&'a SparsePolynomial<F>> for &'b DensePolynomial<F>
where F: Field,

§

type Output = DensePolynomial<F>

§

impl<'a, 'b, F> Add<&'a SparsePolynomial<F>> for &'b SparsePolynomial<F>
where F: Field,

§

type Output = SparsePolynomial<F>

§

impl<'a, 'b, F, D> Add<&'a Evaluations<F, D>> for &'b Evaluations<F, D>
where F: FftField, D: EvaluationDomain<F>,

§

type Output = Evaluations<F, D>

§

impl<'a, 'b, F, T> Add<&'a SparsePolynomial<F, T>> for &'b SparsePolynomial<F, T>
where F: Field, T: Term,

§

type Output = SparsePolynomial<F, T>

§

impl<'a, 'b, P> Add<&'a CubicExtField<P>> for &'b CubicExtField<P>
where P: CubicExtConfig,

§

type Output = CubicExtField<P>

§

impl<'a, 'b, P> Add<&'a PairingOutput<P>> for &'b PairingOutput<P>
where P: Pairing,

§

type Output = PairingOutput<P>

§

impl<'a, 'b, P> Add<&'a Projective<P>> for &'b Projective<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<'a, 'b, P> Add<&'a Projective<P>> for &'b Projective<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<'a, 'b, P> Add<&'a QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

§

type Output = QuadExtField<P>

§

impl<'a, 'b, P> Add<&'a mut CubicExtField<P>> for &'b CubicExtField<P>
where P: CubicExtConfig,

§

type Output = CubicExtField<P>

§

impl<'a, 'b, P> Add<&'a mut PairingOutput<P>> for &'b PairingOutput<P>
where P: Pairing,

§

type Output = PairingOutput<P>

§

impl<'a, 'b, P> Add<&'a mut Projective<P>> for &'b Projective<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<'a, 'b, P> Add<&'a mut Projective<P>> for &'b Projective<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<'a, 'b, P> Add<&'a mut QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

§

type Output = QuadExtField<P>

§

impl<'a, 'b, P, const N: usize> Add<&'b Fp<P, N>> for &'a Fp<P, N>
where P: FpConfig<N>,

§

type Output = Fp<P, N>

§

impl<'a, P> Add<&'a CubicExtField<P>> for CubicExtField<P>
where P: CubicExtConfig,

§

type Output = CubicExtField<P>

§

impl<'a, P> Add<&'a PairingOutput<P>> for PairingOutput<P>
where P: Pairing,

§

type Output = PairingOutput<P>

§

impl<'a, P> Add<&'a Projective<P>> for Affine<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<'a, P> Add<&'a Projective<P>> for Affine<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<'a, P> Add<&'a Projective<P>> for Projective<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<'a, P> Add<&'a Projective<P>> for Projective<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<'a, P> Add<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

§

type Output = QuadExtField<P>

§

impl<'a, P> Add<&'a mut CubicExtField<P>> for CubicExtField<P>
where P: CubicExtConfig,

§

type Output = CubicExtField<P>

§

impl<'a, P> Add<&'a mut PairingOutput<P>> for PairingOutput<P>
where P: Pairing,

§

type Output = PairingOutput<P>

§

impl<'a, P> Add<&'a mut Projective<P>> for Projective<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<'a, P> Add<&'a mut Projective<P>> for Projective<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<'a, P> Add<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

§

type Output = QuadExtField<P>

§

impl<'a, P, const N: usize> Add<&'a Fp<P, N>> for Fp<P, N>
where P: FpConfig<N>,

§

type Output = Fp<P, N>

§

impl<'a, P, const N: usize> Add<&'a mut Fp<P, N>> for Fp<P, N>
where P: FpConfig<N>,

§

type Output = Fp<P, N>

§

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

§

type Output = U128

§

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

§

type Output = U128

§

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

§

type Output = U256

§

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

§

type Output = U256

§

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

§

type Output = U512

§

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

§

type Output = U512

§

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

§

type Output = EdwardsPoint

§

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

§

type Output = RistrettoPoint

§

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

§

type Output = Scalar

§

impl<'b, P> Add<CubicExtField<P>> for &'b CubicExtField<P>
where P: CubicExtConfig,

§

type Output = CubicExtField<P>

§

impl<'b, P> Add<PairingOutput<P>> for &'b PairingOutput<P>
where P: Pairing,

§

type Output = PairingOutput<P>

§

impl<'b, P> Add<Projective<P>> for &'b Projective<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<'b, P> Add<Projective<P>> for &'b Projective<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<'b, P> Add<QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

§

type Output = QuadExtField<P>

source§

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

§

type Output = Simd<T, N>

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>

§

impl<E> Add for KzgCommitment<E>
where E: Pairing,

§

type Output = KzgCommitment<E>

§

impl<F> Add for DenseMultilinearExtension<F>
where F: Field,

§

type Output = DenseMultilinearExtension<F>

§

impl<F> Add for DensePolynomial<F>
where F: Field,

§

type Output = DensePolynomial<F>

§

impl<F> Add for SparseMultilinearExtension<F>
where F: Field,

§

type Output = SparseMultilinearExtension<F>

§

impl<F> Add for SparsePolynomial<F>
where F: Field,

§

type Output = SparsePolynomial<F>

§

impl<F> Add<&SecretScalar<F>> for &SecretScalar<F>
where F: PrimeField,

§

type Output = SecretScalar<F>

§

impl<F, T> Add for SparsePolynomial<F, T>
where F: Field, T: Term,

§

type Output = SparsePolynomial<F, T>

source§

impl<I> Add<I> for Z0
where I: Integer,

Z0 + I = I

§

type Output = I

§

impl<P> Add for CubicExtField<P>
where P: CubicExtConfig,

§

type Output = CubicExtField<P>

§

impl<P> Add for PairingOutput<P>
where P: Pairing,

§

type Output = PairingOutput<P>

§

impl<P> Add for Projective<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<P> Add for Projective<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<P> Add for QuadExtField<P>
where P: QuadExtConfig,

§

type Output = QuadExtField<P>

§

impl<P> Add<Projective<P>> for Affine<P>
where P: SWCurveConfig,

§

type Output = Projective<P>

§

impl<P> Add<Projective<P>> for Affine<P>
where P: TECurveConfig,

§

type Output = Projective<P>

§

impl<P, T> Add<T> for Affine<P>
where P: SWCurveConfig, T: Borrow<Affine<P>>,

§

type Output = Projective<P>

§

impl<P, T> Add<T> for Affine<P>
where P: TECurveConfig, T: Borrow<Affine<P>>,

§

type Output = Projective<P>

§

impl<P, T> Add<T> for Projective<P>
where P: SWCurveConfig, T: Borrow<Affine<P>>,

§

type Output = Projective<P>

§

impl<P, T> Add<T> for Projective<P>
where P: TECurveConfig, T: Borrow<Affine<P>>,

§

type Output = Projective<P>

§

impl<P, const N: usize> Add for Fp<P, N>
where P: FpConfig<N>,

§

type Output = Fp<P, N>

§

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

§

type Output = U128

§

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

§

type Output = U128

§

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

§

type Output = U256

§

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

§

type Output = U256

§

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

§

type Output = U512

§

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

§

type Output = U512

§

impl<T, D> Add for TypeWithDefault<T, D>
where T: Add<Output = T>, D: Get<T>,

§

type Output = TypeWithDefault<T, D>

source§

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

§

type Output = Simd<T, N>

source§

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

§

type Output = Simd<T, N>

source§

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

§

type Output = DateTime<Tz>

source§

impl<Tz> Add<Duration> for chrono::date::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<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<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 UTerm
where 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 for Simd<f32, N>

§

type Output = Simd<f32, N>

source§

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

§

type Output = Simd<f64, N>

source§

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

§

type Output = Simd<i8, N>

source§

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

§

type Output = Simd<i16, N>

source§

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

§

type Output = Simd<i32, N>

source§

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

§

type Output = Simd<i64, N>

source§

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

§

type Output = Simd<isize, N>

source§

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

§

type Output = Simd<u8, N>

source§

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

§

type Output = Simd<u16, N>

source§

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

§

type Output = Simd<u32, N>

source§

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

§

type Output = Simd<u64, N>

source§

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

§

type Output = Simd<usize, N>