pub struct StorageString(pub StorageBytes);
Expand description
Accessor for storage-backed bytes
Tuple Fields§
§0: StorageBytes
Implementations§
Source§impl StorageString
impl StorageString
Sourcepub fn get_string(&self) -> String
pub fn get_string(&self) -> String
Gets the underlying String
, ignoring any invalid data.
Trait Implementations§
Source§impl Erase for StorageString
impl Erase for StorageString
Source§impl Extend<char> for StorageString
impl Extend<char> for StorageString
Source§fn extend<T: IntoIterator<Item = char>>(&mut self, iter: T)
fn extend<T: IntoIterator<Item = char>>(&mut self, iter: T)
Extends a collection with the contents of an iterator. Read more
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
🔬This is a nightly-only experimental API. (
extend_one
)Extends a collection with exactly one element.
Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
🔬This is a nightly-only experimental API. (
extend_one
)Reserves capacity in a collection for the given number of additional elements. Read more
Source§impl<T> From<&T> for StorageString
impl<T> From<&T> for StorageString
Source§impl HostAccess for StorageString
impl HostAccess for StorageString
Source§impl StorageType for StorageString
impl StorageType for StorageString
Source§type Wraps<'a> = StorageGuard<'a, StorageString>
where
Self: 'a
type Wraps<'a> = StorageGuard<'a, StorageString> where Self: 'a
For primitive types, this is the type being stored.
For collections, this is the
StorageType
being collected.Source§type WrapsMut<'a> = StorageGuardMut<'a, StorageString>
where
Self: 'a
type WrapsMut<'a> = StorageGuardMut<'a, StorageString> where Self: 'a
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 SLOT_BYTES: usize = 32usize
const SLOT_BYTES: usize = 32usize
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§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 StorageString
impl !RefUnwindSafe for StorageString
impl !Send for StorageString
impl !Sync for StorageString
impl Unpin for StorageString
impl !UnwindSafe for StorageString
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