forked from bonsai/harakit
fop(1): made checking argv better
This commit is contained in:
parent
cb12a5b8fc
commit
f89a686d3c
26
src/fop.rs
26
src/fop.rs
@ -28,30 +28,20 @@ use sysexits::{ EX_DATAERR, EX_USAGE };
|
|||||||
fn main() {
|
fn main() {
|
||||||
let argv = args().collect::<Vec<String>>();
|
let argv = args().collect::<Vec<String>>();
|
||||||
|
|
||||||
let usage = format!("Usage: {} index command [args...]", argv[0]);
|
argv.get(2).unwrap_or_else(|| {
|
||||||
|
eprintln!("Usage: {} index command [args...]", argv[0]);
|
||||||
|
exit(EX_USAGE);
|
||||||
|
});
|
||||||
|
|
||||||
let index = match argv.get(1) {
|
let index = argv[1].parse::<usize>().unwrap_or_else(|_| {
|
||||||
Some(i) => {
|
eprintln!("{}: {}: Not an integer.", argv[0], argv[1]);
|
||||||
i.parse::<usize>().unwrap_or_else(|_| {
|
exit(EX_DATAERR);
|
||||||
eprintln!("{}: {}: Not an integer.", argv[0], i);
|
});
|
||||||
exit(1);
|
|
||||||
})
|
|
||||||
},
|
|
||||||
None => {
|
|
||||||
eprintln!("{}", usage);
|
|
||||||
exit(EX_USAGE);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
let mut buf = String::new();
|
let mut buf = String::new();
|
||||||
stdin().read_line(&mut buf).unwrap();
|
stdin().read_line(&mut buf).unwrap();
|
||||||
let mut fields = buf.split('␞').collect::<Vec<&str>>();
|
let mut fields = buf.split('␞').collect::<Vec<&str>>();
|
||||||
|
|
||||||
argv.get(2).unwrap_or_else(|| {
|
|
||||||
eprintln!("{}", usage);
|
|
||||||
exit(EX_USAGE);
|
|
||||||
});
|
|
||||||
|
|
||||||
let opts = argv.iter().clone().skip(3).collect::<Vec<&String>>();
|
let opts = argv.iter().clone().skip(3).collect::<Vec<&String>>();
|
||||||
|
|
||||||
let mut spawned = Command::new(argv.get(2).unwrap())
|
let mut spawned = Command::new(argv.get(2).unwrap())
|
||||||
|
Loading…
Reference in New Issue
Block a user