pub trait Sum<A = Self>: Sized {
// Required method
fn sum<I>(iter: I) -> Self
where I: Iterator<Item = A>;
}Expand description
Trait to represent types that can be created by summing up an iterator.
This trait is used to implement Iterator::sum(). Types which implement
this trait can be generated by using the sum() method on an iterator.
Like FromIterator, this trait should rarely be called directly.
Required Methodsยง
Dyn Compatibilityยง
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.
Implementorsยง
impl Sum for f16
impl Sum for f32
impl Sum for f64
impl Sum for f128
impl Sum for i8
impl Sum for i16
impl Sum for i32
impl Sum for i64
impl Sum for i128
impl Sum for isize
impl Sum for u8
impl Sum for u16
impl Sum for u32
impl Sum for u64
impl Sum for u128
impl Sum for usize
impl Sum for Saturating<u8>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl Sum for Saturating<u16>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl Sum for Saturating<u32>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl Sum for Saturating<u64>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl Sum for Saturating<u128>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl Sum for Saturating<usize>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl Sum for Wrapping<i8>
impl Sum for Wrapping<i16>
impl Sum for Wrapping<i32>
impl Sum for Wrapping<i64>
impl Sum for Wrapping<i128>
impl Sum for Wrapping<isize>
impl Sum for Wrapping<u8>
impl Sum for Wrapping<u16>
impl Sum for Wrapping<u32>
impl Sum for Wrapping<u64>
impl Sum for Wrapping<u128>
impl Sum for Wrapping<usize>
impl Sum for flams_router_vscode::server_fn::inventory::core::time::Duration
impl Sum for TimeDelta
impl Sum for BigInt
impl Sum for Number
impl Sum for ByteCount
impl Sum for CacheStats
impl Sum for Duration
impl Sum for LengthHint
impl Sum<usize> for LengthHint
impl<'a> Sum<&'a f16> for f16
impl<'a> Sum<&'a f32> for f32
impl<'a> Sum<&'a f64> for f64
impl<'a> Sum<&'a f128> for f128
impl<'a> Sum<&'a i8> for i8
impl<'a> Sum<&'a i16> for i16
impl<'a> Sum<&'a i32> for i32
impl<'a> Sum<&'a i64> for i64
impl<'a> Sum<&'a i128> for i128
impl<'a> Sum<&'a isize> for isize
impl<'a> Sum<&'a u8> for u8
impl<'a> Sum<&'a u16> for u16
impl<'a> Sum<&'a u32> for u32
impl<'a> Sum<&'a u64> for u64
impl<'a> Sum<&'a u128> for u128
impl<'a> Sum<&'a usize> for usize
impl<'a> Sum<&'a Saturating<u8>> for Saturating<u8>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl<'a> Sum<&'a Saturating<u16>> for Saturating<u16>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl<'a> Sum<&'a Saturating<u32>> for Saturating<u32>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl<'a> Sum<&'a Saturating<u64>> for Saturating<u64>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl<'a> Sum<&'a Saturating<u128>> for Saturating<u128>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl<'a> Sum<&'a Saturating<usize>> for Saturating<usize>
The short-circuiting behavior of this implementation is unspecified. If you care about short-circuiting, use Iterator::fold directly.
impl<'a> Sum<&'a Wrapping<i8>> for Wrapping<i8>
impl<'a> Sum<&'a Wrapping<i16>> for Wrapping<i16>
impl<'a> Sum<&'a Wrapping<i32>> for Wrapping<i32>
impl<'a> Sum<&'a Wrapping<i64>> for Wrapping<i64>
impl<'a> Sum<&'a Wrapping<i128>> for Wrapping<i128>
impl<'a> Sum<&'a Wrapping<isize>> for Wrapping<isize>
impl<'a> Sum<&'a Wrapping<u8>> for Wrapping<u8>
impl<'a> Sum<&'a Wrapping<u16>> for Wrapping<u16>
impl<'a> Sum<&'a Wrapping<u32>> for Wrapping<u32>
impl<'a> Sum<&'a Wrapping<u64>> for Wrapping<u64>
impl<'a> Sum<&'a Wrapping<u128>> for Wrapping<u128>
impl<'a> Sum<&'a Wrapping<usize>> for Wrapping<usize>
impl<'a> Sum<&'a Duration> for flams_router_vscode::server_fn::inventory::core::time::Duration
impl<'a> Sum<&'a TimeDelta> for TimeDelta
impl<'a> Sum<&'a BigInt> for BigInt
impl<'a> Sum<&'a Number> for Number
impl<'a> Sum<&'a Duration> for Duration
impl<'a, T> Sum<&'a NotNan<T>> for NotNan<T>
impl<'a, T> Sum<&'a NotNan<T>> for NotNan<T>
impl<'a, T> Sum<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, T> Sum<&'a OrderedFloat<T>> for OrderedFloat<T>
impl<'a, const N: usize> Sum<&'a Simd<f32, N>> for Simd<f32, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<f64, N>> for Simd<f64, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<i8, N>> for Simd<i8, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<i16, N>> for Simd<i16, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<i32, N>> for Simd<i32, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<i64, N>> for Simd<i64, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<isize, N>> for Simd<isize, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<u8, N>> for Simd<u8, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<u16, N>> for Simd<u16, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<u32, N>> for Simd<u32, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<u64, N>> for Simd<u64, N>where
LaneCount<N>: SupportedLaneCount,
impl<'a, const N: usize> Sum<&'a Simd<usize, N>> for Simd<usize, N>where
LaneCount<N>: SupportedLaneCount,
impl<T> Sum for NotNan<T>
Adds a float directly.
Panics if the provided value is NaN.
impl<T> Sum for NotNan<T>
Adds a float directly.
Panics if the provided value is NaN.
impl<T> Sum for OrderedFloat<T>
Adds a float directly.
impl<T> Sum for OrderedFloat<T>
Adds a float directly.