]> git.saurik.com Git - bison.git/commitdiff
* NEWS: Improve wording for unused-value warnings.
authorPaul Eggert <eggert@cs.ucla.edu>
Fri, 23 Dec 2005 00:13:11 +0000 (00:13 +0000)
committerPaul Eggert <eggert@cs.ucla.edu>
Fri, 23 Dec 2005 00:13:11 +0000 (00:13 +0000)
ChangeLog
NEWS

index 6b584a2d3729285b51525bea95df265be8a24c55..78f9344fced938ee73c9b94483ecc45c11bff79f 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2005-12-22  Paul Eggert  <eggert@cs.ucla.edu>
+
+       * NEWS: Improve wording for unused-value warnings.
+
 2005-12-22  Akim Demaille  <akim@epita.fr>
 
        * data/lalr1.cc, data/yacc.c, data/glr.c, data/c.m4
@@ -8,7 +12,7 @@
 
 2005-12-22  Akim Demaille  <akim@epita.fr>
 
-       Warn about unused values.
+       * NEWS: Warn about unused values.
        * src/symlist.h, src/symlist.c (symbol_list, symbol_list_new): Add
        a `used' member.
        (symbol_list_n_get, symbol_list_n_used_set): New.
diff --git a/NEWS b/NEWS
index 94e9cc17cfe181f07df0734bb9e78a64b3f87273..176ce6f27df09ec78e2954172852b64eeade8674 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -5,21 +5,29 @@ Changes in version 2.1a:
 
 * New warning: unused values
   Typed right-hand side symbols whose value are not used are reported.
-  For instance
+  For instance:
 
-       exp: exp "?" exp ":" exp { $$ = $1 + $3; }
-          | exp "+" exp
-         ;
+     exp: exp "?" exp ":" exp { $$ = $1 ? $1 : $3; }
+       | exp "+" exp
+       ;
 
   will trigger a warning about $5 of the first rule, and $3 in the
-  second ($1 is copied to $$ by the default rule).  To avoid this
-  warning, let Bison believe the value is used, e.g.
+  second ($1 is copied to $$ by the default rule).  This example
+  most likely contains two errors, and should be rewritten as:
+
+     exp: exp "?" exp ":" exp { $$ = $1 ? $3 : $5; }
+       | exp "+" exp         { $$ = $1 + $3; }
+       ;
+
+  However, if the original actions were really intended, the warnings
+  can be suppressed by letting Bison believe the values are used, e.g.:
 
-       exp: exp "?" exp ":" exp { $$ = $1 + $3; $5; }
-          | exp "+" exp         { $$ = $1; $3; }
+     exp: exp "?" exp ":" exp { $$ = $1 ? $1 : $3; (void) $5; }
+       | exp "+" exp         { $$ = $1; (void) $3; }
+       ;
 
-  This helps catching lost values and memory leaks: if a value is
-  ignored, its associated memory will never be reclaimed.
+  The warning is intended to help catching lost values and memory leaks.
+  If a value is ignored, its associated memory typically is not reclaimed.
 
 * %destructor vs. YYABORT, YYACCEPT, and YYERROR.
   Destructors are now called when user code invokes YYABORT, YYACCEPT,