Cretonne is a low-level retargetable code generator. It translates a target-independent intermediate language into executable machine code.
This is a work in progress that is not yet functional.
For more information, see the documentation.
Cretonne is designed to be a code generator for WebAssembly, but it is general enough to be useful elsewhere too. The initial planned uses that affected its design are:
- WebAssembly compiler for the SpiderMonkey engine in Firefox.
- Backend for the IonMonkey JavaScript JIT compiler in Firefox.
- Debug build backend for the Rust compiler.
Cretonne is using the Cargo package manager format. First, ensure you have installed a current stable rust (stable, beta, and nightly should all work, but only stable and beta are tested consistently). Then, change the working directory to your clone of cretonne and run:
cargo build
This will create a target/debug directory where you can find the generated binary.
To build the optimized binary for release:
cargo build --release
You can then run tests with:
./test-all.sh
You may need to install the wat2wasm tool from the wabt project in order to run all of the WebAssembly tests. Tests requiring wat2wasm are ignored if the tool is not installed.
To build the Cretonne documentation, you need the Sphinx documentation generator:
$ pip install sphinx sphinx-autobuild sphinx_rtd_theme $ cd cretonne/docs $ make html $ open _build/html/index.html
We don't support Sphinx versions before 1.4 since the format of index tuples has changed.