]>
git.saurik.com Git - bison.git/blob - src/state.c
1 /* Type definitions for nondeterministic finite state machine for bison,
2 Copyright (C) 2001, 2002 Free Software Foundation, Inc.
4 This file is part of Bison, the GNU Compiler Compiler.
6 Bison is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
11 Bison is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with Bison; see the file COPYING. If not, write to
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA. */
26 /*---------------------------------.
27 | Create a new array of N shitfs. |
28 `---------------------------------*/
30 #define SHIFTS_ALLOC(Nshifts) \
31 (shifts *) xcalloc ((unsigned) (sizeof (shifts) \
32 + (Nshifts - 1) * sizeof (short)), 1)
37 shifts
*res
= SHIFTS_ALLOC (n
);
43 /*-------------------------------.
44 | Create a new array of N errs. |
45 `-------------------------------*/
47 #define ERRS_ALLOC(Nerrs) \
48 (errs *) xcalloc ((unsigned) (sizeof (errs) \
49 + (Nerrs - 1) * sizeof (short)), 1)
55 errs
*res
= ERRS_ALLOC (n
);
64 errs
*res
= errs_new (src
->nerrs
);
65 memcpy (res
->errs
, src
->errs
, src
->nerrs
* sizeof (src
->errs
[0]));
69 /*-------------------------------------.
70 | Create a new array of N reductions. |
71 `-------------------------------------*/
73 #define REDUCTIONS_ALLOC(Nreductions) \
74 (reductions *) xcalloc ((unsigned) (sizeof (reductions) \
75 + (Nreductions - 1) * sizeof (short)), 1)
78 reductions_new (int n
)
80 reductions
*res
= REDUCTIONS_ALLOC (n
);
86 /*--------------------------------------------------------------.
87 | Print on OUT all the lookaheads such that this STATE wants to |
89 `--------------------------------------------------------------*/
92 state_rule_lookaheads_print (state_t
*state
, rule_t
*rule
, FILE *out
)
96 /* Count the number of lookaheads corresponding to this rule. */
97 for (j
= 0; j
< state
->nlookaheads
; ++j
)
98 for (k
= 0; k
< ntokens
; ++k
)
99 if (bitset_test (state
->lookaheads
[j
], k
)
100 && state
->lookaheads_rule
[j
]->number
== rule
->number
)
103 /* Print them if there are. */
107 for (j
= 0; j
< state
->nlookaheads
; ++j
)
108 for (k
= 0; k
< ntokens
; ++k
)
109 if (bitset_test (state
->lookaheads
[j
], k
)
110 && state
->lookaheads_rule
[j
]->number
== rule
->number
)
111 fprintf (out
, "%s%s",
112 symbol_tag_get (symbols
[k
]),
113 --nlookaheads
? ", " : "");