]> 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)
committerJoel E. Denny <joeldenny@joeldenny.org>
Sun, 27 Mar 2011 19:07:48 +0000 (15:07 -0400)
* src/getargs.c (flags_argmatch): Handles no-XXX.
Fix typo in doxygen comment.
(cherry picked from commit 4182a0a18681fe4808f474441d62c5d2489e24e4)

ChangeLog
src/getargs.c

index 53dfb150f88bfb0e5125ef70de787874d18a75bb..97c0906ddf0778acd20bce0e370512aecdae7b93 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.
+
 2011-03-20  Joel E. Denny  <joeldenny@joeldenny.org>
 
        doc: fix confusing citation of LAC publication.
 2011-03-20  Joel E. Denny  <joeldenny@joeldenny.org>
 
        doc: fix confusing citation of LAC publication.
index 2408550c2eeaf888b5f65feaf814f3e2ef5bc4c8..d65cfc0941ab8d65d9906b7260e1f04de6c3bc41 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 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.
  *
  *                  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,
  */
 static void
 flags_argmatch (const char *option,
@@ -102,11 +104,18 @@ flags_argmatch (const char *option,
       args = strtok (args, ",");
       while (args)
        {
       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)
          if (value == 0)
-           *flags = 0;
+           if (no)
+             *flags = ~0;
+           else
+             *flags = 0;
          else
          else
-           *flags |= value;
+           if (no)
+             *flags &= ~value;
+           else
+             *flags |= value;
          args = strtok (NULL, ",");
        }
     }
          args = strtok (NULL, ",");
        }
     }