Struct bp::TapMerklePath

source ·
pub struct TapMerklePath(/* private fields */);

Implementations§

source§

impl TapMerklePath

source

pub fn try_from(path: Vec<TapBranchHash>) -> Result<TapMerklePath, Error>

Tries to construct a confinement over a collection. Fails if the number of items in the collection exceeds one of the confinement bounds.

source

pub fn try_from_iter<I>(iter: I) -> Result<TapMerklePath, Error>
where I: IntoIterator<Item = TapBranchHash>,

Tries to construct a confinement with a collection of elements taken from an iterator. Fails if the number of items in the collection exceeds one of the confinement bounds.

Methods from Deref<Target = Confined<Vec<TapBranchHash>, 0, 128>>§

source

pub fn iter_mut(&'c mut self) -> <&'c mut C as IntoIterator>::IntoIter

Returns an iterator that allows modifying each value.

The iterator yields all items from start to end.

source

pub fn keyed_values_mut(&'c mut self) -> <&'c mut C as IntoIterator>::IntoIter

Returns an iterator that allows modifying each value for each key.

source

pub fn as_inner(&self) -> &C

Returns inner collection type

source

pub fn to_inner(&self) -> C
where C: Clone,

Clones inner collection type and returns it

source

pub fn push(&mut self, elem: <C as Collection>::Item) -> Result<(), Error>

Attempts to add a single element to the confined collection. Fails if the number of elements in the collection already maximal.

source

pub fn extend<T>(&mut self, iter: T) -> Result<(), Error>
where T: IntoIterator<Item = <C as Collection>::Item>,

Attempts to add all elements from an iterator to the confined collection. Fails if the number of elements in the collection already maximal.

source

pub fn clear(&mut self)

Removes all elements from the confined collection.

source

pub fn len_u8(&self) -> u8

Returns number of elements in the confined collection as u8. The confinement guarantees that the collection length can’t exceed u8::MAX.

source

pub fn len_u16(&self) -> u16

Returns number of elements in the confined collection as u16. The confinement guarantees that the collection length can’t exceed u16::MAX.

source

pub fn len_u24(&self) -> u24

Returns number of elements in the confined collection as u24. The confinement guarantees that the collection length can’t exceed u24::MAX.

source

pub fn len_u32(&self) -> u32

Returns number of elements in the confined collection as u32. The confinement guarantees that the collection length can’t exceed u32::MAX.

source

pub fn get_mut( &mut self, key: &<C as KeyedCollection>::Key ) -> Option<&mut <C as KeyedCollection>::Value>

Gets mutable reference to an element of the collection.

source

pub fn insert( &mut self, key: <C as KeyedCollection>::Key, value: <C as KeyedCollection>::Value ) -> Result<Option<<C as KeyedCollection>::Value>, Error>

Inserts a new value into the confined collection under a given key. Fails if the collection already contains maximum number of elements allowed by the confinement.

source

pub fn pop(&mut self) -> Option<char>

Removes the last character from a string and returns it, or None if it is empty.

source

pub fn remove(&mut self, index: usize) -> Result<char, Error>

Removes a single character from the confined string, unless the string doesn’t shorten more than the confinement requirement. Errors otherwise.

source

pub fn pop(&mut self) -> Option<AsciiChar>

Removes the last character from a string and returns it, or None if it is empty.

source

pub fn remove(&mut self, index: usize) -> Result<AsciiChar, Error>

Removes a single character from the confined string, unless the string doesn’t shorten more than the confinement requirement. Errors otherwise.

source

pub fn as_slice(&self) -> &[T]

Returns slice representation of the vec.

source

pub fn get_mut<I>( &mut self, index: I ) -> Option<&mut <I as SliceIndex<[T]>>::Output>
where I: SliceIndex<[T]>,

Gets the mutable element of a vector

source

pub fn pop(&mut self) -> Option<T>

Removes the last element from a vector and returns it, or None if it is empty.

source

pub fn remove(&mut self, index: usize) -> Result<T, Error>

Removes an element from the vector at a given index. Errors if the index exceeds the number of elements in the vector, of if the new vector length will be less than the confinement requirement. Returns the removed element otherwise.

source

pub fn iter(&self) -> Iter<'_, T>

Returns an iterator over the slice.

The iterator yields all items from start to end.

source

pub fn pop_front(&mut self) -> Option<T>

Removes the first element and returns it, or None if the deque is empty.

source

pub fn pop_back(&mut self) -> Option<T>

Removes the last element and returns it, or None if the deque is empty.

source

pub fn push_from(&mut self, elem: T) -> Result<(), Error>

Prepends an element to the deque. Errors if the new collection length will not fit the confinement requirements.

source

pub fn push_back(&mut self, elem: T) -> Result<(), Error>

Appends an element to the deque. Errors if the new collection length will not fit the confinement requirements.

source

pub fn remove(&mut self, index: usize) -> Result<T, Error>

Removes an element from the deque at a given index. Errors if the index exceeds the number of elements in the deque, of if the new deque length will be less than the confinement requirement. Returns the removed element otherwise.

source

pub fn remove(&mut self, elem: &T) -> Result<bool, Error>

Available on crate feature std only.

Removes an element from the set. Errors if the index exceeds the number of elements in the set, of if the new collection length will be less than the confinement requirement. Returns if the element was present in the set.

source

pub fn take(&mut self, elem: &T) -> Result<Option<T>, Error>

Available on crate feature std only.

Removes an element from the set. Errors if the index exceeds the number of elements in the set, of if the new collection length will be less than the confinement requirement. Returns the removed element otherwise.

source

pub fn remove(&mut self, elem: &T) -> Result<bool, Error>

Removes an element from the set. Errors if the index exceeds the number of elements in the set, of if the new collection length will be less than the confinement requirement. Returns if the element was present in the set.

source

pub fn take(&mut self, elem: &T) -> Result<Option<T>, Error>

Removes an element from the set. Errors if the index exceeds the number of elements in the set, of if the new collection length will be less than the confinement requirement. Returns the removed element otherwise.

source

pub fn remove(&mut self, key: &K) -> Result<Option<V>, Error>

Available on crate feature std only.

Removes an element from the map. Errors if the index exceeds the number of elements in the map, of if the new collection length will be less than the confinement requirement. Returns the removed value otherwise.

source

pub fn remove(&mut self, key: &K) -> Result<Option<V>, Error>

Removes an element from the map. Errors if the index exceeds the number of elements in the map, of if the new collection length will be less than the confinement requirement. Returns the removed value otherwise.

Trait Implementations§

source§

impl AsMut<<TapMerklePath as Wrapper>::Inner> for TapMerklePath

source§

fn as_mut(&mut self) -> &mut <TapMerklePath as Wrapper>::Inner

Converts this type into a mutable reference of the (usually inferred) input type.
source§

impl AsRef<Confined<Vec<TapBranchHash>, 0, 128>> for TapMerklePath

source§

fn as_ref(&self) -> &Confined<Vec<TapBranchHash>, 0, 128>

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl Borrow<Confined<Vec<TapBranchHash>, 0, 128>> for TapMerklePath

source§

fn borrow(&self) -> &Confined<Vec<TapBranchHash>, 0, 128>

Immutably borrows from an owned value. Read more
source§

impl BorrowMut<<TapMerklePath as Wrapper>::Inner> for TapMerklePath

source§

fn borrow_mut(&mut self) -> &mut <TapMerklePath as Wrapper>::Inner

Mutably borrows from an owned value. Read more
source§

impl Clone for TapMerklePath

source§

fn clone(&self) -> TapMerklePath

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 TapMerklePath

source§

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

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

impl Default for TapMerklePath

source§

fn default() -> TapMerklePath

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

impl Deref for TapMerklePath

§

type Target = Confined<Vec<TapBranchHash>, 0, 128>

The resulting type after dereferencing.
source§

fn deref(&self) -> &<TapMerklePath as Deref>::Target

Dereferences the value.
source§

impl DerefMut for TapMerklePath

source§

fn deref_mut(&mut self) -> &mut <TapMerklePath as Deref>::Target

Mutably dereferences the value.
source§

impl<'de> Deserialize<'de> for TapMerklePath

source§

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

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

impl From<Confined<Vec<TapBranchHash>, 0, 128>> for TapMerklePath

source§

fn from(v: Confined<Vec<TapBranchHash>, 0, 128>) -> TapMerklePath

Converts to this type from the input type.
source§

impl From<TapMerklePath> for Confined<Vec<TapBranchHash>, 0, 128>

source§

fn from(wrapped: TapMerklePath) -> Confined<Vec<TapBranchHash>, 0, 128>

Converts to this type from the input type.
source§

impl Hash for TapMerklePath

source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<'a> IntoIterator for &'a TapMerklePath

§

type Item = &'a TapBranchHash

The type of the elements being iterated over.
§

type IntoIter = Iter<'a, TapBranchHash>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> <&'a TapMerklePath as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
source§

impl IntoIterator for TapMerklePath

§

type Item = TapBranchHash

The type of the elements being iterated over.
§

type IntoIter = IntoIter<TapBranchHash>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> <TapMerklePath as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
source§

impl Ord for TapMerklePath

source§

fn cmp(&self, other: &TapMerklePath) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for TapMerklePath

source§

fn eq(&self, other: &TapMerklePath) -> 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 PartialOrd for TapMerklePath

source§

fn partial_cmp(&self, other: &TapMerklePath) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

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

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

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

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

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

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

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

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl Serialize for TapMerklePath

source§

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

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

impl StrictDecode for TapMerklePath

source§

impl StrictEncode for TapMerklePath

source§

fn strict_encode<W>(&self, writer: W) -> Result<W, Error>
where W: TypedWrite,

source§

fn strict_write(&self, writer: impl WriteRaw) -> Result<(), Error>

source§

impl StrictTuple for TapMerklePath

source§

impl StrictType for TapMerklePath

source§

const STRICT_LIB_NAME: &'static str = LIB_NAME_BITCOIN

source§

fn strict_name() -> Option<TypeName>

source§

impl Wrapper for TapMerklePath

§

type Inner = Confined<Vec<TapBranchHash>, 0, 128>

Inner type wrapped by the current newtype
source§

fn from_inner(inner: <TapMerklePath as Wrapper>::Inner) -> TapMerklePath

Instantiates wrapper type with the inner data
source§

fn as_inner(&self) -> &<TapMerklePath as Wrapper>::Inner

Returns reference to the inner representation for the wrapper type
source§

fn into_inner(self) -> <TapMerklePath as Wrapper>::Inner

Unwraps the wrapper returning the inner type
source§

fn to_inner(&self) -> Self::Inner
where Self::Inner: Clone,

Clones inner data of the wrapped type and return them
source§

impl WrapperMut for TapMerklePath

source§

fn as_inner_mut(&mut self) -> &mut <TapMerklePath as Wrapper>::Inner

Returns a mutable reference to the inner representation for the wrapper type
source§

impl Eq for TapMerklePath

source§

impl StrictProduct for TapMerklePath

source§

impl StructuralPartialEq for TapMerklePath

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
source§

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

source§

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

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where 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

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

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> Same for T

§

type Output = T

Should always be Self
source§

impl<T> StrictDumb for T
where T: StrictType + Default,

source§

impl<T> ToOwned for T
where 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, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

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

source§

fn vzip(self) -> V

source§

impl<T> VerifyEq for T
where T: Eq,

source§

fn verify_eq(&self, other: &T) -> bool

Verifies commit-equivalence of two instances of the same type.
source§

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