#wasm-module #compiler #wasm-bytecode

no-std wasmer-compiler

Base compiler abstraction for Wasmer WebAssembly runtime

78 releases (44 stable)

new 5.0.5-rc1 Jan 3, 2025
5.0.4 Dec 17, 2024
5.0.2 Nov 25, 2024
4.4.0 Oct 4, 2024
1.0.0-alpha5 Nov 6, 2020

#668 in WebAssembly

Download history 15261/week @ 2024-09-13 17803/week @ 2024-09-20 15804/week @ 2024-09-27 22814/week @ 2024-10-04 20355/week @ 2024-10-11 17410/week @ 2024-10-18 19862/week @ 2024-10-25 18980/week @ 2024-11-01 15765/week @ 2024-11-08 14821/week @ 2024-11-15 16177/week @ 2024-11-22 18817/week @ 2024-11-29 17672/week @ 2024-12-06 18498/week @ 2024-12-13 14991/week @ 2024-12-20 19578/week @ 2024-12-27

72,731 downloads per month
Used in 258 crates (22 directly)

MIT license

575KB
12K SLoC

wasmer-compiler Build Status Join Wasmer Slack MIT License

This crate is the base for Compiler implementations.

It performs the translation from a Wasm module into a basic ModuleInfo, but leaves the Wasm function bytecode translation to the compiler implementor.

Here are some of the Compilers provided by Wasmer:

How to create a compiler

To create a compiler, one needs to implement two traits:

  1. CompilerConfig, that configures and creates a new compiler,
  2. Compiler, the compiler itself that will compile a module.
/// The compiler configuration options.
pub trait CompilerConfig {
    /// Gets the custom compiler config
    fn compiler(&self) -> Box<dyn Compiler>;
}

/// An implementation of a compiler from parsed WebAssembly module to compiled native code.
pub trait Compiler {
    /// Compiles a parsed module.
    ///
    /// It returns the [`Compilation`] or a [`CompileError`].
    fn compile_module<'data, 'module>(
        &self,
        target: &Target,
        compile_info: &'module CompileModuleInfo,
        module_translation: &ModuleTranslationState,
        // The list of function bodies
        function_body_inputs: PrimaryMap<LocalFunctionIndex, FunctionBodyData<'data>>,
    ) -> Result<Compilation, CompileError>;
}

Acknowledgments

This project borrowed some of the code strucutre from the cranelift-wasm crate, however it's been adapted to not depend on any specific IR and be abstract of any compiler.

Please check Wasmer ATTRIBUTIONS to further see licenses and other attributions of the project.

Dependencies

~7–17MB
~239K SLoC