diff options
author | Will Estes <wlestes@users.sourceforge.net> | 2007-05-12 13:11:57 +0000 |
---|---|---|
committer | Will Estes <wlestes@users.sourceforge.net> | 2007-05-12 13:11:57 +0000 |
commit | 1a5070a187380dedf3153843c38e2c536e7a9ee1 (patch) | |
tree | a1d9ab2c245e5f3f9b1860c2e10fe4a5af1d8309 | |
parent | fe229c623ffc20cc114dacd7813007d450d81c0a (diff) |
parse multiple short concatenated options; patch submitted by Petr Machata <pmachata@redhat.com
-rw-r--r-- | scanopt.c | 17 |
1 files changed, 10 insertions, 7 deletions
@@ -789,12 +789,12 @@ int scanopt (svoid, arg, optindex) } optarg = pstart + 1; - arglen = 0; - while (optarg[arglen]) - arglen++; - - if (arglen == 0) + if (!*optarg) { optarg = NULL; + arglen = 0; + } + else + arglen = strlen (optarg); } /* At this point, we have a long or short option matched at opt_offset into @@ -812,13 +812,16 @@ int scanopt (svoid, arg, optindex) /* case: no args allowed */ if (auxp->flags & ARG_NONE) { - if (optarg) { + if (optarg && !is_short) { scanopt_err (s, opt_offset, is_short, errcode = SCANOPT_ERR_ARG_NOT_ALLOWED); INC_INDEX (s, 1); return errcode; } - INC_INDEX (s, 1); + else if (!optarg) + INC_INDEX (s, 1); + else + s->subscript++; return optp->r_val; } |