wasmer/lib
Ivan Enderlin c8872f1a6f test(runtime-c-api) Test the new wasmer_module_(de)?serialize functions.
This test suite compiles a module, then serializes it, deserializes
it, and continues by creating an instance and calling a function on
it. It allows to test the entire roundtrip.
2019-03-15 12:04:23 +01:00
..
clif-backend fix(clif-backend) Remove unused imports. 2019-03-12 10:03:55 +01:00
emscripten Merge branch 'master' into fix/llvm-feature-flag 2019-03-13 12:22:21 -07:00
llvm-backend Use wasmerio fork of inkwell 2019-03-11 10:03:40 -07:00
runtime feat(runtime) Make default_compiler public. 2019-03-15 12:04:23 +01:00
runtime-c-api test(runtime-c-api) Test the new wasmer_module_(de)?serialize functions. 2019-03-15 12:04:23 +01:00
runtime-core fix(runtime-core) Remove unused imports. 2019-03-12 09:51:54 +01:00
spectests create an llvm flag 2019-03-11 09:58:09 -07:00
win-exception-handler fix appveyor installer and build (#224) 2019-03-01 13:16:32 -08:00
.gitignore Remove generated spectest codes from repo. 2019-01-12 23:48:21 -05:00
README.md Update README.md 2019-03-07 20:39:58 -08:00

Wasmer Libraries

Wasmer is modularized into different libraries, separated into three main sections:

Runtime

The core of Wasmer is the runtime, which provides the necessary abstractions to create a good user experience when embedding.

The runtime is divided into two main libraries:

  • runtime-core: The main implementation of the runtime.
  • runtime: Easy-to-use API on top of runtime-core.

Integrations

The integration builds on the Wasmer runtime and allow us to run WebAssembly files compiled for different environments.

Wasmer intends to support different integrations:

  • emscripten: run Emscripten-generated WebAssembly files, such as Lua or nginx.
  • Go ABI: we will work on this soon! Want to give us a hand?
  • Blazor: research period, see tracking issue

Backends

The Wasmer runtime is designed to support multiple compiler backends, allowing the user to tune the codegen properties (compile speed, performance, etc) to best fit their use case.

Currently, we support multiple backends for compiling WebAssembly to machine code: