Struct sp_trie::TrieDBRawIterator
source · pub struct TrieDBRawIterator<L>where
L: TrieLayout,{ /* private fields */ }
Expand description
Various re-exports from the trie-db
crate.
Iterator for going through all nodes in the trie in pre-order traversal order.
Implementations§
source§impl<L> TrieDBRawIterator<L>where
L: TrieLayout,
impl<L> TrieDBRawIterator<L>where
L: TrieLayout,
sourcepub fn empty() -> TrieDBRawIterator<L>
pub fn empty() -> TrieDBRawIterator<L>
Create a new empty iterator.
sourcepub fn new(
db: &TrieDB<'_, '_, L>,
) -> Result<TrieDBRawIterator<L>, Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>
pub fn new( db: &TrieDB<'_, '_, L>, ) -> Result<TrieDBRawIterator<L>, Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>
Create a new iterator.
sourcepub fn new_prefixed(
db: &TrieDB<'_, '_, L>,
prefix: &[u8],
) -> Result<TrieDBRawIterator<L>, Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>
pub fn new_prefixed( db: &TrieDB<'_, '_, L>, prefix: &[u8], ) -> Result<TrieDBRawIterator<L>, Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>
Create a new iterator, but limited to a given prefix.
sourcepub fn new_prefixed_then_seek(
db: &TrieDB<'_, '_, L>,
prefix: &[u8],
start_at: &[u8],
) -> Result<TrieDBRawIterator<L>, Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>
pub fn new_prefixed_then_seek( db: &TrieDB<'_, '_, L>, prefix: &[u8], start_at: &[u8], ) -> Result<TrieDBRawIterator<L>, Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>
Create a new iterator, but limited to a given prefix.
It then do a seek operation from prefixed context (using seek
lose
prefix context by default).
sourcepub fn next_item(
&mut self,
db: &TrieDB<'_, '_, L>,
) -> Option<Result<(Vec<u8>, Vec<u8>), Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>>
pub fn next_item( &mut self, db: &TrieDB<'_, '_, L>, ) -> Option<Result<(Vec<u8>, Vec<u8>), Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>>
Fetches the next trie item.
Must be called with the same db
as when the iterator was created.
sourcepub fn prev_item(
&mut self,
db: &TrieDB<'_, '_, L>,
) -> Option<Result<(Vec<u8>, Vec<u8>), Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>>
pub fn prev_item( &mut self, db: &TrieDB<'_, '_, L>, ) -> Option<Result<(Vec<u8>, Vec<u8>), Box<TrieError<<<L as TrieLayout>::Hash as Hasher>::Out, <<L as TrieLayout>::Codec as NodeCodec>::Error>>>>
Fetches the previous trie item.
Must be called with the same db
as when the iterator was created.
Auto Trait Implementations§
impl<L> Freeze for TrieDBRawIterator<L>
impl<L> RefUnwindSafe for TrieDBRawIterator<L>
impl<L> Send for TrieDBRawIterator<L>
impl<L> Sync for TrieDBRawIterator<L>
impl<L> Unpin for TrieDBRawIterator<L>
impl<L> UnwindSafe for TrieDBRawIterator<L>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
source§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to
unchecked_from
.