diff options
author | Rob Landley <rob@landley.net> | 2013-06-22 15:36:25 -0500 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2013-06-22 15:36:25 -0500 |
commit | 4d3b3da2746f6b71b4f1f2649a800818e88a1b66 (patch) | |
tree | 760dc1ad532c3e40c93f5c111587ba9c2593f5a2 /lib/args.c | |
parent | 3a489e4f02f2003c972e5bdf7780266a5a495dd8 (diff) | |
download | toybox-4d3b3da2746f6b71b4f1f2649a800818e88a1b66.tar.gz toybox-4d3b3da2746f6b71b4f1f2649a800818e88a1b66.tar.bz2 toybox-4d3b3da2746f6b71b4f1f2649a800818e88a1b66.zip |
Option type @ counts number of occurrences, it doesn't take an argument.
Diffstat (limited to 'lib/args.c')
-rw-r--r-- | lib/args.c | 6 |
1 files changed, 4 insertions, 2 deletions
@@ -142,7 +142,9 @@ static int gotflag(struct getoptflagstate *gof, struct opts *opt) // Does this option take an argument? gof->arg++; type = opt->type; - if (type) { + + if (type == '@') ++*(opt->arg); + else if (type) { char *arg = gof->arg; // Handle "-xblah" and "-x blah", but also a third case: "abxc blah" @@ -176,7 +178,7 @@ static int gotflag(struct getoptflagstate *gof, struct opts *opt) error_exit("-%c < %lf", opt->c, (double)opt->val[0].f); if (opt->val[1].l != LONG_MAX && *f > opt->val[1].f) error_exit("-%c > %lf", opt->c, (double)opt->val[1].f); - } else if (type == '@') ++*(opt->arg); + } if (!gof->nodash_now) gof->arg = ""; } |