Compare commits
2 Commits
d0527ea349
...
f3893c4da1
Author | SHA1 | Date | |
---|---|---|---|
f3893c4da1 | |||
b1f90eff11 |
@ -1,2 +1,4 @@
|
|||||||
retval: retval.c
|
RUSTC = rustc
|
||||||
$(CC) -o retval retval.c
|
|
||||||
|
retval: retval.rs
|
||||||
|
$(RUSTC) $(RUSTCFLAGS) -o retval retval.rs
|
||||||
|
@ -3,21 +3,22 @@
|
|||||||
#include <stdlib.h> /* strtol(3) */
|
#include <stdlib.h> /* strtol(3) */
|
||||||
#include <sysexits.h> /* EX_USAGE */
|
#include <sysexits.h> /* EX_USAGE */
|
||||||
|
|
||||||
static char *program_name = "retval";
|
int usage(char *s){
|
||||||
|
fprintf(stderr, "Usage: %s [status]\n", s == NULL ? "retval" : s);
|
||||||
|
return EX_USAGE;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[]){
|
int main(int argc, char *argv[]){
|
||||||
unsigned int s;
|
|
||||||
|
|
||||||
if(argc < 2)
|
switch(argc){
|
||||||
goto usage;
|
case 2: { unsigned int s;
|
||||||
|
errno = 0;
|
||||||
errno = 0;
|
s = strtol(argv[1], &argv[1], 10);
|
||||||
s = strtol(argv[1], &argv[1], 10);
|
if(*argv[1] != '\0' || errno != 0){
|
||||||
if(*argv[1] != '\0' || errno != 0){
|
return usage(argv[0]);
|
||||||
usage: fprintf(stderr, "Usage: %s [status]\n",
|
}
|
||||||
argv[0] == NULL ? program_name : argv[0]);
|
return s;
|
||||||
return EX_USAGE;
|
}
|
||||||
|
default: return usage(argv[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return s;
|
|
||||||
}
|
}
|
||||||
|
18
retval/retval.rs
Normal file
18
retval/retval.rs
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
use std::{env::args, process::ExitCode};
|
||||||
|
|
||||||
|
fn usage(s: &str) -> ExitCode {
|
||||||
|
eprintln!("Usage: {} [status]", s);
|
||||||
|
ExitCode::from(64 /* NetBSD sysexits(3) EX_USAGE */)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() -> ExitCode {
|
||||||
|
let argv = args().collect::<Vec<String>>();
|
||||||
|
|
||||||
|
match argv.len() {
|
||||||
|
2 => match argv[1].parse::<u8>() {
|
||||||
|
Ok(e) => ExitCode::from(e),
|
||||||
|
_ => usage(&argv[0]),
|
||||||
|
},
|
||||||
|
_ => usage(&argv[0]),
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user