diff --git a/README.md b/README.md index 03ab270..947e928 100644 --- a/README.md +++ b/README.md @@ -35,16 +35,58 @@ const string wat_sum_module = auto engine = new Engine(); auto store = new Store(engine); auto module_ = Module.from(store, wat_sum_module); +assert(engine.valid && store.valid && module_.valid, "Could not load module!"); + auto instance = new Instance(store, module_); -auto sumFunc = Function.from(instance.exports[0]); +assert(instance.valid, "Could not instantiate module!"); -assert(engine.valid && store.valid && module_.valid && instance.valid && sumFunc.valid, "Could not instantiate module!"); +assert(instance.exports[0].name == "sum"); +auto sumFunc = Function.from(instance.exports[0]); +assert(sumFunc.valid, "Could not load exported 'sum' function!"); Value[] results; assert(sumFunc.call([new Value(3), new Value(4)], results), "Error calling the `sum` function!"); assert(results.length == 1 && results[0].value.of.i32 == 7); ``` +### Import a D Function into a WebAssembly Module + +```d +const string wat_callback_module = + "(module" ~ + " (func $print (import \"\" \"print\") (param i32) (result i32))" ~ + " (func (export \"run\") (param $x i32) (param $y i32) (result i32)" ~ + " (call $print (i32.add (local.get $x) (local.get $y)))" ~ + " )" ~ + ")"; + +auto engine = new Engine(); +auto store = new Store(engine); +auto module_ = Module.from(store, wat_callback_module); +assert(module_.valid, "Error compiling module!"); + +auto print = (Module module_, int value) => { + return value; +}(); +auto imports = [new Function(store, module_, print.toDelegate).asExtern]; +auto instance = module_.instantiate(imports); +assert(instance.valid, "Could not instantiate module!"); + +auto runFunc = Function.from(instance.exports[0]); +assert(instance.exports[0].name == "run" && runFunc.valid, "Failed to get the `run` function!"); + +auto three = new Value(3); +auto four = new Value(4); +Value[] results; +assert(runFunc.call([three, four], results), "Error calling the `run` function!"); +assert(results.length == 1 && results[0].value.of.i32 == 7); + +destroy(three); +destroy(four); +destroy(instance); +destroy(module_); +``` + ## License [MIT Licence](https://opensource.org/licenses/MIT) diff --git a/views/index.html b/views/index.html index d4298cd..723fc86 100644 --- a/views/index.html +++ b/views/index.html @@ -84,7 +84,7 @@

Usage

}

See the official Wasmer Runtime C API documentation.

-

Run a WebAssembly Module

+

Run a WebAssembly Module

Sum function in a WebAssembly text format module:

@@ -101,14 +101,54 @@

Run a WebAssembly Module

auto engine = new Engine(); auto store = new Store(engine); auto module_ = Module.from(store, wat_sum_module); +assert(engine.valid && store.valid && module_.valid, "Could not load module!"); + auto instance = new Instance(store, module_); -auto sumFunc = Function.from(instance.exports[0]); +assert(instance.valid, "Could not instantiate module!"); -assert(engine.valid && store.valid && module_.valid && instance.valid && sumFunc.valid, "Could not instantiate module!"); +assert(instance.exports[0].name == "sum"); +auto sumFunc = Function.from(instance.exports[0]); +assert(sumFunc.valid, "Could not load exported 'sum' function!"); Value[] results; assert(sumFunc.call([new Value(3), new Value(4)], results), "Error calling the `sum` function!"); assert(results.length == 1 && results[0].value.of.i32 == 7); +

Import a D Function into a WebAssembly Module

+
+const string wat_callback_module =
+  "(module" ~
+  "  (func $print (import \"\" \"print\") (param i32) (result i32))" ~
+  "  (func (export \"run\") (param $x i32) (param $y i32) (result i32)" ~
+  "    (call $print (i32.add (local.get $x) (local.get $y)))" ~
+  "  )" ~
+  ")";
+
+auto engine = new Engine();
+auto store = new Store(engine);
+auto module_ = Module.from(store, wat_callback_module);
+assert(module_.valid, "Error compiling module!");
+
+auto print = (Module module_, int value) => {
+  return value;
+}();
+auto imports = [new Function(store, module_, print.toDelegate).asExtern];
+auto instance = module_.instantiate(imports);
+assert(instance.valid, "Could not instantiate module!");
+
+auto runFunc = Function.from(instance.exports[0]);
+assert(instance.exports[0].name == "run" && runFunc.valid, "Failed to get the `run` function!");
+
+auto three = new Value(3);
+auto four = new Value(4);
+Value[] results;
+assert(runFunc.call([three, four], results), "Error calling the `run` function!");
+assert(results.length == 1 && results[0].value.of.i32 == 7);
+
+destroy(three);
+destroy(four);
+destroy(instance);
+destroy(module_);
+

Modules