]> git.saurik.com Git - bison.git/blame - src/symlist.h
tests: link lib/libbison.a for gnulib.
[bison.git] / src / symlist.h
CommitLineData
56c47203 1/* Lists of symbols for Bison
e3921448 2
219c26ea 3 Copyright (C) 2002, 2005-2007, 2009-2010 Free Software Foundation,
98744608 4 Inc.
56c47203
AD
5
6 This file is part of Bison, the GNU Compiler Compiler.
7
f16b0819 8 This program is free software: you can redistribute it and/or modify
56c47203 9 it under the terms of the GNU General Public License as published by
f16b0819
PE
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
56c47203 12
f16b0819 13 This program is distributed in the hope that it will be useful,
56c47203
AD
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
f16b0819 19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
56c47203
AD
20
21#ifndef SYMLIST_H_
22# define SYMLIST_H_
23
56c47203 24# include "location.h"
7c0c6181 25# include "scan-code.h"
e3921448 26# include "symtab.h"
56c47203 27
affac613 28/* A list of symbols, used during the parsing to store the rules. */
e3921448 29typedef struct symbol_list
56c47203 30{
3be03b13 31 /**
12e35840 32 * Whether this node contains a symbol, a semantic type, a \c <*>, or a
3ebecc24 33 * \c <>.
3be03b13 34 */
12e35840
JD
35 enum {
36 SYMLIST_SYMBOL, SYMLIST_TYPE,
37 SYMLIST_DEFAULT_TAGGED, SYMLIST_DEFAULT_TAGLESS
38 } content_type;
3be03b13 39 union {
7c0c6181
JD
40 /**
41 * The symbol or \c NULL iff
42 * <tt>symbol_list::content_type = SYMLIST_SYMBOL</tt>.
43 */
3be03b13 44 symbol *sym;
7c0c6181
JD
45 /**
46 * The semantic type iff <tt>symbol_list::content_type = SYMLIST_TYPE</tt>.
47 */
3be03b13
JD
48 uniqstr type_name;
49 } content;
e3921448 50 location location;
56c47203 51
ffa4ba3a
JD
52 /* If this symbol is the generated lhs for a midrule but this is the rule in
53 whose rhs it appears, MIDRULE = a pointer to that midrule. */
6ec2c0f2 54 struct symbol_list *midrule;
84866159 55
ffa4ba3a
JD
56 /* If this symbol is the generated lhs for a midrule and this is that
57 midrule, MIDRULE_PARENT_RULE = a pointer to the rule in whose rhs it
58 appears, and MIDRULE_PARENT_RHS_INDEX = its rhs index (1-origin) in the
59 parent rule. */
60 struct symbol_list *midrule_parent_rule;
61 int midrule_parent_rhs_index;
62
f6857bbf
JD
63 /* The action is attached to the LHS of a rule, but action properties for
64 * each RHS are also stored here. */
65 code_props action_props;
affac613
AD
66
67 /* Precedence/associativity. */
e3921448 68 symbol *ruleprec;
676385e2
PH
69 int dprec;
70 int merger;
8ee5b538 71 location merger_declaration_location;
affac613
AD
72
73 /* The list. */
74 struct symbol_list *next;
e3921448 75} symbol_list;
56c47203
AD
76
77
3be03b13
JD
78/** Create a list containing \c sym at \c loc. */
79symbol_list *symbol_list_sym_new (symbol *sym, location loc);
56c47203 80
3be03b13
JD
81/** Create a list containing \c type_name at \c loc. */
82symbol_list *symbol_list_type_new (uniqstr type_name, location loc);
867a3e00 83
12e35840
JD
84/** Create a list containing a \c <*> at \c loc. */
85symbol_list *symbol_list_default_tagged_new (location loc);
3ebecc24 86/** Create a list containing a \c <> at \c loc. */
12e35840 87symbol_list *symbol_list_default_tagless_new (location loc);
56c47203 88
3be03b13 89/** Print this list.
56c47203 90
3be03b13
JD
91 \pre For every node \c n in the list, <tt>n->content_type =
92 SYMLIST_SYMBOL</tt>. */
93void symbol_list_syms_print (const symbol_list *l, FILE *f);
94
95/** Prepend \c node to \c list. */
96symbol_list *symbol_list_prepend (symbol_list *list, symbol_list *node);
97
98/** Free \c list, but not the items it contains. */
99void symbol_list_free (symbol_list *list);
100
101/** Return the length of \c l. */
b37acfe1 102int symbol_list_length (symbol_list const *l);
affac613 103
3be03b13 104/** Get item \c n in symbol list \c l. */
affac613 105symbol_list *symbol_list_n_get (symbol_list *l, int n);
56c47203
AD
106
107/* Get the data type (alternative in the union) of the value for
108 symbol N in rule RULE. */
affac613
AD
109uniqstr symbol_list_n_type_name_get (symbol_list *l, location loc, int n);
110
7c0c6181
JD
111/** Set the \c \%destructor for \c node as \c code at \c loc. */
112void symbol_list_destructor_set (symbol_list *node, char const *code,
3be03b13
JD
113 location loc);
114
7c0c6181
JD
115/** Set the \c \%printer for \c node as \c code at \c loc. */
116void symbol_list_printer_set (symbol_list *node, char const *code,
3be03b13
JD
117 location loc);
118
56c47203 119#endif /* !SYMLIST_H_ */