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: 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 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.Source§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> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::RequestCreates 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<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
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