forked from extern/nushell
ab480856a5
# Description Lint: `clippy::uninlined_format_args` More readable in most situations. (May be slightly confusing for modifier format strings https://doc.rust-lang.org/std/fmt/index.html#formatting-parameters) Alternative to #7865 # User-Facing Changes None intended # Tests + Formatting (Ran `cargo +stable clippy --fix --workspace -- -A clippy::all -D clippy::uninlined_format_args` to achieve this. Depends on Rust `1.67`)
44 lines
1.1 KiB
Rust
44 lines
1.1 KiB
Rust
use std::{
|
|
io::Read,
|
|
process::{Command, Stdio},
|
|
};
|
|
|
|
pub fn ensure_binary_present(package: &str) {
|
|
let cargo_path = env!("CARGO");
|
|
let mut arguments = vec!["build", "--package", package, "--quiet"];
|
|
|
|
let profile = std::env::var("NUSHELL_CARGO_TARGET");
|
|
if let Ok(profile) = &profile {
|
|
arguments.push("--profile");
|
|
arguments.push(profile);
|
|
}
|
|
|
|
let mut command = Command::new(cargo_path)
|
|
.args(arguments)
|
|
.stdout(Stdio::piped())
|
|
.stderr(Stdio::piped())
|
|
.spawn()
|
|
.expect("Failed to spawn cargo build command");
|
|
|
|
let stderr = command.stderr.take();
|
|
|
|
let success = command
|
|
.wait()
|
|
.expect("failed to wait cargo build command")
|
|
.success();
|
|
|
|
if let Some(mut stderr) = stderr {
|
|
let mut buffer = String::new();
|
|
stderr
|
|
.read_to_string(&mut buffer)
|
|
.expect("failed to read cargo build stderr");
|
|
if !buffer.is_empty() {
|
|
println!("=== cargo build stderr\n{buffer}");
|
|
}
|
|
}
|
|
|
|
if !success {
|
|
panic!("cargo build failed");
|
|
}
|
|
}
|