]> git.saurik.com Git - bison.git/blobdiff - src/symlist.c
* data/glr.c (YYCHK1): Do not assume YYE is in range.
[bison.git] / src / symlist.c
index 8b61c8dcb5b6f97ab1917d1cf0cfa98311c7427b..106db46cb2f5f662f0fcd3937fc4fd8356334b8d 100644 (file)
@@ -1,5 +1,6 @@
 /* Lists of symbols for Bison
 /* Lists of symbols for Bison
-   Copyright (C) 2002  Free Software Foundation, Inc.
+
+   Copyright (C) 2002, 2005 Free Software Foundation, Inc.
 
    This file is part of Bison, the GNU Compiler Compiler.
 
 
    This file is part of Bison, the GNU Compiler Compiler.
 
 
    You should have received a copy of the GNU General Public License
    along with Bison; see the file COPYING.  If not, write to
 
    You should have received a copy of the GNU General Public License
    along with Bison; see the file COPYING.  If not, write to
-   the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-   Boston, MA 02111-1307, USA.  */
+   the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+   Boston, MA 02110-1301, USA.  */
 
 #include "system.h"
 
 #include "system.h"
+
 #include "complain.h"
 #include "symlist.h"
 
 
 #include "complain.h"
 #include "symlist.h"
 
 
-/*----------------------------------------------.
-| Create a list containing SYMBOL at LOCATION.  |
-`----------------------------------------------*/
+/*--------------------------------------.
+| Create a list containing SYM at LOC.  |
+`--------------------------------------*/
 
 
-symbol_list_t *
-symbol_list_new (symbol_t *sym, location_t location)
+symbol_list *
+symbol_list_new (symbol *sym, location loc)
 {
 {
-  symbol_list_t *res = XMALLOC (symbol_list_t, 1);
+  symbol_list *res = xmalloc (sizeof *res);
   res->next = NULL;
   res->sym = sym;
   res->next = NULL;
   res->sym = sym;
-  res->location = location;
+  res->location = loc;
   res->action = NULL;
   res->ruleprec = NULL;
   res->dprec = 0;
   res->action = NULL;
   res->ruleprec = NULL;
   res->dprec = 0;
@@ -42,15 +44,30 @@ symbol_list_new (symbol_t *sym, location_t location)
 }
 
 
 }
 
 
-/*-----------------------------------------.
-| Prepend SYMBOL at LOCATION to the LIST.  |
-`-----------------------------------------*/
+/*------------------.
+| Print this list.  |
+`------------------*/
+
+void
+symbol_list_print (symbol_list *l, FILE *f)
+{
+  for (/* Nothing. */; l && l->sym; l = l->next)
+    {
+      symbol_print (l->sym, f);
+      if (l && l->sym)
+       fputc (' ', f);
+    }
+}
+
+
+/*---------------------------------.
+| Prepend SYM at LOC to the LIST.  |
+`---------------------------------*/
 
 
-symbol_list_t *
-symbol_list_prepend (symbol_list_t *list,
-                    symbol_t *symbol, location_t location)
+symbol_list *
+symbol_list_prepend (symbol_list *list, symbol *sym, location loc)
 {
 {
-  symbol_list_t *res = symbol_list_new (symbol, location);
+  symbol_list *res = symbol_list_new (sym, loc);
   res->next = list;
   return res;
 }
   res->next = list;
   return res;
 }
@@ -61,9 +78,9 @@ symbol_list_prepend (symbol_list_t *list,
 `-------------------------------------------------*/
 
 void
 `-------------------------------------------------*/
 
 void
-symbol_list_free (symbol_list_t *list)
+symbol_list_free (symbol_list *list)
 {
 {
-  LIST_FREE (symbol_list_t, list);
+  LIST_FREE (symbol_list, list);
 }
 
 
 }
 
 
@@ -72,7 +89,7 @@ symbol_list_free (symbol_list_t *list)
 `--------------------*/
 
 unsigned int
 `--------------------*/
 
 unsigned int
-symbol_list_length (symbol_list_t *list)
+symbol_list_length (symbol_list *list)
 {
   int res = 0;
   for (/* Nothing. */; list; list = list->next)
 {
   int res = 0;
   for (/* Nothing. */; list; list = list->next)
@@ -83,22 +100,20 @@ symbol_list_length (symbol_list_t *list)
 
 /*--------------------------------------------------------------.
 | Get the data type (alternative in the union) of the value for |
 
 /*--------------------------------------------------------------.
 | Get the data type (alternative in the union) of the value for |
-| symbol N in rule RULE.                                        |
+| symbol N in symbol list RP.                                   |
 `--------------------------------------------------------------*/
 
 `--------------------------------------------------------------*/
 
-char *
-symbol_list_n_type_name_get (symbol_list_t *rule, location_t location, int n)
+uniqstr
+symbol_list_n_type_name_get (symbol_list *rp, location loc, int n)
 {
   int i;
 {
   int i;
-  symbol_list_t *rp;
 
   if (n < 0)
     {
 
   if (n < 0)
     {
-      complain_at (location, _("invalid $ value"));
+      complain_at (loc, _("invalid $ value: $%d"), n);
       return NULL;
     }
 
       return NULL;
     }
 
-  rp = rule;
   i = 0;
 
   while (i < n)
   i = 0;
 
   while (i < n)
@@ -106,7 +121,7 @@ symbol_list_n_type_name_get (symbol_list_t *rule, location_t location, int n)
       rp = rp->next;
       if (rp == NULL || rp->sym == NULL)
        {
       rp = rp->next;
       if (rp == NULL || rp->sym == NULL)
        {
-         complain_at (location, _("invalid $ value"));
+         complain_at (loc, _("invalid $ value: $%d"), n);
          return NULL;
        }
       ++i;
          return NULL;
        }
       ++i;