pub struct WasmPtr<T, M: MemorySize = Memory32> { /* private fields */ }
Expand description
A zero-cost type that represents a pointer to something in Wasm linear memory.
This type can be used directly in the host function arguments:
pub fn host_import(mut env: FunctionEnvMut<()>, memory: Memory, ptr: WasmPtr<u32>) {
let memory = memory.view(&env);
let derefed_ptr = ptr.deref(&memory);
let inner_val: u32 = derefed_ptr.read().expect("pointer in bounds");
println!("Got {} from Wasm memory address 0x{:X}", inner_val, ptr.offset());
// update the value being pointed to
derefed_ptr.write(inner_val + 1).expect("pointer in bounds");
}
This type can also be used with primitive-filled structs, but be careful of
guarantees required by ValueType
.
// This is safe as the 12 bytes represented by this struct
// are valid for all bit combinations.
#[derive(Copy, Clone, Debug, ValueType)]
#[repr(C)]
struct V3 {
x: f32,
y: f32,
z: f32
}
fn update_vector_3(mut env: FunctionEnvMut<()>, memory: Memory, ptr: WasmPtr<V3>) {
let memory = memory.view(&env);
let derefed_ptr = ptr.deref(&memory);
let mut inner_val: V3 = derefed_ptr.read().expect("pointer in bounds");
println!("Got {:?} from Wasm memory address 0x{:X}", inner_val, ptr.offset());
// update the value being pointed to
inner_val.x = 10.4;
derefed_ptr.write(inner_val).expect("pointer in bounds");
}
Implementations§
Source§impl<T, M: MemorySize> WasmPtr<T, M>
impl<T, M: MemorySize> WasmPtr<T, M>
Sourcepub fn add_offset(self, offset: M::Offset) -> Result<Self, MemoryAccessError>
pub fn add_offset(self, offset: M::Offset) -> Result<Self, MemoryAccessError>
Calculates an offset from the current pointer address. The argument is
in units of T
.
This method returns an error if an address overflow occurs.
Sourcepub fn sub_offset(self, offset: M::Offset) -> Result<Self, MemoryAccessError>
pub fn sub_offset(self, offset: M::Offset) -> Result<Self, MemoryAccessError>
Calculates an offset from the current pointer address. The argument is
in units of T
.
This method returns an error if an address underflow occurs.
Source§impl<T: ValueType, M: MemorySize> WasmPtr<T, M>
impl<T: ValueType, M: MemorySize> WasmPtr<T, M>
Sourcepub fn deref<'a>(&self, view: &'a MemoryView<'_>) -> WasmRef<'a, T>
pub fn deref<'a>(&self, view: &'a MemoryView<'_>) -> WasmRef<'a, T>
Creates a WasmRef
from this WasmPtr
which allows reading and
mutating of the value being pointed to.
Sourcepub fn read(&self, view: &MemoryView<'_>) -> Result<T, MemoryAccessError>
pub fn read(&self, view: &MemoryView<'_>) -> Result<T, MemoryAccessError>
Reads the address pointed to by this WasmPtr
in a memory.
Sourcepub fn write(
&self,
view: &MemoryView<'_>,
val: T,
) -> Result<(), MemoryAccessError>
pub fn write( &self, view: &MemoryView<'_>, val: T, ) -> Result<(), MemoryAccessError>
Writes to the address pointed to by this WasmPtr
in a memory.
Sourcepub fn slice<'a>(
&self,
view: &'a MemoryView<'_>,
len: M::Offset,
) -> Result<WasmSlice<'a, T>, MemoryAccessError>
pub fn slice<'a>( &self, view: &'a MemoryView<'_>, len: M::Offset, ) -> Result<WasmSlice<'a, T>, MemoryAccessError>
Creates a WasmSlice
starting at this WasmPtr
which allows reading
and mutating of an array of value being pointed to.
Returns a MemoryAccessError
if the slice length overflows a 64-bit
address.
Sourcepub fn read_until(
&self,
view: &MemoryView<'_>,
end: impl FnMut(&T) -> bool,
) -> Result<Vec<T>, MemoryAccessError>
pub fn read_until( &self, view: &MemoryView<'_>, end: impl FnMut(&T) -> bool, ) -> Result<Vec<T>, MemoryAccessError>
Reads a sequence of values from this WasmPtr
until a value that
matches the given condition is found.
This last value is not included in the returned vector.
Sourcepub fn access<'a>(
&self,
view: &'a MemoryView<'_>,
) -> Result<WasmRefAccess<'a, T>, MemoryAccessError>
pub fn access<'a>( &self, view: &'a MemoryView<'_>, ) -> Result<WasmRefAccess<'a, T>, MemoryAccessError>
Creates a WasmAccess
Source§impl<M: MemorySize> WasmPtr<u8, M>
impl<M: MemorySize> WasmPtr<u8, M>
Sourcepub fn read_utf8_string(
&self,
view: &MemoryView<'_>,
len: M::Offset,
) -> Result<String, MemoryAccessError>
pub fn read_utf8_string( &self, view: &MemoryView<'_>, len: M::Offset, ) -> Result<String, MemoryAccessError>
Reads a UTF-8 string from the WasmPtr
with the given length.
This method is safe to call even if the memory is being concurrently modified.
Sourcepub fn read_utf8_string_with_nul(
&self,
view: &MemoryView<'_>,
) -> Result<String, MemoryAccessError>
pub fn read_utf8_string_with_nul( &self, view: &MemoryView<'_>, ) -> Result<String, MemoryAccessError>
Reads a null-terminated UTF-8 string from the WasmPtr
.
This method is safe to call even if the memory is being concurrently modified.
Trait Implementations§
Source§impl<T: ValueType, M: MemorySize> FromToNativeWasmType for WasmPtr<T, M>
impl<T: ValueType, M: MemorySize> FromToNativeWasmType for WasmPtr<T, M>
Source§type Native = <M as MemorySize>::Native
type Native = <M as MemorySize>::Native
Source§fn from_native(n: Self::Native) -> Self
fn from_native(n: Self::Native) -> Self
Source§fn is_from_store(&self, _store: &impl AsStoreRef) -> bool
fn is_from_store(&self, _store: &impl AsStoreRef) -> bool
Source§impl<T: ValueType, M: MemorySize> ValueType for WasmPtr<T, M>
impl<T: ValueType, M: MemorySize> ValueType for WasmPtr<T, M>
Source§fn zero_padding_bytes(&self, _bytes: &mut [MaybeUninit<u8>])
fn zero_padding_bytes(&self, _bytes: &mut [MaybeUninit<u8>])
self
. It must zero out any bytes which are
uninitialized (e.g. padding bytes).impl<T: ValueType, M: MemorySize> Copy for WasmPtr<T, M>
impl<T: ValueType, M: MemorySize> Eq for WasmPtr<T, M>
Auto Trait Implementations§
impl<T, M> Freeze for WasmPtr<T, M>
impl<T, M> RefUnwindSafe for WasmPtr<T, M>
impl<T, M> Send for WasmPtr<T, M>where
T: Send,
impl<T, M> Sync for WasmPtr<T, M>where
T: Sync,
impl<T, M> Unpin for WasmPtr<T, M>
impl<T, M> UnwindSafe for WasmPtr<T, M>
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§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<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out
indicating that a T
is niched.Source§impl<T> Pointable for T
impl<T> Pointable for T
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)
Source§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
Source§impl<A1> WasmTypeList for A1where
A1: FromToNativeWasmType,
impl<A1> WasmTypeList for A1where
A1: FromToNativeWasmType,
Source§type CStruct = S1<A1>
type CStruct = S1<A1>
Source§unsafe fn from_array(
_store: &mut impl AsStoreMut,
array: <A1 as WasmTypeList>::Array,
) -> A1
unsafe fn from_array( _store: &mut impl AsStoreMut, array: <A1 as WasmTypeList>::Array, ) -> A1
Self
based on an array of values. Read moreSource§unsafe fn from_slice(
store: &mut impl AsStoreMut,
slice: &[RawValue],
) -> Result<A1, TryFromSliceError>
unsafe fn from_slice( store: &mut impl AsStoreMut, slice: &[RawValue], ) -> Result<A1, TryFromSliceError>
Self
based on a slice of values. Read moreSource§unsafe fn into_array(
self,
_store: &mut impl AsStoreMut,
) -> <A1 as WasmTypeList>::Array
unsafe fn into_array( self, _store: &mut impl AsStoreMut, ) -> <A1 as WasmTypeList>::Array
Array
from a tuple
(list) of values. Read moreSource§fn empty_array() -> <A1 as WasmTypeList>::Array
fn empty_array() -> <A1 as WasmTypeList>::Array
Array
that
will hold a tuple (list) of values, usually to hold the
returned values of a WebAssembly function call.Source§unsafe fn from_c_struct(
_store: &mut impl AsStoreMut,
c_struct: <A1 as WasmTypeList>::CStruct,
) -> A1
unsafe fn from_c_struct( _store: &mut impl AsStoreMut, c_struct: <A1 as WasmTypeList>::CStruct, ) -> A1
CStruct
. Read moreSource§unsafe fn into_c_struct(
self,
_store: &mut impl AsStoreMut,
) -> <A1 as WasmTypeList>::CStruct
unsafe fn into_c_struct( self, _store: &mut impl AsStoreMut, ) -> <A1 as WasmTypeList>::CStruct
CStruct
from a
tuple (list) of values. Read moreSource§unsafe fn write_c_struct_to_ptr(
c_struct: <A1 as WasmTypeList>::CStruct,
_ptr: *mut RawValue,
)
unsafe fn write_c_struct_to_ptr( c_struct: <A1 as WasmTypeList>::CStruct, _ptr: *mut RawValue, )
RawValue
. Read more