6 releases (breaking)

0.5.0 Feb 27, 2022
0.4.0 Feb 24, 2022
0.3.1 Jun 24, 2021
0.2.0 Jun 23, 2021
0.1.0 Jun 16, 2021

#4 in #nif

MIT license

85KB
2.5K SLoC

erl_nif

This crate provides bindings to the erl_nif C API, making it easy to write native extensions for Erlang and Elixir in Rust.

Example

Write your NIF in Rust:

erl_nif::init!(
  name: "Elixir.Add",
  funcs: [add],
);

#[erl_nif::nif]
fn add(a: u64, b: u64) -> Result<u64, String> {
  Ok(a + b)
}

Then load it in Elixir.

defmodule Add do
  @on_load {:init, 0}
  def init do
    path = :filename.join(:code.priv_dir(:add), "libadd")
    :ok = :erlang.load_nif(path, nil)
  end

  def add(_) do
    :erlang.nif_error(:nif_not_loaded)
  end
end

See the examples folder for a complete example.

Serde integration

To make it easy to move data structures between Rust and Elixir, the erl_nif crate supports integration with serde.

#[derive(serde::Serialize, serde::Deserialize)]
#[serde(rename = "Elixir.Example.Contact")]
struct Contact {
  name: String,
  email: String,
}
defmodule Example do
  defmodule Contact do
    defstruct [
      :name,
      :email
    ]
  end
end

Dependencies

~2.5MB
~56K SLoC