Struct wasmtime_wasi::preview2::Table
source · pub struct Table { /* private fields */ }
Expand description
The Table
type is designed to map u32 handles to resources. The table is now part of the
public interface to a WasiCtx
- it is reference counted so that it can be shared beyond a
WasiCtx
with other WASI proposals (e.g. wasi-crypto
and wasi-nn
) to manage their
resources. Elements in the Table
are Any
typed.
The Table
type is intended to model how the Interface Types concept of Resources is shaping
up. Right now it is just an approximation.
Implementations§
source§impl Table
impl Table
sourcepub fn push(
&mut self,
entry: Box<dyn Any + Send + Sync>
) -> Result<u32, TableError>
pub fn push( &mut self, entry: Box<dyn Any + Send + Sync> ) -> Result<u32, TableError>
Insert a resource at the next available index.
sourcepub fn push_child(
&mut self,
entry: Box<dyn Any + Send + Sync>,
parent: u32
) -> Result<u32, TableError>
pub fn push_child( &mut self, entry: Box<dyn Any + Send + Sync>, parent: u32 ) -> Result<u32, TableError>
Insert a resource at the next available index, and track that it has a parent resource.
The parent must exist to create a child. All children resources must
be destroyed before a parent can be destroyed - otherwise Table::delete
or OccupiedEntry::remove_entry
will fail with
TableError::HasChildren
.
Parent-child relationships are tracked inside the table to ensure that
a parent resource is not deleted while it has live children. This
allows child resources to hold “references” to a parent by table
index, to avoid needing e.g. an Arc<Mutex<parent>>
and the associated
locking overhead and design issues, such as child existence extending
lifetime of parent referent even after parent resource is destroyed,
possibility for deadlocks.
Parent-child relationships may not be modified once created. There
is no way to observe these relationships through the Table
methods
except for erroring on deletion, or the std::fmt::Debug
impl.
sourcepub fn contains_key(&self, key: u32) -> bool
pub fn contains_key(&self, key: u32) -> bool
Check if the table has a resource at the given index.
sourcepub fn is<T: Any + Sized>(&self, key: u32) -> bool
pub fn is<T: Any + Sized>(&self, key: u32) -> bool
Check if the resource at a given index can be downcast to a given type. Note: this will always fail if the resource is already borrowed.
sourcepub fn get<T: Any + Sized>(&self, key: u32) -> Result<&T, TableError>
pub fn get<T: Any + Sized>(&self, key: u32) -> Result<&T, TableError>
Get an immutable reference to a resource of a given type at a given index. Multiple immutable references can be borrowed at any given time. Borrow failure results in a trapping error.
sourcepub fn get_mut<T: Any + Sized>(
&mut self,
key: u32
) -> Result<&mut T, TableError>
pub fn get_mut<T: Any + Sized>( &mut self, key: u32 ) -> Result<&mut T, TableError>
Get a mutable reference to a resource of a given type at a given index. Only one mutable reference can be borrowed at any given time. Borrow failure results in a trapping error.
sourcepub fn entry(&mut self, index: u32) -> Result<OccupiedEntry<'_>, TableError>
pub fn entry(&mut self, index: u32) -> Result<OccupiedEntry<'_>, TableError>
Get an OccupiedEntry
corresponding to a table entry, if it exists. This allows you to
remove or replace the entry based on its contents. The methods available are a subset of
std::collections::hash_map::OccupiedEntry
- it does not give access to the key, it
restricts replacing the entry to items of the same type, and it does not allow for deletion.
sourcepub fn delete<T: Any + Sized>(&mut self, key: u32) -> Result<T, TableError>
pub fn delete<T: Any + Sized>(&mut self, key: u32) -> Result<T, TableError>
Remove a resource at a given index from the table.
If this method fails, the resource remains in the table.
May fail with TableError::HasChildren
if the resource has any live
children.
sourcepub fn iter_entries<'a, T>(
&'a mut self,
map: HashMap<u32, T>
) -> impl Iterator<Item = (Result<&'a mut dyn Any, TableError>, T)>
pub fn iter_entries<'a, T>( &'a mut self, map: HashMap<u32, T> ) -> impl Iterator<Item = (Result<&'a mut dyn Any, TableError>, T)>
Trait Implementations§
source§impl TablePollableExt for Table
impl TablePollableExt for Table
fn push_host_pollable(&mut self, p: HostPollable) -> Result<u32, TableError>
fn get_host_pollable_mut( &mut self, fd: u32 ) -> Result<&mut HostPollable, TableError>
fn delete_host_pollable(&mut self, fd: u32) -> Result<HostPollable, TableError>
source§impl TableStreamExt for Table
impl TableStreamExt for Table
source§fn push_input_stream(
&mut self,
istream: Box<dyn HostInputStream>
) -> Result<u32, TableError>
fn push_input_stream( &mut self, istream: Box<dyn HostInputStream> ) -> Result<u32, TableError>
HostInputStream
into a Table
, returning the table index.source§fn get_input_stream_mut(
&mut self,
fd: u32
) -> Result<&mut dyn HostInputStream, TableError>
fn get_input_stream_mut( &mut self, fd: u32 ) -> Result<&mut dyn HostInputStream, TableError>
HostInputStream
in a Table
.source§fn delete_input_stream(
&mut self,
fd: u32
) -> Result<Box<dyn HostInputStream>, TableError>
fn delete_input_stream( &mut self, fd: u32 ) -> Result<Box<dyn HostInputStream>, TableError>
HostInputStream
from table:source§fn push_output_stream(
&mut self,
ostream: Box<dyn HostOutputStream>
) -> Result<u32, TableError>
fn push_output_stream( &mut self, ostream: Box<dyn HostOutputStream> ) -> Result<u32, TableError>
HostOutputStream
into a Table
, returning the table index.source§fn get_output_stream_mut(
&mut self,
fd: u32
) -> Result<&mut dyn HostOutputStream, TableError>
fn get_output_stream_mut( &mut self, fd: u32 ) -> Result<&mut dyn HostOutputStream, TableError>
HostOutputStream
in a Table
.source§fn delete_output_stream(
&mut self,
fd: u32
) -> Result<Box<dyn HostOutputStream>, TableError>
fn delete_output_stream( &mut self, fd: u32 ) -> Result<Box<dyn HostOutputStream>, TableError>
HostOutputStream
from table:Auto Trait Implementations§
impl !RefUnwindSafe for Table
impl Send for Table
impl Sync for Table
impl Unpin for Table
impl !UnwindSafe for Table
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
source§impl<T> GetSetFdFlags for T
impl<T> GetSetFdFlags for T
source§fn get_fd_flags(&self) -> Result<FdFlags, Error>where
T: AsFilelike,
fn get_fd_flags(&self) -> Result<FdFlags, Error>where T: AsFilelike,
self
file descriptor.source§fn new_set_fd_flags(&self, fd_flags: FdFlags) -> Result<SetFdFlags<T>, Error>where
T: AsFilelike,
fn new_set_fd_flags(&self, fd_flags: FdFlags) -> Result<SetFdFlags<T>, Error>where T: AsFilelike,
source§fn set_fd_flags(&mut self, set_fd_flags: SetFdFlags<T>) -> Result<(), Error>where
T: AsFilelike,
fn set_fd_flags(&mut self, set_fd_flags: SetFdFlags<T>) -> Result<(), Error>where T: AsFilelike,
self
file descriptor. Read more