]> git.saurik.com Git - bison.git/commitdiff
Implement no-XXX arguments for --warnings, --report, --trace.
authorDi-an Jan <dianj@freeshell.org>
Fri, 21 Nov 2008 21:09:16 +0000 (13:09 -0800)
committerDi-an Jan <dianj@freeshell.org>
Fri, 21 Nov 2008 21:09:16 +0000 (13:09 -0800)
* src/getargs.c (flags_argmatch): Handles no-XXX.
Fix typo in doxygen comment.

ChangeLog
src/getargs.c

index aaaefcd508444cc55bd793dd4987f21c5b31ec43..7b3358caa55e8991e0573e6f6ae25e526014477c 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2008-11-21  Di-an Jan  <dianj@freeshell.org>
+
+       Implement no-XXX arguments for --warnings, --report, --trace.
+       * src/getargs.c (flags_argmatch): Handles no-XXX.
+       Fix typo in doxygen comment.
+
 2008-11-21  Akim Demaille  <demaille@gostai.com>
 
        Display the changes in cross-options.texi.
index aebc240128ae485c005dbd528b35429419b681c9..cff6ff3fecdb553d679d7e8ec3999eaedd4ac4a5 100644 (file)
@@ -87,10 +87,12 @@ char *program_name;
  *  \param keys     array of valid subarguments.
  *  \param values   array of corresponding (int) values.
  *  \param flags    the flags to update
- *  \param args     colon separated list of effective subarguments to decode.
+ *  \param args     comma separated list of effective subarguments to decode.
  *                  If 0, then activate all the flags.
  *
- *  The special value 0 resets the flags to 0.
+ *  If VALUE != 0 then KEY sets flags and no-KEY clears them.
+ *  If VALUE == 0 then KEY clears all flags and no-KEY sets all flags.
+ *  Thus no-none = all and no-all = none.
  */
 static void
 flags_argmatch (const char *option,
@@ -102,11 +104,18 @@ flags_argmatch (const char *option,
       args = strtok (args, ",");
       while (args)
        {
-         int value = XARGMATCH (option, args, keys, values);
+         int no = strncmp (args, "no-", 3) == 0 ? 3 : 0;
+         int value = XARGMATCH (option, args + no, keys, values);
          if (value == 0)
-           *flags = 0;
+           if (no)
+             *flags = ~0;
+           else
+             *flags = 0;
          else
-           *flags |= value;
+           if (no)
+             *flags &= ~value;
+           else
+             *flags |= value;
          args = strtok (NULL, ",");
        }
     }