diff options
| author | Mike Vink <mike@pionative.com> | 2025-01-19 14:03:13 +0100 |
|---|---|---|
| committer | Mike Vink <mike@pionative.com> | 2025-01-19 14:03:13 +0100 |
| commit | 883055eb4182cdb8ebf784a2171771de7334f95e (patch) | |
| tree | f909a2c824a21050ce510b9603ba881a34167d66 /mut/tabbed/arg.h | |
| parent | 6d83cc53aa950a8f8e6c8fbabdda8abddebea027 (diff) | |
| parent | a481aa1ad86e16dcf3083734696bae29b5fd8ebb (diff) | |
Merge commit 'a481aa1ad86e16dcf3083734696bae29b5fd8ebb' as 'mut/tabbed'
Diffstat (limited to 'mut/tabbed/arg.h')
| -rw-r--r-- | mut/tabbed/arg.h | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/mut/tabbed/arg.h b/mut/tabbed/arg.h new file mode 100644 index 0000000..ba3fb3f --- /dev/null +++ b/mut/tabbed/arg.h @@ -0,0 +1,48 @@ +/* + * Copy me if you can. + * by 20h + */ + +#ifndef ARG_H__ +#define ARG_H__ + +extern char *argv0; + +/* use main(int argc, char *argv[]) */ +#define ARGBEGIN for (argv0 = *argv, argv++, argc--;\ + argv[0] && argv[0][0] == '-'\ + && argv[0][1];\ + argc--, argv++) {\ + char argc_;\ + char **argv_;\ + int brk_;\ + if (argv[0][1] == '-' && argv[0][2] == '\0') {\ + argv++;\ + argc--;\ + break;\ + }\ + for (brk_ = 0, argv[0]++, argv_ = argv;\ + argv[0][0] && !brk_;\ + argv[0]++) {\ + if (argv_ != argv)\ + break;\ + argc_ = argv[0][0];\ + switch (argc_) +#define ARGEND }\ + } + +#define ARGC() argc_ + +#define EARGF(x) ((argv[0][1] == '\0' && argv[1] == NULL)?\ + ((x), abort(), (char *)0) :\ + (brk_ = 1, (argv[0][1] != '\0')?\ + (&argv[0][1]) :\ + (argc--, argv++, argv[0]))) + +#define ARGF() ((argv[0][1] == '\0' && argv[1] == NULL)?\ + (char *)0 :\ + (brk_ = 1, (argv[0][1] != '\0')?\ + (&argv[0][1]) :\ + (argc--, argv++, argv[0]))) + +#endif |
