pub struct ReentrantByteCollectionView<C, W> { /* private fields */ }
Expand description
A view that supports accessing a collection of views of the same kind, indexed by Vec<u8>
,
possibly several subviews at a time.
Implementations§
source§impl<C, W> ReentrantByteCollectionView<C, W>
impl<C, W> ReentrantByteCollectionView<C, W>
sourcepub async fn try_load_entry_mut(
&mut self,
short_key: &[u8],
) -> Result<WriteGuardedView<W>, ViewError>
pub async fn try_load_entry_mut( &mut self, short_key: &[u8], ) -> Result<WriteGuardedView<W>, ViewError>
Loads a subview for the data at the given index in the collection. If an entry is absent then a default entry is added to the collection. The resulting view can be modified.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
let subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
let value = subview.get();
assert_eq!(*value, String::default());
sourcepub async fn try_load_entry(
&self,
short_key: &[u8],
) -> Result<Option<ReadGuardedView<W>>, ViewError>
pub async fn try_load_entry( &self, short_key: &[u8], ) -> Result<Option<ReadGuardedView<W>>, ViewError>
Loads a subview at the given index in the collection and gives read-only access to the data.
If an entry is absent then None
is returned.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
{
let _subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
}
let subview = view.try_load_entry(&[0, 1]).await.unwrap().unwrap();
let value = subview.get();
assert_eq!(*value, String::default());
sourcepub async fn contains_key(&self, short_key: &[u8]) -> Result<bool, ViewError>
pub async fn contains_key(&self, short_key: &[u8]) -> Result<bool, ViewError>
Returns true
if the collection contains a value for the specified key.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
let _subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
assert!(view.contains_key(&[0, 1]).await.unwrap());
assert!(!view.contains_key(&[0, 2]).await.unwrap());
sourcepub fn remove_entry(&mut self, short_key: Vec<u8>)
pub fn remove_entry(&mut self, short_key: Vec<u8>)
Removes an entry. If absent then nothing happens.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
let mut subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
let value = subview.get_mut();
assert_eq!(*value, String::default());
view.remove_entry(vec![0, 1]);
let keys = view.keys().await.unwrap();
assert_eq!(keys.len(), 0);
sourcepub fn try_reset_entry_to_default(
&mut self,
short_key: &[u8],
) -> Result<(), ViewError>
pub fn try_reset_entry_to_default( &mut self, short_key: &[u8], ) -> Result<(), ViewError>
Marks the entry so that it is removed in the next flush.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
{
let mut subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
let value = subview.get_mut();
*value = String::from("Hello");
}
view.try_reset_entry_to_default(&[0, 1]).unwrap();
let mut subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
let value = subview.get_mut();
assert_eq!(*value, String::default());
source§impl<C, W> ReentrantByteCollectionView<C, W>
impl<C, W> ReentrantByteCollectionView<C, W>
sourcepub async fn try_load_entries_mut(
&mut self,
short_keys: Vec<Vec<u8>>,
) -> Result<Vec<WriteGuardedView<W>>, ViewError>
pub async fn try_load_entries_mut( &mut self, short_keys: Vec<Vec<u8>>, ) -> Result<Vec<WriteGuardedView<W>>, ViewError>
Loads multiple entries for writing at once.
The entries in short_keys
have to be all distinct.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
{
let mut subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
*subview.get_mut() = "Bonjour".to_string();
}
let short_keys = vec![vec![0, 1], vec![2, 3]];
let subviews = view.try_load_entries_mut(short_keys).await.unwrap();
let value1 = subviews[0].get();
let value2 = subviews[1].get();
assert_eq!(*value1, "Bonjour".to_string());
assert_eq!(*value2, String::default());
sourcepub async fn try_load_entries(
&self,
short_keys: Vec<Vec<u8>>,
) -> Result<Vec<Option<ReadGuardedView<W>>>, ViewError>
pub async fn try_load_entries( &self, short_keys: Vec<Vec<u8>>, ) -> Result<Vec<Option<ReadGuardedView<W>>>, ViewError>
Loads multiple entries for reading at once.
The entries in short_keys
have to be all distinct.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
{
let _subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
}
let short_keys = vec![vec![0, 1], vec![2, 3]];
let subviews = view.try_load_entries(short_keys).await.unwrap();
assert!(subviews[1].is_none());
let value0 = subviews[0].as_ref().unwrap().get();
assert_eq!(*value0, String::default());
sourcepub async fn try_load_all_entries(
&self,
) -> Result<Vec<(Vec<u8>, ReadGuardedView<W>)>, ViewError>
pub async fn try_load_all_entries( &self, ) -> Result<Vec<(Vec<u8>, ReadGuardedView<W>)>, ViewError>
Loads all the entries for reading at once.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
{
let _subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
}
let subviews = view.try_load_all_entries().await.unwrap();
assert_eq!(subviews.len(), 1);
sourcepub async fn try_load_all_entries_mut(
&mut self,
) -> Result<Vec<(Vec<u8>, WriteGuardedView<W>)>, ViewError>
pub async fn try_load_all_entries_mut( &mut self, ) -> Result<Vec<(Vec<u8>, WriteGuardedView<W>)>, ViewError>
Loads all the entries for writing at once.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
{
let _subview = view.try_load_entry_mut(&[0, 1]).await.unwrap();
}
let subviews = view.try_load_all_entries_mut().await.unwrap();
assert_eq!(subviews.len(), 1);
source§impl<C, W> ReentrantByteCollectionView<C, W>
impl<C, W> ReentrantByteCollectionView<C, W>
sourcepub async fn keys(&self) -> Result<Vec<Vec<u8>>, ViewError>
pub async fn keys(&self) -> Result<Vec<Vec<u8>>, ViewError>
Returns the list of indices in the collection in lexicographic order.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
view.try_load_entry_mut(&[0, 1]).await.unwrap();
view.try_load_entry_mut(&[0, 2]).await.unwrap();
let keys = view.keys().await.unwrap();
assert_eq!(keys, 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 indices of the collection.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
view.try_load_entry_mut(&[0, 1]).await.unwrap();
view.try_load_entry_mut(&[0, 2]).await.unwrap();
assert_eq!(view.count().await.unwrap(), 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 view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
view.try_load_entry_mut(&[0, 1]).await.unwrap();
view.try_load_entry_mut(&[0, 2]).await.unwrap();
let mut count = 0;
view.for_each_key_while(|_key| {
count += 1;
Ok(count < 1)
})
.await
.unwrap();
assert_eq!(count, 1);
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 index (aka key). Keys are visited in a lexicographic order.
let mut view: ReentrantByteCollectionView<_, RegisterView<_, String>> =
ReentrantByteCollectionView::load(context).await.unwrap();
view.try_load_entry_mut(&[0, 1]).await.unwrap();
view.try_load_entry_mut(&[0, 2]).await.unwrap();
let mut count = 0;
view.for_each_key(|_key| {
count += 1;
Ok(())
})
.await
.unwrap();
assert_eq!(count, 2);
Trait Implementations§
source§impl<C, W> ClonableView<C> for ReentrantByteCollectionView<C, W>
impl<C, W> ClonableView<C> for ReentrantByteCollectionView<C, W>
source§fn clone_unchecked(&mut self) -> Result<Self, ViewError>
fn clone_unchecked(&mut self) -> Result<Self, ViewError>
source§impl<C, W> HashableView<C> for ReentrantByteCollectionView<C, W>
impl<C, W> HashableView<C> for ReentrantByteCollectionView<C, W>
§type Hasher = CoreWrapper<Sha3_256Core>
type Hasher = CoreWrapper<Sha3_256Core>
source§impl<C, W> View<C> for ReentrantByteCollectionView<C, W>
impl<C, W> View<C> for ReentrantByteCollectionView<C, W>
source§const NUM_INIT_KEYS: usize = 0usize
const NUM_INIT_KEYS: usize = 0usize
source§fn pre_load(_context: &C) -> Result<Vec<Vec<u8>>, ViewError>
fn pre_load(_context: &C) -> Result<Vec<Vec<u8>>, ViewError>
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>
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,
source§fn rollback(&mut self)
fn rollback(&mut self)
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,
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>
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, W> !Freeze for ReentrantByteCollectionView<C, W>
impl<C, W> !RefUnwindSafe for ReentrantByteCollectionView<C, W>
impl<C, W> Send for ReentrantByteCollectionView<C, W>
impl<C, W> Sync for ReentrantByteCollectionView<C, W>
impl<C, W> Unpin for ReentrantByteCollectionView<C, W>where
C: Unpin,
impl<C, W> !UnwindSafe for ReentrantByteCollectionView<C, W>
Blanket Implementations§
source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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
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>
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>
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> 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>
source§impl<T> MockResults for T
impl<T> MockResults for T
§type Results = T
type Results = T
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
.