diff options
author | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
---|---|---|
committer | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
commit | e5888a1ffdae813d7575f5fb02275c6bb07e5199 (patch) | |
tree | d8d51eac403f07814b9e936eed0c9a79195e2450 /sys/src/cmd/aux/getflags.c |
Import sources from 2011-03-30 iso image
Diffstat (limited to 'sys/src/cmd/aux/getflags.c')
-rwxr-xr-x | sys/src/cmd/aux/getflags.c | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/sys/src/cmd/aux/getflags.c b/sys/src/cmd/aux/getflags.c new file mode 100755 index 000000000..407b73781 --- /dev/null +++ b/sys/src/cmd/aux/getflags.c @@ -0,0 +1,83 @@ +#include <u.h> +#include <libc.h> + +void +usage(void) +{ + print("status=usage\n"); + exits(0); +} + +char* +findarg(char *flags, Rune r) +{ + char *p; + Rune rr; + + for(p=flags; p!=(char*)1; p=strchr(p, ',')+1){ + chartorune(&rr, p); + if(rr == r) + return p; + } + return nil; +} + +int +countargs(char *p) +{ + int n; + + n = 1; + while(*p == ' ') + p++; + for(; *p && *p != ','; p++) + if(*p == ' ' && *(p-1) != ' ') + n++; + return n; +} + +void +main(int argc, char *argv[]) +{ + char *flags, *p, buf[512]; + int i, n; + Fmt fmt; + + doquote = needsrcquote; + quotefmtinstall(); + argv0 = argv[0]; /* for sysfatal */ + + flags = getenv("flagfmt"); + if(flags == nil){ + fprint(2, "$flagfmt not set\n"); + print("exit 'missing flagfmt'"); + exits(0); + } + + fmtfdinit(&fmt, 1, buf, sizeof buf); + for(p=flags; p!=(char*)1; p=strchr(p, ',')+1) + fmtprint(&fmt, "flag%.1s=()\n", p); + ARGBEGIN{ + default: + if((p = findarg(flags, ARGC())) == nil) + usage(); + p += runelen(ARGC()); + if(*p == ',' || *p == 0){ + fmtprint(&fmt, "flag%C=1\n", ARGC()); + break; + } + n = countargs(p); + fmtprint(&fmt, "flag%C=(", ARGC()); + for(i=0; i<n; i++) + fmtprint(&fmt, "%s%q", i ? " " : "", EARGF(usage())); + fmtprint(&fmt, ")\n"); + }ARGEND + + fmtprint(&fmt, "*=("); + for(i=0; i<argc; i++) + fmtprint(&fmt, "%s%q", i ? " " : "", argv[i]); + fmtprint(&fmt, ")\n"); + fmtprint(&fmt, "status=''\n"); + fmtfdflush(&fmt); + exits(0); +} |