about summary refs log tree commit diff
path: root/scripts
diff options
context:
space:
mode:
authorbjorn3 <17426603+bjorn3@users.noreply.github.com>2022-10-28 12:51:15 +0000
committerbjorn3 <17426603+bjorn3@users.noreply.github.com>2022-10-28 12:51:15 +0000
commitf17dbfc933eaef12d3ae29ca500675328eaeb08e (patch)
tree0ca3a2336c523451ed422bdead7c9f31989645e1 /scripts
parentddc66ffecc85fa7ba089367fe7ad6c307cbea216 (diff)
downloadrust-f17dbfc933eaef12d3ae29ca500675328eaeb08e.tar.gz
rust-f17dbfc933eaef12d3ae29ca500675328eaeb08e.zip
Add rustdoc-clif wrapper
Diffstat (limited to 'scripts')
-rw-r--r--scripts/rustdoc-clif.rs36
1 files changed, 36 insertions, 0 deletions
diff --git a/scripts/rustdoc-clif.rs b/scripts/rustdoc-clif.rs
new file mode 100644
index 00000000000..a19d72acfa8
--- /dev/null
+++ b/scripts/rustdoc-clif.rs
@@ -0,0 +1,36 @@
+use std::env;
+use std::ffi::OsString;
+#[cfg(unix)]
+use std::os::unix::process::CommandExt;
+use std::path::PathBuf;
+use std::process::Command;
+
+fn main() {
+    let sysroot = PathBuf::from(env::current_exe().unwrap().parent().unwrap());
+
+    let cg_clif_dylib_path = sysroot.join(if cfg!(windows) { "bin" } else { "lib" }).join(
+        env::consts::DLL_PREFIX.to_string() + "rustc_codegen_cranelift" + env::consts::DLL_SUFFIX,
+    );
+
+    let mut args = std::env::args_os().skip(1).collect::<Vec<_>>();
+    args.push(OsString::from("-Cpanic=abort"));
+    args.push(OsString::from("-Zpanic-abort-tests"));
+    let mut codegen_backend_arg = OsString::from("-Zcodegen-backend=");
+    codegen_backend_arg.push(cg_clif_dylib_path);
+    args.push(codegen_backend_arg);
+    if !args.contains(&OsString::from("--sysroot")) {
+        args.push(OsString::from("--sysroot"));
+        args.push(OsString::from(sysroot.to_str().unwrap()));
+    }
+
+    // Ensure that the right toolchain is used
+    env::set_var("RUSTUP_TOOLCHAIN", env!("RUSTUP_TOOLCHAIN"));
+
+    #[cfg(unix)]
+    Command::new("rustdoc").args(args).exec();
+
+    #[cfg(not(unix))]
+    std::process::exit(
+        Command::new("rustdoc").args(args).spawn().unwrap().wait().unwrap().code().unwrap_or(1),
+    );
+}