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, CurrentStorage>
impl<SA, T> LinkedListMapper<SA, T, CurrentStorage>
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§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, CurrentStorage>
impl<SA, T> StorageMapper<SA> for LinkedListMapper<SA, T, CurrentStorage>
Source§fn new(base_key: StorageKey<SA>) -> Self
fn new(base_key: StorageKey<SA>) -> Self
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>,
) -> Self
fn new_from_address( address: ManagedAddress<SA>, base_key: StorageKey<SA>, ) -> Self
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::HandledErr>where
O: TopEncodeMultiOutput,
H: EncodeErrorHandler,
fn multi_encode_or_handle_err<O, H>(
&self,
output: &mut O,
h: H,
) -> Result<(), H::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() -> TypeName
fn type_name_rust() -> TypeName
Source§fn provide_type_descriptions<TDC: TypeDescriptionContainer>(
accumulator: &mut TDC,
)
fn provide_type_descriptions<TDC: TypeDescriptionContainer>( accumulator: &mut TDC, )
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