pub struct ByteSetView<C> { /* private fields */ }Expand description
A View that supports inserting and removing values indexed by a key.
Implementations§
Source§impl<C: Context> ByteSetView<C>
impl<C: Context> 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: Context> ByteSetView<C>
impl<C: Context> 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: Context> ByteSetView<C>
impl<C: Context> 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> Allocative for ByteSetView<C>
impl<C> Allocative for ByteSetView<C>
Source§impl<C: Context> ClonableView for ByteSetView<C>
impl<C: Context> ClonableView 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: Context> HashableView for ByteSetView<C>
impl<C: Context> HashableView for ByteSetView<C>
Source§impl<C: Context, C2: Context> ReplaceContext<C2> for ByteSetView<C>
impl<C: Context, C2: Context> ReplaceContext<C2> for ByteSetView<C>
Source§impl<C: Context> View for ByteSetView<C>
impl<C: Context> View 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 rollback(&mut self)
fn rollback(&mut self)
Discards all pending changes. After that
flush should have no effect to storage.Source§async fn has_pending_changes(&self) -> bool
async fn has_pending_changes(&self) -> bool
Returns
true if flushing this view would result in changes to the persistent storage.Source§fn pre_save(&self, batch: &mut Batch) -> Result<bool, ViewError>
fn pre_save(&self, batch: &mut Batch) -> Result<bool, ViewError>
Computes the batch of operations to persist changes to storage without modifying the view.
Crash-resistant storage implementations accumulate the desired changes in the
batch variable.
The returned boolean indicates whether the operation removes the view or not.Source§fn post_save(&mut self)
fn post_save(&mut self)
Updates the view state after the batch has been executed in the database.
This should be called after
pre_save and after the batch has been successfully written to storage.
This leaves the view in a clean state with no pending changes. Read moreSource§fn clear(&mut self)
fn clear(&mut self)
Clears the view. That can be seen as resetting to default. If the clear is followed
by a flush then all the relevant data is removed on the storage.
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
Source§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
Source§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