pub struct LinkedListMapper<SA, T, A = CurrentStorage>where
SA: StorageMapperApi,
A: StorageAddress<SA>,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone + 'static,{ /* private fields */ }
Implementations§
Source§impl<SA, T, A> LinkedListMapper<SA, T, A>where
SA: StorageMapperApi,
A: StorageAddress<SA>,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone,
impl<SA, T, A> LinkedListMapper<SA, T, A>where
SA: StorageMapperApi,
A: StorageAddress<SA>,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone,
pub fn is_empty(&self) -> bool
pub fn len(&self) -> usize
pub fn front(&self) -> Option<LinkedListNode<T>>
pub fn back(&self) -> Option<LinkedListNode<T>>
pub fn get_node_by_id(&self, node_id: u32) -> Option<LinkedListNode<T>>
pub fn iter(&self) -> Iter<'_, SA, T, A>
pub fn iter_from_node_id(&self, node_id: u32) -> Iter<'_, SA, T, A>
pub fn check_internal_consistency(&self) -> bool
Source§impl<SA, T> LinkedListMapper<SA, T>
impl<SA, T> LinkedListMapper<SA, T>
pub fn pop_back(&mut self) -> Option<LinkedListNode<T>>
pub fn pop_front(&mut self) -> Option<LinkedListNode<T>>
pub fn push_after( &mut self, node: &mut LinkedListNode<T>, element: T, ) -> Option<LinkedListNode<T>>
pub fn push_before( &mut self, node: &mut LinkedListNode<T>, element: T, ) -> Option<LinkedListNode<T>>
pub fn push_after_node_id( &mut self, node_id: u32, element: T, ) -> Option<LinkedListNode<T>>
pub fn push_before_node_id( &mut self, node_id: u32, element: T, ) -> Option<LinkedListNode<T>>
pub fn push_back(&mut self, element: T) -> LinkedListNode<T>
pub fn push_front(&mut self, element: T) -> LinkedListNode<T>
pub fn set_node_value(&mut self, node: LinkedListNode<T>, new_value: T)
pub fn set_node_value_by_id(&mut self, node_id: u32, new_value: T)
pub fn remove_node(&mut self, node: &LinkedListNode<T>)
pub fn remove_node_by_id(&mut self, node_id: u32) -> Option<LinkedListNode<T>>
Trait Implementations§
Source§impl<'a, SA, T, A> IntoIterator for &'a LinkedListMapper<SA, T, A>where
SA: StorageMapperApi,
A: StorageAddress<SA>,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone + 'static,
impl<'a, SA, T, A> IntoIterator for &'a LinkedListMapper<SA, T, A>where
SA: StorageMapperApi,
A: StorageAddress<SA>,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone + 'static,
Source§type Item = LinkedListNode<T>
type Item = LinkedListNode<T>
The type of the elements being iterated over.
Source§fn into_iter(self) -> <&'a LinkedListMapper<SA, T, A> as IntoIterator>::IntoIter
fn into_iter(self) -> <&'a LinkedListMapper<SA, T, A> as IntoIterator>::IntoIter
Creates an iterator from a value. Read more
Source§impl<SA, T> StorageClearable for LinkedListMapper<SA, T>
impl<SA, T> StorageClearable for LinkedListMapper<SA, T>
Source§impl<SA, T> StorageMapper<SA> for LinkedListMapper<SA, T>
impl<SA, T> StorageMapper<SA> for LinkedListMapper<SA, T>
Source§fn new(base_key: StorageKey<SA>) -> LinkedListMapper<SA, T>
fn new(base_key: StorageKey<SA>) -> LinkedListMapper<SA, T>
Will be called automatically by the
#[storage_mapper]
annotation generated code.Source§impl<SA, T> StorageMapperFromAddress<SA> for LinkedListMapper<SA, T, ManagedAddress<SA>>
impl<SA, T> StorageMapperFromAddress<SA> for LinkedListMapper<SA, T, ManagedAddress<SA>>
Source§fn new_from_address(
address: ManagedAddress<SA>,
base_key: StorageKey<SA>,
) -> LinkedListMapper<SA, T, ManagedAddress<SA>>
fn new_from_address( address: ManagedAddress<SA>, base_key: StorageKey<SA>, ) -> LinkedListMapper<SA, T, ManagedAddress<SA>>
Will be called automatically by the
#[storage_mapper_from_address]
annotation generated code.Source§impl<SA, T> TopEncodeMulti for LinkedListMapper<SA, T>
impl<SA, T> TopEncodeMulti for LinkedListMapper<SA, T>
Source§fn multi_encode_or_handle_err<O, H>(
&self,
output: &mut O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: TopEncodeMultiOutput,
H: EncodeErrorHandler,
fn multi_encode_or_handle_err<O, H>(
&self,
output: &mut O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: TopEncodeMultiOutput,
H: EncodeErrorHandler,
Version of
top_encode
that can handle errors as soon as they occur.
For instance in can exit immediately and make sure that if it returns, it is a success.
By not deferring error handling, this can lead to somewhat smaller bytecode.Source§fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>where
O: TopEncodeMultiOutput,
fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>where
O: TopEncodeMultiOutput,
Attempt to serialize the value to ouput.
Source§impl<SA, T> TypeAbi for LinkedListMapper<SA, T>where
SA: StorageMapperApi,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone + TypeAbi,
impl<SA, T> TypeAbi for LinkedListMapper<SA, T>where
SA: StorageMapperApi,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone + TypeAbi,
type Unmanaged = LinkedListMapper<SA, T>
fn type_name() -> String
fn type_name_rust() -> String
Source§fn provide_type_descriptions<TDC>(accumulator: &mut TDC)where
TDC: TypeDescriptionContainer,
fn provide_type_descriptions<TDC>(accumulator: &mut TDC)where
TDC: TypeDescriptionContainer,
A type can provide more than its own name.
For instance, a struct can also provide the descriptions of the type of its fields.
TypeAbi doesn’t care for the exact accumulator type,
which is abstracted by the TypeDescriptionContainer trait.
fn type_names() -> TypeNames
impl<SA, T> TypeAbiFrom<LinkedListMapper<SA, T>> for LinkedListMapper<SA, T>
impl<SA, T, U> TypeAbiFrom<LinkedListMapper<SA, T>> for MultiValueEncoded<SA, U>where
SA: StorageMapperApi,
T: TopEncode + TopDecode + NestedEncode + NestedDecode + Clone,
U: TypeAbiFrom<T>,
Auto Trait Implementations§
impl<SA, T, A> Freeze for LinkedListMapper<SA, T, A>
impl<SA, T, A> RefUnwindSafe for LinkedListMapper<SA, T, A>where
A: RefUnwindSafe,
SA: RefUnwindSafe,
T: RefUnwindSafe,
<SA as HandleTypeInfo>::ManagedBufferHandle: RefUnwindSafe,
impl<SA, T, A> Send for LinkedListMapper<SA, T, A>
impl<SA, T, A> Sync for LinkedListMapper<SA, T, A>
impl<SA, T, A> Unpin for LinkedListMapper<SA, T, A>
impl<SA, T, A> UnwindSafe for LinkedListMapper<SA, T, A>where
A: UnwindSafe,
SA: UnwindSafe,
T: UnwindSafe,
<SA as HandleTypeInfo>::ManagedBufferHandle: UnwindSafe,
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> InterpretableFrom<T> for T
impl<T> InterpretableFrom<T> for T
fn interpret_from(from: T, _context: &InterpreterContext) -> T
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 more