diff options
Diffstat (limited to 'js/rust/README.md')
-rw-r--r-- | js/rust/README.md | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/js/rust/README.md b/js/rust/README.md new file mode 100644 index 0000000000..743793c5bc --- /dev/null +++ b/js/rust/README.md @@ -0,0 +1,46 @@ +# The `js` Crate: Rust Bindings to SpiderMonkey + +[User Documentation](http://doc.servo.org/mozjs/) + +## Building + +To build a release version of SpiderMonkey and the Rust code with optimizations +enabled: + +``` +$ cargo build --release +``` + +To build with SpiderMonkey's DEBUG checks and assertions: + +``` +$ cargo build --features debugmozjs +``` + +Raw FFI bindings to JSAPI are machine generated with +[`rust-lang-nursery/rust-bindgen`][bindgen], and requires libclang >= 3.9. See +`./build.rs` for details. + +[bindgen]: https://github.com/rust-lang-nursery/rust-bindgen + +## Cargo Features + +* `debugmozjs`: Create a DEBUG build of SpiderMonkey with many extra assertions + enabled. This is decoupled from whether the crate and its Rust code is built + in debug or release mode. + +* `promises`: Enable SpiderMonkey native promises. + +* `nonzero`: Leverage the unstable `NonZero` type. Requires nightly Rust. + +## Testing + +Make sure to test both with and without the `debugmozjs` feature because various +structures have different sizes and get passed through functions differently at +the ABI level! At minimum, you should test with `debugmozjs` to get extra +assertions and checking. + +``` +$ cargo test +$ cargo test --features debugmozjs +``` |