Struct wasmtime_runtime::VMExternRef
source · pub struct VMExternRef(/* private fields */);
Expand description
An external reference to some opaque data.
VMExternRef
s dereference to their underlying opaque data as dyn Any
.
Unlike the externref
in the Wasm spec, VMExternRef
s are non-nullable,
and always point to a valid value. You may use Option<VMExternRef>
to
represent nullable references, and Option<VMExternRef>
is guaranteed to
have the same size and alignment as a raw pointer, with None
represented
with the null pointer.
VMExternRef
s are reference counted, so cloning is a cheap, shallow
operation. It also means they are inherently shared, so you may not get a
mutable, exclusive reference to their inner contents, only a shared,
immutable reference. You may use interior mutability with RefCell
or
Mutex
to work around this restriction, if necessary.
VMExternRef
s have pointer-equality semantics, not structural-equality
semantics. Given two VMExternRef
s a
and b
, a == b
only if a
and
b
point to the same allocation. a
and b
are considered not equal, even
if a
and b
are two different identical copies of the same data, if they
are in two different allocations. The hashing and ordering implementations
also only operate on the pointer.
§Example
use std::cell::RefCell;
use wasmtime_runtime::VMExternRef;
// Open a file. Wasm doesn't know about files, but we can let Wasm instances
// work with files via opaque `externref` handles.
let file = std::fs::File::create("some/file/path")?;
// Wrap the file up as an `VMExternRef` that can be passed to Wasm.
let extern_ref_to_file = VMExternRef::new(file);
// `VMExternRef`s dereference to `dyn Any`, so you can use `Any` methods to
// perform runtime type checks and downcasts.
assert!(extern_ref_to_file.is::<std::fs::File>());
assert!(!extern_ref_to_file.is::<String>());
if let Some(mut file) = extern_ref_to_file.downcast_ref::<std::fs::File>() {
use std::io::Write;
writeln!(&mut file, "Hello, `VMExternRef`!")?;
}
Implementations§
source§impl VMExternRef
impl VMExternRef
sourcepub fn new<T>(value: T) -> VMExternRef
pub fn new<T>(value: T) -> VMExternRef
Wrap the given value inside an VMExternRef
.
sourcepub fn new_with<T>(make_value: impl FnOnce() -> T) -> VMExternRef
pub fn new_with<T>(make_value: impl FnOnce() -> T) -> VMExternRef
Construct a new VMExternRef
in place by invoking make_value
.
sourcepub fn as_raw(&self) -> *mut u8
pub fn as_raw(&self) -> *mut u8
Turn this VMExternRef
into a raw, untyped pointer.
Unlike into_raw
, this does not consume and forget self
. It is not
safe to use from_raw
on pointers returned from this method; only use
clone_from_raw
!
Nor does this method increment the reference count. You must ensure
that self
(or some other clone of self
) stays alive until
clone_from_raw
is called.
sourcepub unsafe fn into_raw(self) -> *mut u8
pub unsafe fn into_raw(self) -> *mut u8
Consume this VMExternRef
into a raw, untyped pointer.
§Safety
This method forgets self, so it is possible to create a leak of the underlying reference counted data if not used carefully.
Use from_raw
to recreate the VMExternRef
.
sourcepub unsafe fn from_raw(ptr: *mut u8) -> Self
pub unsafe fn from_raw(ptr: *mut u8) -> Self
Recreate a VMExternRef
from a pointer returned from a previous call to
as_raw
.
§Safety
Unlike clone_from_raw
, this does not increment the reference count of the
underlying data. It is not safe to continue to use the pointer passed to this
function.
sourcepub unsafe fn clone_from_raw(ptr: *mut u8) -> Self
pub unsafe fn clone_from_raw(ptr: *mut u8) -> Self
Recreate a VMExternRef
from a pointer returned from a previous call to
as_raw
.
§Safety
Wildly unsafe to use with anything other than the result of a previous
as_raw
call!
Additionally, it is your responsibility to ensure that this raw
VMExternRef
’s reference count has not dropped to zero. Failure to do
so will result in use after free!
sourcepub fn strong_count(&self) -> usize
pub fn strong_count(&self) -> usize
Get the strong reference count for this VMExternRef
.
Note that this loads with a SeqCst
ordering to synchronize with other
threads.
source§impl VMExternRef
impl VMExternRef
Methods that would normally be trait implementations, but aren’t to avoid
potential footguns around VMExternRef
’s pointer-equality semantics.
Note that none of these methods are on &self
, they all require a
fully-qualified VMExternRef::foo(my_ref)
invocation.
sourcepub fn eq(a: &Self, b: &Self) -> bool
pub fn eq(a: &Self, b: &Self) -> bool
Check whether two VMExternRef
s point to the same inner allocation.
Note that this uses pointer-equality semantics, not structural-equality
semantics, and so only pointers are compared, and doesn’t use any Eq
or PartialEq
implementation of the pointed-to values.
Trait Implementations§
source§impl Clone for VMExternRef
impl Clone for VMExternRef
source§fn clone(&self) -> VMExternRef
fn clone(&self) -> VMExternRef
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for VMExternRef
impl Debug for VMExternRef
source§impl Deref for VMExternRef
impl Deref for VMExternRef
source§impl Drop for VMExternRef
impl Drop for VMExternRef
source§impl From<VMExternRef> for TableElement
impl From<VMExternRef> for TableElement
source§fn from(x: VMExternRef) -> TableElement
fn from(x: VMExternRef) -> TableElement
source§impl Pointer for VMExternRef
impl Pointer for VMExternRef
impl Send for VMExternRef
impl Sync for VMExternRef
Auto Trait Implementations§
impl Freeze for VMExternRef
impl !RefUnwindSafe for VMExternRef
impl Unpin for VMExternRef
impl !UnwindSafe for VMExternRef
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)