pub struct Module { /* private fields */ }Expand description
Deserialized module prepared for instantiation.
Implementations§
Source§impl Module
impl Module
Sourcepub fn from_susy_wasm_module(module: Module) -> Result<Module, Error>
pub fn from_susy_wasm_module(module: Module) -> Result<Module, Error>
Create Module from susy_wasm::elements::Module.
This function will load, validate and prepare a susy_wasm’s Module.
§Errors
Returns Err if provided Module is not valid.
§Examples
extern crate susy_wasm;
extern crate susy_wasmi;
use susy_wasm::builder;
use susy_wasm::elements;
fn main() {
let susy_module =
builder::module()
.function()
.signature().with_param(elements::ValueType::I32).build()
.body().build()
.build()
.build();
let module = susy_wasmi::Module::from_susy_wasm_module(susy_module)
.expect("susy-wasm builder generated invalid module!");
// Instantiate `module`, etc...
}Sourcepub fn deny_floating_point(&self) -> Result<(), Error>
pub fn deny_floating_point(&self) -> Result<(), Error>
Fail if the module contains any floating-point operations
§Errors
Returns Err if provided Module is not valid.
§Examples
let wasm_binary: Vec<u8> =
wabt::wat2wasm(
r#"
(module
(func $add (param $lhs i32) (param $rhs i32) (result i32)
get_local $lhs
get_local $rhs
i32.add))
"#,
)
.expect("failed to parse wat");
// Load wasm binary and prepare it for instantiation.
let module = susy_wasmi::Module::from_buffer(&wasm_binary).expect("Parsing failed");
assert!(module.deny_floating_point().is_ok());
let wasm_binary: Vec<u8> =
wabt::wat2wasm(
r#"
(module
(func $add (param $lhs f32) (param $rhs f32) (result f32)
get_local $lhs
get_local $rhs
f32.add))
"#,
)
.expect("failed to parse wat");
let module = susy_wasmi::Module::from_buffer(&wasm_binary).expect("Parsing failed");
assert!(module.deny_floating_point().is_err());
let wasm_binary: Vec<u8> =
wabt::wat2wasm(
r#"
(module
(func $add (param $lhs f32) (param $rhs f32) (result f32)
get_local $lhs))
"#,
)
.expect("failed to parse wat");
let module = susy_wasmi::Module::from_buffer(&wasm_binary).expect("Parsing failed");
assert!(module.deny_floating_point().is_err());Sourcepub fn from_buffer<B: AsRef<[u8]>>(buffer: B) -> Result<Module, Error>
pub fn from_buffer<B: AsRef<[u8]>>(buffer: B) -> Result<Module, Error>
Create Module from a given buffer.
This function will deserialize wasm module from a given module, validate and prepare it for instantiation.
§Errors
Returns Err if wasm binary in provided buffer is not valid wasm binary.
§Examples
extern crate susy_wasmi;
fn main() {
let module =
susy_wasmi::Module::from_buffer(
// Minimal module:
// \0asm - magic
// 0x01 - version (in little-endian)
&[0x00, 0x61, 0x73, 0x6d, 0x01, 0x00, 0x00, 0x00]
).expect("Failed to load minimal module");
// Instantiate `module`, etc...
}Auto Trait Implementations§
impl Freeze for Module
impl RefUnwindSafe for Module
impl Send for Module
impl Sync for Module
impl Unpin for Module
impl UnwindSafe for Module
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
Mutably borrows from an owned value. Read more