mirror of
https://github.com/uutils/coreutils
synced 2024-11-17 10:18:11 +00:00
parent
425de97650
commit
7d94121b95
1 changed files with 36 additions and 22 deletions
|
@ -7,20 +7,21 @@
|
||||||
|
|
||||||
// spell-checker:ignore (ToDO) signalname pids
|
// spell-checker:ignore (ToDO) signalname pids
|
||||||
|
|
||||||
|
// clippy bug https://github.com/rust-lang/rust-clippy/issues/7422
|
||||||
|
#![allow(clippy::nonstandard_macro_braces)]
|
||||||
|
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate uucore;
|
extern crate uucore;
|
||||||
|
|
||||||
use clap::{crate_version, App, Arg};
|
use clap::{crate_version, App, Arg};
|
||||||
use libc::{c_int, pid_t};
|
use libc::{c_int, pid_t};
|
||||||
use std::io::Error;
|
use std::io::Error;
|
||||||
|
use uucore::error::{UResult, USimpleError};
|
||||||
use uucore::signals::ALL_SIGNALS;
|
use uucore::signals::ALL_SIGNALS;
|
||||||
use uucore::InvalidEncodingHandling;
|
use uucore::InvalidEncodingHandling;
|
||||||
|
|
||||||
static ABOUT: &str = "Send signal to processes or list information about signals.";
|
static ABOUT: &str = "Send signal to processes or list information about signals.";
|
||||||
|
|
||||||
static EXIT_OK: i32 = 0;
|
|
||||||
static EXIT_ERR: i32 = 1;
|
|
||||||
|
|
||||||
pub mod options {
|
pub mod options {
|
||||||
pub static PIDS_OR_SIGNALS: &str = "pids_of_signals";
|
pub static PIDS_OR_SIGNALS: &str = "pids_of_signals";
|
||||||
pub static LIST: &str = "list";
|
pub static LIST: &str = "list";
|
||||||
|
@ -36,7 +37,8 @@ pub enum Mode {
|
||||||
List,
|
List,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn uumain(args: impl uucore::Args) -> i32 {
|
#[uucore_procs::gen_uumain]
|
||||||
|
pub fn uumain(args: impl uucore::Args) -> UResult<()> {
|
||||||
let args = args
|
let args = args
|
||||||
.collect_str(InvalidEncodingHandling::Ignore)
|
.collect_str(InvalidEncodingHandling::Ignore)
|
||||||
.accept_any();
|
.accept_any();
|
||||||
|
@ -69,10 +71,10 @@ pub fn uumain(args: impl uucore::Args) -> i32 {
|
||||||
return kill(&sig, &pids_or_signals);
|
return kill(&sig, &pids_or_signals);
|
||||||
}
|
}
|
||||||
Mode::Table => table(),
|
Mode::Table => table(),
|
||||||
Mode::List => list(pids_or_signals.get(0).cloned()),
|
Mode::List => list(pids_or_signals.get(0).cloned())?,
|
||||||
}
|
}
|
||||||
|
|
||||||
EXIT_OK
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn uu_app() -> App<'static, 'static> {
|
pub fn uu_app() -> App<'static, 'static> {
|
||||||
|
@ -142,20 +144,23 @@ fn table() {
|
||||||
println!()
|
println!()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn print_signal(signal_name_or_value: &str) {
|
fn print_signal(signal_name_or_value: &str) -> UResult<()> {
|
||||||
for (value, &signal) in ALL_SIGNALS.iter().enumerate() {
|
for (value, &signal) in ALL_SIGNALS.iter().enumerate() {
|
||||||
if signal == signal_name_or_value || (format!("SIG{}", signal)) == signal_name_or_value {
|
if signal == signal_name_or_value || (format!("SIG{}", signal)) == signal_name_or_value {
|
||||||
println!("{}", value);
|
println!("{}", value);
|
||||||
exit!(EXIT_OK as i32)
|
return Ok(());
|
||||||
} else if signal_name_or_value == value.to_string() {
|
} else if signal_name_or_value == value.to_string() {
|
||||||
println!("{}", signal);
|
println!("{}", signal);
|
||||||
exit!(EXIT_OK as i32)
|
return Ok(());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
crash!(EXIT_ERR, "unknown signal name {}", signal_name_or_value)
|
Err(USimpleError::new(
|
||||||
|
1,
|
||||||
|
format!("unknown signal name {}", signal_name_or_value),
|
||||||
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn print_signals() {
|
fn print_signals() -> UResult<()> {
|
||||||
let mut pos = 0;
|
let mut pos = 0;
|
||||||
for (idx, signal) in ALL_SIGNALS.iter().enumerate() {
|
for (idx, signal) in ALL_SIGNALS.iter().enumerate() {
|
||||||
pos += signal.len();
|
pos += signal.len();
|
||||||
|
@ -168,32 +173,41 @@ fn print_signals() {
|
||||||
print!(" ");
|
print!(" ");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn list(arg: Option<String>) {
|
fn list(arg: Option<String>) -> UResult<()> {
|
||||||
match arg {
|
match arg {
|
||||||
Some(ref x) => print_signal(x),
|
Some(ref x) => Ok(print_signal(x)?),
|
||||||
None => print_signals(),
|
None => Ok(print_signals()?),
|
||||||
};
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn kill(signalname: &str, pids: &[String]) -> i32 {
|
fn kill(signalname: &str, pids: &[String]) -> UResult<()> {
|
||||||
let mut status = 0;
|
|
||||||
let optional_signal_value = uucore::signals::signal_by_name_or_value(signalname);
|
let optional_signal_value = uucore::signals::signal_by_name_or_value(signalname);
|
||||||
let signal_value = match optional_signal_value {
|
let signal_value = match optional_signal_value {
|
||||||
Some(x) => x,
|
Some(x) => x,
|
||||||
None => crash!(EXIT_ERR, "unknown signal name {}", signalname),
|
None => {
|
||||||
|
return Err(USimpleError::new(
|
||||||
|
1,
|
||||||
|
format!("unknown signal name {}", signalname),
|
||||||
|
));
|
||||||
|
}
|
||||||
};
|
};
|
||||||
for pid in pids {
|
for pid in pids {
|
||||||
match pid.parse::<usize>() {
|
match pid.parse::<usize>() {
|
||||||
Ok(x) => {
|
Ok(x) => {
|
||||||
if unsafe { libc::kill(x as pid_t, signal_value as c_int) } != 0 {
|
if unsafe { libc::kill(x as pid_t, signal_value as c_int) } != 0 {
|
||||||
show_error!("{}", Error::last_os_error());
|
return Err(USimpleError::new(1, format!("{}", Error::last_os_error())));
|
||||||
status = 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(e) => crash!(EXIT_ERR, "failed to parse argument {}: {}", pid, e),
|
Err(e) => {
|
||||||
|
return Err(USimpleError::new(
|
||||||
|
1,
|
||||||
|
format!("failed to parse argument {}: {}", pid, e),
|
||||||
|
));
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
status
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue