fd/src/exec/command.rs

51 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<()>, is_multithread: bool) -> ExitCode {
let output;
// Spawn the supplied command.
if is_multithread {
output = 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
let child = cmd.spawn().expect("Failed to execute command");
output = child.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
}
}
}