#wasm-interpreter #interpreter #vm #virtualization

sys no-std wasmi_c_api_impl

C bindings for the Wasmi WebAssembly interpreter

1 unstable release

0.36.0 Jul 24, 2024

#1214 in WebAssembly

MIT/Apache

2.5MB
53K SLoC

Wasmi C-API

Usage in a C Project

If you have a C project with which you want to use Wasmi, you can interface with Wasmi's C API:

Prerequisites

From the root of the Wasmi repository, run the following commands:

cmake -S crates/c_api -B target/c_api --install-prefix "$(pwd)/artifacts" &&
cmake --build target/c_api --target install

These commands will produce the following files:

  • artifacts/lib/libwasmi.{a,lib}: The static Wasmi library.
  • artifacts/lib/libwasmi.{so,dylib,dll}: The dynamic (or shared) Wasmi library.
  • artifacts/include/**.h: The header files for interfacing with Wasmi from C or C++.

Usage in a Rust Project

If you have a Rust crate that uses a C or C++ library that uses Wasmi, you can link to the Wasmi C API as follows:

  1. Add a dependency on the wasmi_c_api_impl crate to your Cargo.toml. Note that package name differs from the library name.
[dependencies]
wasmi_c_api = { version = "0.35.0", package = "wasmi_c_api_impl" }
  1. In your build.rs file, when compiling your C/C++ source code, add the C wasmi_c_api headers to the include path:
fn main() {
    let mut cfg = cc::Build::new();
    // Add the Wasmi and standard Wasm C-API headers to the include path.
    cfg
        .include(std::env::var("DEP_WASMI_C_API_INCLUDE").unwrap());
        .include(std::env::var("DEP_WASMI_C_API_WASM_INCLUDE").unwrap());
    // Compile your C code.
    cfg
        .file("src/your_c_code.c")
        .compile("your_library");
}

Dependencies

~4MB
~74K SLoC