pub trait FunctionContext {
// Required methods
fn read_memory_into(
&self,
address: Pointer<u8>,
dest: &mut [u8],
) -> Result<(), String>;
fn write_memory(
&mut self,
address: Pointer<u8>,
data: &[u8],
) -> Result<(), String>;
fn allocate_memory(&mut self, size: u32) -> Result<Pointer<u8>, String>;
fn deallocate_memory(&mut self, ptr: Pointer<u8>) -> Result<(), String>;
fn register_panic_error_message(&mut self, message: &str);
// Provided method
fn read_memory(
&self,
address: Pointer<u8>,
size: u32,
) -> Result<Vec<u8>, String> { ... }
}
Expand description
Context used by Function
to interact with the allocator and the memory of the wasm instance.
Required Methods§
sourcefn read_memory_into(
&self,
address: Pointer<u8>,
dest: &mut [u8],
) -> Result<(), String>
fn read_memory_into( &self, address: Pointer<u8>, dest: &mut [u8], ) -> Result<(), String>
Read memory into the given dest
buffer from address
.
sourcefn write_memory(
&mut self,
address: Pointer<u8>,
data: &[u8],
) -> Result<(), String>
fn write_memory( &mut self, address: Pointer<u8>, data: &[u8], ) -> Result<(), String>
Write the given data at address
into the memory.
sourcefn allocate_memory(&mut self, size: u32) -> Result<Pointer<u8>, String>
fn allocate_memory(&mut self, size: u32) -> Result<Pointer<u8>, String>
Allocate a memory instance of size
bytes.
sourcefn deallocate_memory(&mut self, ptr: Pointer<u8>) -> Result<(), String>
fn deallocate_memory(&mut self, ptr: Pointer<u8>) -> Result<(), String>
Deallocate a given memory instance.
sourcefn register_panic_error_message(&mut self, message: &str)
fn register_panic_error_message(&mut self, message: &str)
Registers a panic error message within the executor.
This is meant to be used in situations where the runtime encounters an unrecoverable error and intends to panic.
Panicking in WASM is done through the unreachable
instruction which causes an unconditional trap and immediately aborts
the execution. It does not however allow for any diagnostics to be
passed through to the host, so while we do know that something went
wrong we don’t have any direct indication of what exactly went wrong.
As a workaround we use this method right before the execution is actually aborted to pass an error message to the host so that it can associate it with the next trap, and return that to the caller.
A WASM trap should be triggered immediately after calling this method; otherwise the error message might be associated with a completely unrelated trap.
It should only be called once, however calling it more than once is harmless and will overwrite the previously set error message.