pub struct StorageAddress { /* private fields */ }
Expand description
Accessor for a storage-backed Address
.
Implementations§
Trait Implementations§
Source§impl Debug for StorageAddress
impl Debug for StorageAddress
Source§impl Erase for StorageAddress
impl Erase for StorageAddress
Source§impl<T> From<&T> for StorageAddress
impl<T> From<&T> for StorageAddress
Source§impl From<StorageAddress> for Address
impl From<StorageAddress> for Address
Source§fn from(value: StorageAddress) -> Self
fn from(value: StorageAddress) -> Self
Converts to this type from the input type.
Source§impl HostAccess for StorageAddress
impl HostAccess for StorageAddress
Source§impl<'a> SimpleStorageType<'a> for StorageAddress
impl<'a> SimpleStorageType<'a> for StorageAddress
Source§fn set_by_wrapped(&mut self, value: Self::Wraps<'a>)
fn set_by_wrapped(&mut self, value: Self::Wraps<'a>)
Write the value to persistent storage.
Source§impl StorageType for StorageAddress
impl StorageType for StorageAddress
Source§const SLOT_BYTES: usize = 20usize
const SLOT_BYTES: usize = 20usize
The number of bytes in a slot needed to represent the type. Must not exceed 32.
For types larger than 32 bytes that are stored inline with a struct’s fields,
set this to 32 and return the full size in
StorageType::new
. Read moreSource§type Wraps<'a> = Address
type Wraps<'a> = Address
For primitive types, this is the type being stored.
For collections, this is the
StorageType
being collected.Source§type WrapsMut<'a> = StorageGuardMut<'a, StorageAddress>
type WrapsMut<'a> = StorageGuardMut<'a, StorageAddress>
Mutable accessor to the type being stored.
Source§unsafe fn new(slot: U256, offset: u8, host: VM) -> Self
unsafe fn new(slot: U256, offset: u8, host: VM) -> Self
Where in persistent storage the type should live. Although useful for framework designers
creating new storage types, most user programs shouldn’t call this.
Note: implementations will have to be
const
once generic_const_exprs
stabilizes. Read moreSource§fn load<'s>(self) -> Self::Wraps<'s>
fn load<'s>(self) -> Self::Wraps<'s>
Load the wrapped type, consuming the accessor.
Note: most types have a
get
and/or getter
, which don’t consume Self
.Source§fn load_mut<'s>(self) -> Self::WrapsMut<'s>
fn load_mut<'s>(self) -> Self::WrapsMut<'s>
Load the wrapped mutable type, consuming the accessor.
Note: most types have a
set
and/or setter
, which don’t consume Self
.Source§const REQUIRED_SLOTS: usize = 0usize
const REQUIRED_SLOTS: usize = 0usize
The number of words this type must fill. For primitives this is always 0.
For complex types requiring more than one inline word, set this to the total size.
Auto Trait Implementations§
impl Freeze for StorageAddress
impl !RefUnwindSafe for StorageAddress
impl !Send for StorageAddress
impl !Sync for StorageAddress
impl Unpin for StorageAddress
impl !UnwindSafe for StorageAddress
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 more