Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'xtask/src/main.rs')
| -rw-r--r-- | xtask/src/main.rs | 48 |
1 files changed, 26 insertions, 22 deletions
diff --git a/xtask/src/main.rs b/xtask/src/main.rs index 5e5401ce28..df726dc23c 100644 --- a/xtask/src/main.rs +++ b/xtask/src/main.rs @@ -14,15 +14,16 @@ mod release; mod dist; mod metrics; -use anyhow::{bail, Result}; +use anyhow::bail; use std::{ env, path::{Path, PathBuf}, }; -use xshell::{cmd, cp, pushd, pushenv}; +use xshell::{cmd, Shell}; -fn main() -> Result<()> { - let _d = pushd(project_root())?; +fn main() -> anyhow::Result<()> { + let sh = &Shell::new()?; + sh.change_dir(project_root()); let flags = flags::Xtask::from_env()?; match flags.subcommand { @@ -30,18 +31,21 @@ fn main() -> Result<()> { println!("{}", flags::Xtask::HELP); Ok(()) } - flags::XtaskCmd::Install(cmd) => cmd.run(), - flags::XtaskCmd::FuzzTests(_) => run_fuzzer(), - flags::XtaskCmd::Release(cmd) => cmd.run(), - flags::XtaskCmd::Promote(cmd) => cmd.run(), - flags::XtaskCmd::Dist(cmd) => cmd.run(), - flags::XtaskCmd::Metrics(cmd) => cmd.run(), + flags::XtaskCmd::Install(cmd) => cmd.run(sh), + flags::XtaskCmd::FuzzTests(_) => run_fuzzer(sh), + flags::XtaskCmd::Release(cmd) => cmd.run(sh), + flags::XtaskCmd::Promote(cmd) => cmd.run(sh), + flags::XtaskCmd::Dist(cmd) => cmd.run(sh), + flags::XtaskCmd::Metrics(cmd) => cmd.run(sh), flags::XtaskCmd::Bb(cmd) => { { - let _d = pushd("./crates/rust-analyzer")?; - cmd!("cargo build --release --features jemalloc").run()?; + let _d = sh.push_dir("./crates/rust-analyzer"); + cmd!(sh, "cargo build --release --features jemalloc").run()?; } - cp("./target/release/rust-analyzer", format!("./target/rust-analyzer-{}", cmd.suffix))?; + sh.copy_file( + "./target/release/rust-analyzer", + format!("./target/rust-analyzer-{}", cmd.suffix), + )?; Ok(()) } } @@ -57,25 +61,25 @@ fn project_root() -> PathBuf { .to_path_buf() } -fn run_fuzzer() -> Result<()> { - let _d = pushd("./crates/syntax")?; - let _e = pushenv("RUSTUP_TOOLCHAIN", "nightly"); - if cmd!("cargo fuzz --help").read().is_err() { - cmd!("cargo install cargo-fuzz").run()?; +fn run_fuzzer(sh: &Shell) -> anyhow::Result<()> { + let _d = sh.push_dir("./crates/syntax"); + let _e = sh.push_env("RUSTUP_TOOLCHAIN", "nightly"); + if cmd!(sh, "cargo fuzz --help").read().is_err() { + cmd!(sh, "cargo install cargo-fuzz").run()?; }; // Expecting nightly rustc - let out = cmd!("rustc --version").read()?; + let out = cmd!(sh, "rustc --version").read()?; if !out.contains("nightly") { bail!("fuzz tests require nightly rustc") } - cmd!("cargo fuzz run parser").run()?; + cmd!(sh, "cargo fuzz run parser").run()?; Ok(()) } -fn date_iso() -> Result<String> { - let res = cmd!("date -u +%Y-%m-%d").read()?; +fn date_iso(sh: &Shell) -> anyhow::Result<String> { + let res = cmd!(sh, "date -u +%Y-%m-%d").read()?; Ok(res) } |