From 26bf9e642eba4ea00cdf736d7ac4cd6be095a6af Mon Sep 17 00:00:00 2001 From: Rob Landley Date: Tue, 12 Feb 2008 17:36:13 -0600 Subject: Add toys.optc, an argv-style count for toys.optargs. --- lib/args.c | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) (limited to 'lib') diff --git a/lib/args.c b/lib/args.c index 96e1e6d3..2391daa3 100644 --- a/lib/args.c +++ b/lib/args.c @@ -66,15 +66,13 @@ struct opts { long *arg; }; -struct getoptflagstate +static struct getoptflagstate { int argc; char *arg; struct opts *opts, *this; int noerror, nodash_now; -}; - -static struct getoptflagstate gof; +} gof; static void gotflag(void) { @@ -123,7 +121,7 @@ static void gotflag(void) void get_optflags(void) { - int stopearly = 0, optarg = 0, nodash = 0, minargs = 0, maxargs; + int stopearly = 0, nodash = 0, minargs = 0, maxargs; struct longopts { struct longopts *next; struct opts *opt; @@ -293,13 +291,13 @@ void get_optflags(void) // Not a flag, save value in toys.optargs[] notflag: if (stopearly) stopearly++; - toys.optargs[optarg++] = toys.argv[gof.argc]; + toys.optargs[toys.optc++] = toys.argv[gof.argc]; } // Sanity check - if (optargmaxargs) + if (toys.optc>maxargs) error_exit("Max %d argument%s", maxargs, maxargs ? "s" : ""); if (CFG_HELP) toys.exithelp = 0; } -- cgit v1.2.3