Skip to content

RoyalIcing/OrbWasmtime

Repository files navigation

OrbWasmtime

Run WebAssembly modules in Elixir via Rust & Wasmtime.

Note: this project is in alpha and will change. For another WebAssembly runtime for Elixir check out Wasmex.

Installation

Add orb_wasmtime to your list of dependencies in mix.exs:

def deps do
  [
    {:orb_wasmtime, "~> 0.1.2"}
  ]
end

About

OrbWasmtime lets you run WebAssembly modules. You can call functions, list exports, pass imports, get/set globals, and read/write memory.

defmodule Example do
  alias OrbWasmtime.Instance

  def run() do
    inst = Instance.run(example_wat())
    add = Instance.capture(inst, :add, 2)
    add.(2, 3) # 5
    add.(4, 5) # 9
  end

  defp example_wat() do
    """
    (module $Add
      (func (export "add") (param $a i32) (param $b i32) (result i32)
        (i32.add (local.get $a) (local.get $b))
      )
    )
    """
  end
end

Documentation can be generated with ExDoc and published on HexDocs. Once published, the docs can be found at https://hexdocs.pm/orb_wasmtime.

Releasing

git tag v0.x.x
git push --tags
# Wait for GitHub Action to succeed
mix rustler_precompiled.download OrbWasmtime.Rust --all --print --ignore-unavailable
rm -rf native/orb_wasmtime/target/
mix hex.publish