fop(1): uses new sysexits

This commit is contained in:
Emma Tebibyte 2024-08-23 14:22:11 -06:00
parent 1fffd3df52
commit 928dce0234
Signed by: emma
GPG Key ID: 06FA419A1698C270

View File

@ -38,7 +38,7 @@ fn err(argv0: &String, e: Error) {
eprintln!("{}: {}", argv0, e.strerror()); eprintln!("{}: {}", argv0, e.strerror());
} }
fn usage(argv0: &String) -> i32 { fn usage(argv0: &String) -> u8 {
eprintln!("Usage: {} [-d delimiter] index command [args...]", argv0); eprintln!("Usage: {} [-d delimiter] index command [args...]", argv0);
EX_USAGE EX_USAGE
} }
@ -52,7 +52,7 @@ fn main() -> ExitCode {
let promises = Promises::new("stdio proc exec"); let promises = Promises::new("stdio proc exec");
if let Err(e) = pledge(Some(promises), None) { if let Err(e) = pledge(Some(promises), None) {
err(&argv[0], e); err(&argv[0], e);
exit(EX_OSERR); return ExitCode::from(EX_OSERR);
} }
} }
@ -64,7 +64,7 @@ fn main() -> ExitCode {
optind = opt.ind(); optind = opt.ind();
}, },
_ => { _ => {
return ExitCode::from(usage(&argv[0]) as u8); return ExitCode::from(usage(&argv[0]));
} }
}; };
} }
@ -72,7 +72,7 @@ fn main() -> ExitCode {
/* parse the specified index as a number we can use */ /* parse the specified index as a number we can use */
let index = argv[optind].parse::<usize>().unwrap_or_else(|e| { let index = argv[optind].parse::<usize>().unwrap_or_else(|e| {
eprintln!("{}: {}: {}", argv[0], argv[1], e); eprintln!("{}: {}: {}", argv[0], argv[1], e);
exit(EX_DATAERR); exit(EX_DATAERR as i32);
}); });
/* index of the argv[0] for the operator command */ /* index of the argv[0] for the operator command */
@ -80,14 +80,14 @@ fn main() -> ExitCode {
/* argv[0] of the operator command */ /* argv[0] of the operator command */
let operator = argv.get(command_arg).unwrap_or_else(|| { let operator = argv.get(command_arg).unwrap_or_else(|| {
exit(usage(&argv[0])); exit(usage(&argv[0]) as i32);
}); });
/* read entire standard input into memory */ /* read entire standard input into memory */
let mut buf = String::new(); let mut buf = String::new();
if let Err(e) = stdin().read_to_string(&mut buf) { if let Err(e) = stdin().read_to_string(&mut buf) {
err(&argv[0], e); err(&argv[0], e);
exit(EX_IOERR); exit(EX_IOERR as i32);
}; };
/* split the buffer by the delimiter (by default, '\u{1E}') */ /* split the buffer by the delimiter (by default, '\u{1E}') */
@ -108,13 +108,13 @@ fn main() -> ExitCode {
.spawn() .spawn()
.unwrap_or_else( |e| { .unwrap_or_else( |e| {
err(&argv[0], e); err(&argv[0], e);
exit(EX_UNAVAILABLE); exit(EX_UNAVAILABLE as i32);
}); });
/* get field we want to pipe into spawned program */ /* get field we want to pipe into spawned program */
let field = fields.get(index).unwrap_or_else(|| { let field = fields.get(index).unwrap_or_else(|| {
eprintln!("{}: {}: no such index in input", argv[0], index); eprintln!("{}: {}: no such index in input", argv[0], index);
exit(EX_DATAERR); exit(EX_DATAERR as i32);
}); });
/* get the stdin of the newly spawned program and feed it the field val */ /* get the stdin of the newly spawned program and feed it the field val */
@ -125,7 +125,7 @@ fn main() -> ExitCode {
let output = spawned.wait_with_output().unwrap_or_else(|e| { let output = spawned.wait_with_output().unwrap_or_else(|e| {
err(&argv[0], e); err(&argv[0], e);
exit(EX_IOERR); exit(EX_IOERR as i32);
}); });
/* get the output with which the original field will be replaced */ /* get the output with which the original field will be replaced */
@ -142,7 +142,7 @@ fn main() -> ExitCode {
/* convert the output of the program to UTF-8 */ /* convert the output of the program to UTF-8 */
let new_field = String::from_utf8(replace).unwrap_or_else(|e| { let new_field = String::from_utf8(replace).unwrap_or_else(|e| {
eprintln!("{}: {}", argv[0], e); eprintln!("{}: {}", argv[0], e);
exit(EX_IOERR); exit(EX_IOERR as i32);
}); });
/* store the new field in the old fields vector */ /* store the new field in the old fields vector */
@ -153,7 +153,7 @@ fn main() -> ExitCode {
fields.join(&d.to_string()).as_bytes() fields.join(&d.to_string()).as_bytes()
).unwrap_or_else(|e| { ).unwrap_or_else(|e| {
err(&argv[0], e); err(&argv[0], e);
exit(EX_IOERR); exit(EX_IOERR as i32);
}); });
ExitCode::SUCCESS ExitCode::SUCCESS