fd/src/exec/command.rs

53 lines
1.6 KiB
Rust
Raw Normal View History

use std::io;
2017-12-09 02:46:08 +01:00
use std::io::Write;
2018-04-13 22:46:17 +02:00
use std::process::Command;
use std::sync::Mutex;
2020-04-03 21:18:54 +02:00
use crate::error::print_error;
use crate::exit_codes::ExitCode;
/// Executes a command.
pub fn execute_command(
mut cmd: Command,
out_perm: &Mutex<()>,
enable_output_buffering: bool,
) -> ExitCode {
// Spawn the supplied command.
let output = if enable_output_buffering {
cmd.output()
} else {
2020-06-23 21:28:15 +02:00
// If running on only one thread, don't buffer output
// Allows for viewing and interacting with intermediate command output
cmd.spawn().and_then(|c| c.wait_with_output())
};
// Then wait for the command to exit, if it was spawned.
match output {
Ok(output) => {
// While this lock is active, this thread will be the only thread allowed
2017-12-09 02:46:08 +01:00
// to write its outputs.
let _lock = out_perm.lock().unwrap();
let stdout = io::stdout();
let stderr = io::stderr();
let _ = stdout.lock().write_all(&output.stdout);
let _ = stderr.lock().write_all(&output.stderr);
if output.status.code() == Some(0) {
ExitCode::Success
} else {
ExitCode::GeneralError
}
}
Err(ref why) if why.kind() == io::ErrorKind::NotFound => {
2020-04-03 21:18:54 +02:00
print_error(format!("Command not found: {:?}", cmd));
ExitCode::GeneralError
}
Err(why) => {
2020-04-03 21:18:54 +02:00
print_error(format!("Problem while executing command: {}", why));
ExitCode::GeneralError
}
}
}