Facilitating high-level interactions between Wasm modules and JavaScript
Go to file
Alex Crichton e06255fba5 Don't generate JS bindings for unused imports
If a JS import's shim isn't actually imported that means that somewhere along
the way it was optimized out or it was never used in the first place! In that
case we can skip generation of the JS bindings for it as it's not needed.
2018-06-29 15:56:12 -07:00
crates Don't generate JS bindings for unused imports 2018-06-29 15:56:12 -07:00
examples rustfmt all the things 2018-06-27 22:42:34 -07:00
guide Add @sendilkumarn to the team! \o/ (#352) 2018-06-28 17:00:33 -05:00
releases Add a template for release announcements 2018-06-19 12:05:52 -07:00
src Add support for js::Error 2018-06-29 23:24:46 +09:00
tests/all Don't generate JS bindings for unused imports 2018-06-29 15:56:12 -07:00
.appveyor.yml use both npm and yarn in ci 2018-06-25 17:22:51 -07:00
.eslintrc.js Update js formatting 2018-06-15 12:55:37 -05:00
.gitignore Binding for Math.cos,cosh,exp,expml,fround,imul,log,log10,log1p,log2 2018-06-28 12:46:53 -04:00
.travis.yml Disable formatting on Travis 2018-06-28 18:35:15 -07:00
Cargo.toml Expose objects and functions from the JavaScript global scope 2018-06-18 16:41:01 -07:00
CHANGELOG.md Add a change log 2018-06-19 12:05:52 -07:00
CONTRIBUTING.md Point to the guide's contributing section instead of CONTRIBUTING.md 2018-06-19 12:05:52 -07:00
LICENSE-APACHE Add license texts 2017-12-18 14:45:06 -08:00
LICENSE-MIT Add license texts 2017-12-18 14:45:06 -08:00
package-lock.json Update js formatting 2018-06-15 12:55:37 -05:00
package.json Update js formatting 2018-06-15 12:55:37 -05:00
README.md Point to the guide's contributing section instead of CONTRIBUTING.md 2018-06-19 12:05:52 -07:00
yarn.lock use both npm and yarn in ci 2018-06-25 17:22:51 -07:00

wasm-bindgen

Facilitating high-level interactions between wasm modules and JavaScript.

Introduction blog post: "JavaScript to Rust and Back Again: A wasm-bindgen Tale"

Build Status Build status API Documentation on docs.rs

Import JavaScript things into Rust and export Rust things to JavaScript.

src/lib.rs:

#![feature(proc_macro, wasm_custom_section, wasm_import_module)]

extern crate wasm_bindgen;
use wasm_bindgen::prelude::*;

// Import the `window.alert` function from the Web.
#[wasm_bindgen]
extern {
    fn alert(s: &str);
}

// Export a `greet` function from Rust to JavaScript, that alerts a
// hello message.
#[wasm_bindgen]
pub fn greet(name: &str) {
    alert(&format!("Hello, {}!", name));
}

Use exported Rust things from JavaScript!

index.js:

// Asynchronously load, compile, and import the Rust's WebAssembly
// and JavaScript interface.
import("./hello_world").then(module => {
  // Alert "Hello, World!"
  module.greet("World!");
});

Guide

📚 Read the wasm-bindgen guide here! 📚

License

This project is licensed under either of

at your option.

Contribution

See the "Contributing" section of the guide for information on hacking on wasm-bindgen!

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.