This book is build using mdBook
It requires a working rustup installation. Install mdBook with
$ cargo install mdbookBuild and run this book afterwards locally with
$ mdbook serve --openThis book contains many code fragments that are important to test.
We assume that you have a rustup toolchain called enzyme. This would have been created in your rust build directory by running something like:
$ rustup toolchain link enzyme $(pwd)/build/host/stage1The above only needs to be run once. The enzyme toolchain will also need rustdoc support. Again, from the Rust build directory, you'll need to have run something like
$ x build --stage 1 library tools/rustdocThis will need to be re-run each time you git pull.
It's unlikely that you want enzyme as your default toolchain for all your rust activities. Instead, you probably use cargo +enzyme build when working with Rust-Enyzme. You can specify a directory override by running the following (once) in the Enzyme-rustbook directory:
$ rustup override set enzymeCode samples worth testing are being migrated to the samples crate. You can run all samples with a simple
$ cargo testor, using cargo-nextest,
$ cargo nextest runFinally, you can run tests for all chapters using
$ mdbook testor a specific chapter using that chapter's name, such as
$ mdbook test -c UsageThis testing mode is being phased out as we move testable code into the samples crate. When using this mode, you will need the following workaround:
Rust's Enzyme support currently requires lto=fat, which is not part of the default profile for rustdoc (which is invoked by mdbook test). My temporary hack has been to patch mdbook by applying the following.
diff --git i/src/book/mod.rs w/src/book/mod.rs
index c0ab8a5..409482f 100644
--- i/src/book/mod.rs
+++ w/src/book/mod.rs
@@ -319,7 +319,11 @@ impl MDBook {
tmpf.write_all(ch.content.as_bytes())?;
let mut cmd = Command::new("rustdoc");
- cmd.arg(&path).arg("--test").args(&library_args);
+ cmd.arg(&path)
+ .arg("--test")
+ .args(&library_args)
+ .arg("-C")
+ .arg("lto=fat");
if let Some(edition) = self.config.rust.edition {
match edition {I'll find a better solution and make a pull request.