Struct linera_views::views::set_view::ByteSetView
source · pub struct ByteSetView<C> { /* private fields */ }
Expand description
A View
that supports inserting and removing values indexed by a key.
Implementations§
source§impl<C> ByteSetView<C>
impl<C> ByteSetView<C>
sourcepub fn insert(&mut self, short_key: Vec<u8>)
pub fn insert(&mut self, short_key: Vec<u8>)
Insert a value. If already present then it has no effect.
let mut set = ByteSetView::load(context).await.unwrap();
set.insert(vec![0, 1]);
assert_eq!(set.contains(&[0, 1]).await.unwrap(), true);
source§impl<C> ByteSetView<C>
impl<C> ByteSetView<C>
sourcepub async fn contains(&self, short_key: &[u8]) -> Result<bool, ViewError>
pub async fn contains(&self, short_key: &[u8]) -> Result<bool, ViewError>
Returns true if the given index exists in the set.
let mut set = ByteSetView::load(context).await.unwrap();
set.insert(vec![0, 1]);
assert_eq!(set.contains(&[34]).await.unwrap(), false);
assert_eq!(set.contains(&[0, 1]).await.unwrap(), true);
source§impl<C> ByteSetView<C>
impl<C> ByteSetView<C>
sourcepub async fn keys(&self) -> Result<Vec<Vec<u8>>, ViewError>
pub async fn keys(&self) -> Result<Vec<Vec<u8>>, ViewError>
Returns the list of keys in the set. The order is lexicographic.
let mut set = ByteSetView::load(context).await.unwrap();
set.insert(vec![0, 1]);
set.insert(vec![0, 2]);
assert_eq!(set.keys().await.unwrap(), vec![vec![0, 1], vec![0, 2]]);
sourcepub async fn count(&self) -> Result<usize, ViewError>
pub async fn count(&self) -> Result<usize, ViewError>
Returns the number of entries in the set.
let mut set = ByteSetView::load(context).await.unwrap();
set.insert(vec![0, 1]);
set.insert(vec![0, 2]);
assert_eq!(set.keys().await.unwrap(), vec![vec![0, 1], vec![0, 2]]);
sourcepub async fn for_each_key_while<F>(&self, f: F) -> Result<(), ViewError>
pub async fn for_each_key_while<F>(&self, f: F) -> Result<(), ViewError>
Applies a function f on each index (aka key). Keys are visited in a lexicographic order. If the function returns false, then the loop ends prematurely.
let mut set = ByteSetView::load(context).await.unwrap();
set.insert(vec![0, 1]);
set.insert(vec![0, 2]);
set.insert(vec![3]);
let mut count = 0;
set.for_each_key_while(|_key| {
count += 1;
Ok(count < 2)
})
.await
.unwrap();
assert_eq!(count, 2);
sourcepub async fn for_each_key<F>(&self, f: F) -> Result<(), ViewError>
pub async fn for_each_key<F>(&self, f: F) -> Result<(), ViewError>
Applies a function f on each serialized index (aka key). Keys are visited in a lexicographic order.
let mut set = ByteSetView::load(context).await.unwrap();
set.insert(vec![0, 1]);
set.insert(vec![0, 2]);
set.insert(vec![3]);
let mut count = 0;
set.for_each_key(|_key| {
count += 1;
Ok(())
})
.await
.unwrap();
assert_eq!(count, 3);
Trait Implementations§
source§impl<C> ClonableView<C> for ByteSetView<C>
impl<C> ClonableView<C> for ByteSetView<C>
source§fn clone_unchecked(&mut self) -> Result<Self, ViewError>
fn clone_unchecked(&mut self) -> Result<Self, ViewError>
Creates a clone of this view, sharing the underlying storage context but prone to
data races which can corrupt the view state.
source§impl<C: Debug> Debug for ByteSetView<C>
impl<C: Debug> Debug for ByteSetView<C>
source§impl<C> HashableView<C> for ByteSetView<C>
impl<C> HashableView<C> for ByteSetView<C>
§type Hasher = CoreWrapper<Sha3_256Core>
type Hasher = CoreWrapper<Sha3_256Core>
How to compute hashes.
source§impl<C> View<C> for ByteSetView<C>
impl<C> View<C> for ByteSetView<C>
source§const NUM_INIT_KEYS: usize = 0usize
const NUM_INIT_KEYS: usize = 0usize
The number of keys used for the initialization
source§fn pre_load(_context: &C) -> Result<Vec<Vec<u8>>, ViewError>
fn pre_load(_context: &C) -> Result<Vec<Vec<u8>>, ViewError>
Creates the keys needed for loading the view
source§fn post_load(context: C, _values: &[Option<Vec<u8>>]) -> Result<Self, ViewError>
fn post_load(context: C, _values: &[Option<Vec<u8>>]) -> Result<Self, ViewError>
Loads a view from the values
source§fn load<'async_trait>(
context: C,
) -> Pin<Box<dyn Future<Output = Result<Self, ViewError>> + Send + 'async_trait>>where
Self: 'async_trait,
fn load<'async_trait>(
context: C,
) -> Pin<Box<dyn Future<Output = Result<Self, ViewError>> + Send + 'async_trait>>where
Self: 'async_trait,
Loads a view
source§fn rollback(&mut self)
fn rollback(&mut self)
Discards all pending changes. After that
flush
should have no effect to storage.source§fn has_pending_changes<'life0, 'async_trait>(
&'life0 self,
) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn has_pending_changes<'life0, 'async_trait>(
&'life0 self,
) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Returns
true
if flushing this view would result in changes to the persistent storage.source§fn flush(&mut self, batch: &mut Batch) -> Result<bool, ViewError>
fn flush(&mut self, batch: &mut Batch) -> Result<bool, ViewError>
Persists changes to storage. This leaves the view still usable and is essentially neutral to the
program running. Crash-resistant storage implementations are expected to accumulate the desired
changes in the
batch
variable first. If the view is dropped without calling flush
, staged
changes are simply lost.
The returned boolean indicates whether the operation removes the view or not.Auto Trait Implementations§
impl<C> Freeze for ByteSetView<C>where
C: Freeze,
impl<C> RefUnwindSafe for ByteSetView<C>where
C: RefUnwindSafe,
impl<C> Send for ByteSetView<C>where
C: Send,
impl<C> Sync for ByteSetView<C>where
C: Sync,
impl<C> Unpin for ByteSetView<C>where
C: Unpin,
impl<C> UnwindSafe for ByteSetView<C>where
C: UnwindSafe,
Blanket Implementations§
source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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<Choices> CoproductSubsetter<CNil, HNil> for Choices
impl<Choices> CoproductSubsetter<CNil, HNil> for Choices
source§impl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
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 moreCreates a shared type from an unshared type.
source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Gets the layout of the type.
source§impl<T> MockResults for T
impl<T> MockResults for T
§type Results = T
type Results = T
The mock native type of the results for the
MockInstance
.source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<M, I> RuntimeMemory<&mut I> for Mwhere
M: RuntimeMemory<I>,
impl<M, I> RuntimeMemory<&mut I> for Mwhere
M: RuntimeMemory<I>,
source§fn read<'instance>(
&self,
instance: &'instance &mut I,
location: GuestPointer,
length: u32,
) -> Result<Cow<'instance, [u8]>, RuntimeError>
fn read<'instance>( &self, instance: &'instance &mut I, location: GuestPointer, length: u32, ) -> Result<Cow<'instance, [u8]>, RuntimeError>
Reads length
bytes from memory from the provided location
.
source§fn write(
&mut self,
instance: &mut &mut I,
location: GuestPointer,
bytes: &[u8],
) -> Result<(), RuntimeError>
fn write( &mut self, instance: &mut &mut I, location: GuestPointer, bytes: &[u8], ) -> Result<(), RuntimeError>
Writes the bytes
to memory at the provided location
.
source§impl<T> Upcastable for T
impl<T> Upcastable for T
source§fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
upcast ref
source§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
upcast mut ref