OSDN Git Service

Fix bug reported by Ashwini Sharma: [-abc] syntax to switch off a command forget
authorRob Landley <rob@landley.net>
Fri, 15 Aug 2014 23:53:01 +0000 (18:53 -0500)
committerRob Landley <rob@landley.net>
Fri, 15 Aug 2014 23:53:01 +0000 (18:53 -0500)
s _all_ saved command line arguments in GLOBALS(), not just for the command bein
g dropped.

lib/args.c

index 16eb48a..d0b483a 100644 (file)
@@ -138,15 +138,18 @@ static int gotflag(struct getoptflagstate *gof, struct opts *opt)
     error_exit("Unknown option %s", gof->arg);
   }
 
-  // Set flags
+  // Might enabling this switch off something else?
   if (toys.optflags & opt->dex[0]) {
     struct opts *clr;
     unsigned i = 1;
 
+    // Forget saved argument for flag we switch back off
     for (clr=gof->opts, i=1; clr; clr = clr->next, i<<=1)
-      if (clr->arg && (i & toys.optflags)) *clr->arg = 0;
+      if (clr->arg && (i & toys.optflags & opt->dex[0])) *clr->arg = 0;
     toys.optflags &= ~opt->dex[0];
   }
+
+  // Set flags
   toys.optflags |= opt->dex[1];
   gof->excludes |= opt->dex[2];
   if (opt->flags&2) gof->stopearly=2;