Struct sp_weights::Weight

source ·
pub struct Weight { /* private fields */ }

Implementations§

source§

impl Weight

source

pub const fn set_ref_time(self, c: u64) -> Self

Set the reference time part of the weight.

source

pub const fn set_proof_size(self, c: u64) -> Self

Set the storage size part of the weight.

source

pub const fn ref_time(&self) -> u64

Return the reference time part of the weight.

source

pub const fn proof_size(&self) -> u64

Return the storage size part of the weight.

source

pub fn ref_time_mut(&mut self) -> &mut u64

Return a mutable reference to the reference time part of the weight.

source

pub fn proof_size_mut(&mut self) -> &mut u64

Return a mutable reference to the storage size part of the weight.

source

pub const MAX: Self = _

source

pub fn min(&self, other: Self) -> Self

Get the conservative min of self and other weight.

source

pub fn max(&self, other: Self) -> Self

Get the aggressive max of self and other weight.

source

pub fn try_add(&self, other: &Self, limit: &Self) -> Option<Self>

Try to add some other weight while upholding the limit.

source

pub const fn from_ref_time(ref_time: u64) -> Self

Construct Weight with reference time weight and 0 storage size weight.

source

pub const fn from_proof_size(proof_size: u64) -> Self

Construct Weight with storage size weight and 0 reference time weight.

source

pub const fn from_parts(ref_time: u64, proof_size: u64) -> Self

Construct Weight from weight parts, namely reference time and proof size weights.

source

pub const fn from_all(value: u64) -> Self

Construct Weight from the same weight for all parts.

source

pub const fn saturating_add(self, rhs: Self) -> Self

Saturating Weight addition. Computes self + rhs, saturating at the numeric bounds of all fields instead of overflowing.

source

pub const fn saturating_sub(self, rhs: Self) -> Self

Saturating Weight subtraction. Computes self - rhs, saturating at the numeric bounds of all fields instead of overflowing.

source

pub const fn saturating_mul(self, scalar: u64) -> Self

Saturating Weight scalar multiplication. Computes self.field * scalar for all fields, saturating at the numeric bounds of all fields instead of overflowing.

source

pub const fn saturating_div(self, scalar: u64) -> Self

Saturating Weight scalar division. Computes self.field / scalar for all fields, saturating at the numeric bounds of all fields instead of overflowing.

source

pub const fn saturating_pow(self, exp: u32) -> Self

Saturating Weight scalar exponentiation. Computes self.field.pow(exp) for all fields, saturating at the numeric bounds of all fields instead of overflowing.

source

pub fn saturating_accrue(&mut self, amount: Self)

Increment Weight by amount via saturating addition.

source

pub fn saturating_reduce(&mut self, amount: Self)

Reduce Weight by amount via saturating subtraction.

source

pub const fn checked_add(&self, rhs: &Self) -> Option<Self>

Checked Weight addition. Computes self + rhs, returning None if overflow occurred.

source

pub const fn checked_sub(&self, rhs: &Self) -> Option<Self>

Checked Weight subtraction. Computes self - rhs, returning None if overflow occurred.

source

pub const fn checked_mul(self, scalar: u64) -> Option<Self>

Checked Weight scalar multiplication. Computes self.field * scalar for each field, returning None if overflow occurred.

source

pub const fn checked_div(self, scalar: u64) -> Option<Self>

Checked Weight scalar division. Computes self.field / scalar for each field, returning None if overflow occurred.

source

pub const fn checked_div_per_component(self, other: &Self) -> Option<u64>

Calculates how many other fit into self.

Divides each component of self against the same component of other. Returns the minimum of all those divisions. Returns None in case all components of other are zero.

This returns Some even if some components of other are zero as long as there is at least one non-zero component in other. The devision for this particular component will then yield the maximum value (e.g u64::MAX). This is because we assume not every operation and hence each Weight will necessarily use each resource.

source

pub fn checked_accrue(&mut self, amount: Self) -> Option<()>

Try to increase self by amount via checked addition.

source

pub fn checked_reduce(&mut self, amount: Self) -> Option<()>

Try to reduce self by amount via checked subtraction.

source

pub const fn zero() -> Self

Return a Weight where all fields are zero.

source

pub const fn add_ref_time(self, scalar: u64) -> Self

Constant version of Add for ref_time component with u64.

Is only overflow safe when evaluated at compile-time.

source

pub const fn add_proof_size(self, scalar: u64) -> Self

Constant version of Add for proof_size component with u64.

Is only overflow safe when evaluated at compile-time.

source

pub const fn sub_ref_time(self, scalar: u64) -> Self

Constant version of Sub for ref_time component with u64.

Is only overflow safe when evaluated at compile-time.

source

pub const fn sub_proof_size(self, scalar: u64) -> Self

Constant version of Sub for proof_size component with u64.

Is only overflow safe when evaluated at compile-time.

source

pub const fn div(self, scalar: u64) -> Self

Constant version of Div with u64.

Is only overflow safe when evaluated at compile-time.

source

pub const fn mul(self, scalar: u64) -> Self

Constant version of Mul with u64.

Is only overflow safe when evaluated at compile-time.

source

pub const fn any_gt(self, other: Self) -> bool

Returns true if any of self’s constituent weights is strictly greater than that of the other’s, otherwise returns false.

source

pub const fn all_gt(self, other: Self) -> bool

Returns true if all of self’s constituent weights is strictly greater than that of the other’s, otherwise returns false.

source

pub const fn any_lt(self, other: Self) -> bool

Returns true if any of self’s constituent weights is strictly less than that of the other’s, otherwise returns false.

source

pub const fn all_lt(self, other: Self) -> bool

Returns true if all of self’s constituent weights is strictly less than that of the other’s, otherwise returns false.

source

pub const fn any_gte(self, other: Self) -> bool

Returns true if any of self’s constituent weights is greater than or equal to that of the other’s, otherwise returns false.

source

pub const fn all_gte(self, other: Self) -> bool

Returns true if all of self’s constituent weights is greater than or equal to that of the other’s, otherwise returns false.

source

pub const fn any_lte(self, other: Self) -> bool

Returns true if any of self’s constituent weights is less than or equal to that of the other’s, otherwise returns false.

source

pub const fn all_lte(self, other: Self) -> bool

Returns true if all of self’s constituent weights is less than or equal to that of the other’s, otherwise returns false.

source

pub const fn any_eq(self, other: Self) -> bool

Returns true if any of self’s constituent weights is equal to that of the other’s, otherwise returns false.

Trait Implementations§

source§

impl Add<Weight> for Weight

§

type Output = Weight

The resulting type after applying the + operator.
source§

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

Performs the + operation. Read more
source§

impl AddAssign<Weight> for Weight

source§

fn add_assign(&mut self, other: Self)

Performs the += operation. Read more
source§

impl Bounded for Weight

source§

fn min_value() -> Self

Returns the smallest finite number this type can represent
source§

fn max_value() -> Self

Returns the largest finite number this type can represent
source§

impl CheckedAdd for Weight

source§

fn checked_add(&self, rhs: &Self) -> Option<Self>

Adds two numbers, checking for overflow. If overflow happens, None is returned.
source§

impl CheckedSub for Weight

source§

fn checked_sub(&self, rhs: &Self) -> Option<Self>

Subtracts two numbers, checking for underflow. If underflow happens, None is returned.
source§

impl Clone for Weight

source§

fn clone(&self) -> Weight

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Weight

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Decode for Weight

source§

fn decode<__CodecInputEdqy: Input>( __codec_input_edqy: &mut __CodecInputEdqy ) -> Result<Self, Error>

Attempt to deserialise the value from input.
source§

fn skip<I>(input: &mut I) -> Result<(), Error>where I: Input,

Attempt to skip the encoded value from input. Read more
source§

fn encoded_fixed_size() -> Option<usize>

Returns the fixed encoded size of the type. Read more
source§

impl Default for Weight

source§

fn default() -> Weight

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for Weight

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Display for Weight

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T> Div<T> for Weightwhere u64: Div<T, Output = u64>, T: Copy,

§

type Output = Weight

The resulting type after applying the / operator.
source§

fn div(self, b: T) -> Self

Performs the / operation. Read more
source§

impl Encode for Weight

source§

fn encode_to<__CodecOutputEdqy: Output + ?Sized>( &self, __codec_dest_edqy: &mut __CodecOutputEdqy )

Convert self to a slice and append it to the destination.
source§

fn size_hint(&self) -> usize

If possible give a hint of expected size of the encoding. Read more
source§

fn encode(&self) -> Vec<u8, Global>

Convert self to an owned vector.
source§

fn using_encoded<R, F>(&self, f: F) -> Rwhere F: FnOnce(&[u8]) -> R,

Convert self to a slice and then invoke the given closure with it.
source§

fn encoded_size(&self) -> usize

Calculates the encoded size. Read more
source§

impl From<(u64, u64)> for Weight

source§

fn from(value: (u64, u64)) -> Self

Converts to this type from the input type.
source§

impl From<OldWeight> for Weight

source§

fn from(old: OldWeight) -> Self

Converts to this type from the input type.
source§

impl From<u64> for Weight

source§

fn from(value: u64) -> Self

Converts to this type from the input type.
source§

impl MaxEncodedLen for Weight

source§

fn max_encoded_len() -> usize

Upper bound, in bytes, of the maximum encoded size of this item.
source§

impl<T> Mul<T> for Weightwhere T: Mul<u64, Output = u64> + Copy,

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: T) -> Self

Performs the * operation. Read more
source§

impl Mul<Weight> for PerU16

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for Perbill

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for Percent

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for Permill

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for Perquintill

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for u16

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for u32

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for u64

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl Mul<Weight> for u8

§

type Output = Weight

The resulting type after applying the * operator.
source§

fn mul(self, b: Weight) -> Weight

Performs the * operation. Read more
source§

impl PartialEq<Weight> for Weight

source§

fn eq(&self, other: &Weight) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for Weight

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Sub<Weight> for Weight

§

type Output = Weight

The resulting type after applying the - operator.
source§

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

Performs the - operation. Read more
source§

impl SubAssign<Weight> for Weight

source§

fn sub_assign(&mut self, other: Self)

Performs the -= operation. Read more
source§

impl TypeInfo for Weight

§

type Identity = Weight

The type identifying for which type info is provided. Read more
source§

fn type_info() -> Type

Returns the static type identifier for Self.
source§

impl Zero for Weight

source§

fn zero() -> Self

Returns the additive identity element of Self, 0. Read more
source§

fn is_zero(&self) -> bool

Returns true if self is equal to the additive identity.
source§

fn set_zero(&mut self)

Sets self to the additive identity element of Self, 0.
source§

impl Copy for Weight

source§

impl EncodeLike<Weight> for Weight

source§

impl Eq for Weight

source§

impl StructuralEq for Weight

source§

impl StructuralPartialEq for Weight

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> DecodeAll for Twhere T: Decode,

source§

fn decode_all(input: &mut &[u8]) -> Result<T, Error>

Decode Self and consume all of the given input data. Read more
source§

impl<T> DecodeLimit for Twhere T: Decode,

source§

fn decode_all_with_depth_limit(limit: u32, input: &mut &[u8]) -> Result<T, Error>

Decode Self and consume all of the given input data. Read more
source§

fn decode_with_depth_limit<I>(limit: u32, input: &mut I) -> Result<T, Error>where I: Input,

Decode Self with the given maximum recursion depth and advance input by the number of bytes consumed. Read more
§

impl<T> Downcast for Twhere T: Any,

§

fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for Twhere T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync + 'static>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> DynClone for Twhere T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

source§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

source§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

source§

impl<T> KeyedVec for Twhere T: Codec,

source§

fn to_keyed_vec(&self, prepend_key: &[u8]) -> Vec<u8, Global>

Return an encoding of Self prepended by given slice.
source§

impl<T> LowerBounded for Twhere T: Bounded,

source§

fn min_value() -> T

Returns the smallest finite number this type can represent
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> SaturatedConversion for T

source§

fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,

Convert from a value of T into an equivalent instance of Self. Read more
source§

fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,

Consume self to return an equivalent value of T. Read more
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,

source§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
source§

impl<T, S> UniqueSaturatedFrom<T> for Swhere S: TryFrom<T> + Bounded,

source§

fn unique_saturated_from(t: T) -> S

Convert from a value of T into an equivalent instance of Self.
source§

impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,

source§

fn unique_saturated_into(self) -> T

Consume self to return an equivalent value of T.
source§

impl<T> UpperBounded for Twhere T: Bounded,

source§

fn max_value() -> T

Returns the largest finite number this type can represent
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<S> Codec for Swhere S: Decode + Encode,

source§

impl<T> DeserializeOwned for Twhere T: for<'de> Deserialize<'de>,

source§

impl<T> EncodeLike<&&T> for Twhere T: Encode,

source§

impl<T> EncodeLike<&T> for Twhere T: Encode,

source§

impl<T> EncodeLike<&mut T> for Twhere T: Encode,

source§

impl<T> EncodeLike<Arc<T>> for Twhere T: Encode,

source§

impl<T> EncodeLike<Box<T, Global>> for Twhere T: Encode,

source§

impl<'a, T> EncodeLike<Cow<'a, T>> for Twhere T: ToOwned + Encode,

source§

impl<T> EncodeLike<Rc<T>> for Twhere T: Encode,

source§

impl<S> FullCodec for Swhere S: Decode + FullEncode,

source§

impl<S> FullEncode for Swhere S: Encode + EncodeLike<S>,

§

impl<T> MaybeDebug for Twhere T: Debug,

§

impl<T> MaybeRefUnwindSafe for Twhere T: RefUnwindSafe,

source§

impl<T> StaticTypeInfo for Twhere T: TypeInfo + 'static,