[−][src]Struct wasmer_runtime_core::vm::Ctx
The context of the currently running WebAssembly instance.
This is implicitly passed to every WebAssembly function. Since this is per-instance, each field has a statically (as in after compiling the wasm) known size, so no runtime checks are necessary.
While the runtime currently just passes this around as the first, implicit parameter of every function, it may someday be pinned to a register (especially on arm, which has a ton of registers) to reduce register shuffling.
Fields
internal: InternalCtx
local_backing: *mut LocalBacking
These are pointers to things that are known to be owned
by the owning Instance
.
import_backing: *mut ImportBacking
module: *const ModuleInner
data: *mut c_void
This is intended to be user-supplied, per-instance
contextual data. There are currently some issue with it,
notably that it cannot be set before running the start
function in a WebAssembly module.
#219 fixes that issue, as well as allowing the user to have per-function context, instead of just per-instance.
data_finalizer: Option<fn(data: *mut c_void)>
If there's a function set in this field, it gets called
when the context is destructed, e.g. when an Instance
is dropped.
Methods
impl Ctx
[src]
pub fn memory(&self, mem_index: u32) -> &Memory
[src]
This exposes the specified memory of the WebAssembly instance as a immutable slice.
WebAssembly will soon support multiple linear memories, so this forces the user to specify.
Usage:
fn read_memory(ctx: &Ctx) -> u8 { let first_memory = ctx.memory(0); // Read the first byte of that linear memory. first_memory.view()[0].get() }
pub unsafe fn borrow_symbol_map(&self) -> &Option<HashMap<u32, String>>
[src]
Gives access to the emscripten symbol map, used for debugging
pub fn dynamic_sigindice_count(&self) -> usize
[src]
Returns the number of dynamic sigindices.
pub fn get_internal(&self, field: &InternalField) -> u64
[src]
Returns the value of the specified internal field.
pub fn set_internal(&mut self, field: &InternalField, value: u64)
[src]
Writes the value to the specified internal field.
Trait Implementations
impl Drop for Ctx
[src]
When an instance context is destructed, we're calling its data_finalizer
In order avoid leaking resources.
Implementing the data_finalizer
function is the responsibility of the wasmer
end-user.
See test: test_data_finalizer
as an example
impl Debug for Ctx
[src]
Auto Trait Implementations
impl !Sync for Ctx
impl !Send for Ctx
impl Unpin for Ctx
impl !RefUnwindSafe for Ctx
impl !UnwindSafe for Ctx
Blanket Implementations
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> From<T> for T
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,