This directory contains a collection of examples. This isn't an exhaustive collection though, if one example is missing, please ask, we will be happy to fulfill your needs!
As a quick introduction to Wasmer's main workflows, here are three diagrams. We hope it provides an overview of how the crates assemble together.
-
Module compilation, illustrates how WebAssembly bytes are validated, parsed, and compiled, with the help of the
wasmer::Module
,wasmer_engine::Engine
, andwasmer_compiler::Compiler
API. -
Module serialization, illustrates how a module can be serialized and deserialized, with the help of
wasmer::Module::serialize
andwasmer::Module::deserialize
. The important part is that the engine can changed between those two steps, and thus how a headless engine can be used for the deserialization. -
Module instantiation, illustrates what happens when
wasmer::Instance::new
is called.
The examples are written in a difficulty/discovery order. Concepts that are explained in an example is not necessarily re-explained in a next example.
-
JIT engine, explains what an engine is, what the JIT engine is, and how to set it up. The example completes itself with the compilation of the Wasm module, its instantiation, and finally, by calling an exported function.
Keywords: JIT, engine, in-memory, executable code.
Execute the example
$ cargo run --example engine-jit --release --features "cranelift"
-
Native engine, explains what a native engine is, and how to set it up. The example completes itself with the compilation of the Wasm module, its instantiation, and finally, by calling an exported function.
Keywords: native, engine, shared library, dynamic library, executable code.
Execute the example
$ cargo run --example engine-native --release --features "cranelift"
-
Headless engines, explains what a headless engine is, what problem it does solve, and what are the benefits of it. The example completes itself with the instantiation of a pre-compiled Wasm module, and finally, by calling an exported function.
Keywords: native, engine, constrained environment, ahead-of-time compilation, cross-compilation, executable code, serialization.
Execute the example
$ cargo run --example engine-headless --release --features "cranelift"
-
Cross-compilation, illustrates the power of the abstraction over the engines and the compilers, such as it is possible to cross-compile a Wasm module for a custom target.
Keywords: engine, compiler, cross-compilation.
Execute the example
$ cargo run --example cross-compilation --release --features "cranelift"
-
Singlepass compiler, explains how to use the
wasmer-compiler-singlepass
compiler.Keywords: compiler, singlepass.
Execute the example
$ cargo run --example compiler-singlepass --release --features "singlepass"
-
Cranelift compiler, explains how to use the
wasmer-compiler-cranelift
compiler.Keywords: compiler, cranelift.
Execute the example
$ cargo run --example compiler-cranelift --release --features "cranelift"
-
LLVM compiler, explains how to use the
wasmer-compiler-llvm
compiler.Keywords: compiler, llvm.
Execute the example
$ cargo run --example compiler-llvm --release --features "llvm"
-
Exported function, explains how to get and how to call an exported function. They come in 2 flavors: dynamic, and “static”/native. The pros and cons are discussed briefly.
Keywords: export, function, dynamic, static, native.
Execute the example
$ cargo run --example exported-function --release --features "cranelift"
-
WASI, explains how to use the WebAssembly System Interface (WASI), i.e. the
wasmer-wasi
crate.Keywords: wasi, system, interface
Execute the example
$ cargo run --example wasi --release --features "cranelift,wasi"