10 releases (6 stable)
2.3.0 | Jun 6, 2022 |
---|---|
2.2.1 | Mar 16, 2022 |
2.2.0 | Feb 28, 2022 |
2.2.0-rc1 | Jan 28, 2022 |
2.0.0 | Jun 16, 2021 |
#1629 in WebAssembly
10,582 downloads per month
Used in 11 crates
(via wasmer-asml-fork)
1MB
21K
SLoC
wasmer-engine-dylib

The Wasmer Dylib engine is usable with any compiler implementation
based on wasmer-compiler
that is able to emit
Position-Independent Code (PIC).
After the compiler generates the machine code for the functions, the
Dylib Engine generates a shared object file and links it via dlsym
so it can be usable by the wasmer
API.
This allows Wasmer to achieve blazing fast native startup times.
Note: you can find a full working example using the Dylib engine here.
Difference with wasmer-engine-universal
The Dylib Engine and Universal Engine mainly differ on how the Modules are loaded/stored. Using the same compilers, both will have the same runtime speed.
However, the Dylib Engine uses the Operating System shared library
loader (via dlopen
) and as such is able to achieve a much faster
startup time when deserializing a serialized Module
.
Requirements
The wasmer-engine-dylib
crate requires a linker available on
your system to generate the shared object file.
We recommend having gcc
or clang
installed.
Note: when cross-compiling to other targets,
clang
will be the default command used for compiling.
You can install LLVM (that provides clang
) easily on your
Debian-like system via this command:
bash -c "$(wget -O - https://apt.llvm.org/llvm.sh)"
Or in macOS:
brew install llvm
Or via any of the pre-built binaries that LLVM offers.
Dependencies
~9–20MB
~317K SLoC