Merge tag 'firewire-updates' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee139...
[GitHub/exynos8895/android_kernel_samsung_universal8895.git] / scripts / dtc / dtc-parser.tab.c_shipped
1 /* A Bison parser, made by GNU Bison 2.4.3. */
2
3 /* Skeleton implementation for Bison's Yacc-like parsers in C
4
5 Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
6 2009, 2010 Free Software Foundation, Inc.
7
8 This program is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
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
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20
21 /* As a special exception, you may create a larger work that contains
22 part or all of the Bison parser skeleton and distribute that work
23 under terms of your choice, so long as that work isn't itself a
24 parser generator using the skeleton or a modified version thereof
25 as a parser skeleton. Alternatively, if you modify or redistribute
26 the parser skeleton itself, you may (at your option) remove this
27 special exception, which will cause the skeleton and the resulting
28 Bison output files to be licensed under the GNU General Public
29 License without this special exception.
30
31 This special exception was added by the Free Software Foundation in
32 version 2.2 of Bison. */
33
34 /* C LALR(1) parser skeleton written by Richard Stallman, by
35 simplifying the original so-called "semantic" parser. */
36
37 /* All symbols defined below should begin with yy or YY, to avoid
38 infringing on user name space. This should be done even for local
39 variables, as they might otherwise be expanded by user macros.
40 There are some unavoidable exceptions within include files to
41 define necessary library symbols; they are noted "INFRINGES ON
42 USER NAME SPACE" below. */
43
44 /* Identify Bison output. */
45 #define YYBISON 1
46
47 /* Bison version. */
48 #define YYBISON_VERSION "2.4.3"
49
50 /* Skeleton name. */
51 #define YYSKELETON_NAME "yacc.c"
52
53 /* Pure parsers. */
54 #define YYPURE 0
55
56 /* Push parsers. */
57 #define YYPUSH 0
58
59 /* Pull parsers. */
60 #define YYPULL 1
61
62 /* Using locations. */
63 #define YYLSP_NEEDED 0
64
65
66
67 /* Copy the first part of user declarations. */
68
69
70 #include <stdio.h>
71
72 #include "dtc.h"
73 #include "srcpos.h"
74
75 YYLTYPE yylloc;
76
77 extern int yylex(void);
78 extern void print_error(char const *fmt, ...);
79 extern void yyerror(char const *s);
80
81 extern struct boot_info *the_boot_info;
82 extern int treesource_error;
83
84 static unsigned long long eval_literal(const char *s, int base, int bits);
85
86
87
88 /* Enabling traces. */
89 #ifndef YYDEBUG
90 # define YYDEBUG 1
91 #endif
92
93 /* Enabling verbose error messages. */
94 #ifdef YYERROR_VERBOSE
95 # undef YYERROR_VERBOSE
96 # define YYERROR_VERBOSE 1
97 #else
98 # define YYERROR_VERBOSE 0
99 #endif
100
101 /* Enabling the token table. */
102 #ifndef YYTOKEN_TABLE
103 # define YYTOKEN_TABLE 0
104 #endif
105
106
107 /* Tokens. */
108 #ifndef YYTOKENTYPE
109 # define YYTOKENTYPE
110 /* Put the tokens into the symbol table, so that GDB and other debuggers
111 know about them. */
112 enum yytokentype {
113 DT_V1 = 258,
114 DT_MEMRESERVE = 259,
115 DT_PROPNODENAME = 260,
116 DT_LITERAL = 261,
117 DT_BASE = 262,
118 DT_BYTE = 263,
119 DT_STRING = 264,
120 DT_LABEL = 265,
121 DT_REF = 266,
122 DT_INCBIN = 267
123 };
124 #endif
125
126
127
128 #if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
129 typedef union YYSTYPE
130 {
131
132
133 char *propnodename;
134 char *literal;
135 char *labelref;
136 unsigned int cbase;
137 uint8_t byte;
138 struct data data;
139
140 uint64_t addr;
141 cell_t cell;
142 struct property *prop;
143 struct property *proplist;
144 struct node *node;
145 struct node *nodelist;
146 struct reserve_info *re;
147
148
149
150 } YYSTYPE;
151 # define YYSTYPE_IS_TRIVIAL 1
152 # define yystype YYSTYPE /* obsolescent; will be withdrawn */
153 # define YYSTYPE_IS_DECLARED 1
154 #endif
155
156
157 /* Copy the second part of user declarations. */
158
159
160
161 #ifdef short
162 # undef short
163 #endif
164
165 #ifdef YYTYPE_UINT8
166 typedef YYTYPE_UINT8 yytype_uint8;
167 #else
168 typedef unsigned char yytype_uint8;
169 #endif
170
171 #ifdef YYTYPE_INT8
172 typedef YYTYPE_INT8 yytype_int8;
173 #elif (defined __STDC__ || defined __C99__FUNC__ \
174 || defined __cplusplus || defined _MSC_VER)
175 typedef signed char yytype_int8;
176 #else
177 typedef short int yytype_int8;
178 #endif
179
180 #ifdef YYTYPE_UINT16
181 typedef YYTYPE_UINT16 yytype_uint16;
182 #else
183 typedef unsigned short int yytype_uint16;
184 #endif
185
186 #ifdef YYTYPE_INT16
187 typedef YYTYPE_INT16 yytype_int16;
188 #else
189 typedef short int yytype_int16;
190 #endif
191
192 #ifndef YYSIZE_T
193 # ifdef __SIZE_TYPE__
194 # define YYSIZE_T __SIZE_TYPE__
195 # elif defined size_t
196 # define YYSIZE_T size_t
197 # elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \
198 || defined __cplusplus || defined _MSC_VER)
199 # include <stddef.h> /* INFRINGES ON USER NAME SPACE */
200 # define YYSIZE_T size_t
201 # else
202 # define YYSIZE_T unsigned int
203 # endif
204 #endif
205
206 #define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
207
208 #ifndef YY_
209 # if defined YYENABLE_NLS && YYENABLE_NLS
210 # if ENABLE_NLS
211 # include <libintl.h> /* INFRINGES ON USER NAME SPACE */
212 # define YY_(msgid) dgettext ("bison-runtime", msgid)
213 # endif
214 # endif
215 # ifndef YY_
216 # define YY_(msgid) msgid
217 # endif
218 #endif
219
220 /* Suppress unused-variable warnings by "using" E. */
221 #if ! defined lint || defined __GNUC__
222 # define YYUSE(e) ((void) (e))
223 #else
224 # define YYUSE(e) /* empty */
225 #endif
226
227 /* Identity function, used to suppress warnings about constant conditions. */
228 #ifndef lint
229 # define YYID(n) (n)
230 #else
231 #if (defined __STDC__ || defined __C99__FUNC__ \
232 || defined __cplusplus || defined _MSC_VER)
233 static int
234 YYID (int yyi)
235 #else
236 static int
237 YYID (yyi)
238 int yyi;
239 #endif
240 {
241 return yyi;
242 }
243 #endif
244
245 #if ! defined yyoverflow || YYERROR_VERBOSE
246
247 /* The parser invokes alloca or malloc; define the necessary symbols. */
248
249 # ifdef YYSTACK_USE_ALLOCA
250 # if YYSTACK_USE_ALLOCA
251 # ifdef __GNUC__
252 # define YYSTACK_ALLOC __builtin_alloca
253 # elif defined __BUILTIN_VA_ARG_INCR
254 # include <alloca.h> /* INFRINGES ON USER NAME SPACE */
255 # elif defined _AIX
256 # define YYSTACK_ALLOC __alloca
257 # elif defined _MSC_VER
258 # include <malloc.h> /* INFRINGES ON USER NAME SPACE */
259 # define alloca _alloca
260 # else
261 # define YYSTACK_ALLOC alloca
262 # if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
263 || defined __cplusplus || defined _MSC_VER)
264 # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
265 # ifndef _STDLIB_H
266 # define _STDLIB_H 1
267 # endif
268 # endif
269 # endif
270 # endif
271 # endif
272
273 # ifdef YYSTACK_ALLOC
274 /* Pacify GCC's `empty if-body' warning. */
275 # define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0))
276 # ifndef YYSTACK_ALLOC_MAXIMUM
277 /* The OS might guarantee only one guard page at the bottom of the stack,
278 and a page size can be as small as 4096 bytes. So we cannot safely
279 invoke alloca (N) if N exceeds 4096. Use a slightly smaller number
280 to allow for a few compiler-allocated temporary stack slots. */
281 # define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
282 # endif
283 # else
284 # define YYSTACK_ALLOC YYMALLOC
285 # define YYSTACK_FREE YYFREE
286 # ifndef YYSTACK_ALLOC_MAXIMUM
287 # define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
288 # endif
289 # if (defined __cplusplus && ! defined _STDLIB_H \
290 && ! ((defined YYMALLOC || defined malloc) \
291 && (defined YYFREE || defined free)))
292 # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
293 # ifndef _STDLIB_H
294 # define _STDLIB_H 1
295 # endif
296 # endif
297 # ifndef YYMALLOC
298 # define YYMALLOC malloc
299 # if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
300 || defined __cplusplus || defined _MSC_VER)
301 void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */
302 # endif
303 # endif
304 # ifndef YYFREE
305 # define YYFREE free
306 # if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
307 || defined __cplusplus || defined _MSC_VER)
308 void free (void *); /* INFRINGES ON USER NAME SPACE */
309 # endif
310 # endif
311 # endif
312 #endif /* ! defined yyoverflow || YYERROR_VERBOSE */
313
314
315 #if (! defined yyoverflow \
316 && (! defined __cplusplus \
317 || (defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
318
319 /* A type that is properly aligned for any stack member. */
320 union yyalloc
321 {
322 yytype_int16 yyss_alloc;
323 YYSTYPE yyvs_alloc;
324 };
325
326 /* The size of the maximum gap between one aligned stack and the next. */
327 # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
328
329 /* The size of an array large to enough to hold all stacks, each with
330 N elements. */
331 # define YYSTACK_BYTES(N) \
332 ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \
333 + YYSTACK_GAP_MAXIMUM)
334
335 /* Copy COUNT objects from FROM to TO. The source and destination do
336 not overlap. */
337 # ifndef YYCOPY
338 # if defined __GNUC__ && 1 < __GNUC__
339 # define YYCOPY(To, From, Count) \
340 __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
341 # else
342 # define YYCOPY(To, From, Count) \
343 do \
344 { \
345 YYSIZE_T yyi; \
346 for (yyi = 0; yyi < (Count); yyi++) \
347 (To)[yyi] = (From)[yyi]; \
348 } \
349 while (YYID (0))
350 # endif
351 # endif
352
353 /* Relocate STACK from its old location to the new one. The
354 local variables YYSIZE and YYSTACKSIZE give the old and new number of
355 elements in the stack, and YYPTR gives the new location of the
356 stack. Advance YYPTR to a properly aligned location for the next
357 stack. */
358 # define YYSTACK_RELOCATE(Stack_alloc, Stack) \
359 do \
360 { \
361 YYSIZE_T yynewbytes; \
362 YYCOPY (&yyptr->Stack_alloc, Stack, yysize); \
363 Stack = &yyptr->Stack_alloc; \
364 yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
365 yyptr += yynewbytes / sizeof (*yyptr); \
366 } \
367 while (YYID (0))
368
369 #endif
370
371 /* YYFINAL -- State number of the termination state. */
372 #define YYFINAL 4
373 /* YYLAST -- Last index in YYTABLE. */
374 #define YYLAST 56
375
376 /* YYNTOKENS -- Number of terminals. */
377 #define YYNTOKENS 25
378 /* YYNNTS -- Number of nonterminals. */
379 #define YYNNTS 16
380 /* YYNRULES -- Number of rules. */
381 #define YYNRULES 39
382 /* YYNRULES -- Number of states. */
383 #define YYNSTATES 67
384
385 /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
386 #define YYUNDEFTOK 2
387 #define YYMAXUTOK 267
388
389 #define YYTRANSLATE(YYX) \
390 ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
391
392 /* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
393 static const yytype_uint8 yytranslate[] =
394 {
395 0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
396 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
397 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
398 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
399 22, 24, 2, 2, 23, 2, 2, 14, 2, 2,
400 2, 2, 2, 2, 2, 2, 2, 2, 2, 13,
401 18, 17, 19, 2, 2, 2, 2, 2, 2, 2,
402 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
403 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
404 2, 20, 2, 21, 2, 2, 2, 2, 2, 2,
405 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
406 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
407 2, 2, 2, 15, 2, 16, 2, 2, 2, 2,
408 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
409 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
410 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
411 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
412 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
413 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
414 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
415 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
416 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
417 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
418 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
419 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
420 2, 2, 2, 2, 2, 2, 1, 2, 3, 4,
421 5, 6, 7, 8, 9, 10, 11, 12
422 };
423
424 #if YYDEBUG
425 /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
426 YYRHS. */
427 static const yytype_uint8 yyprhs[] =
428 {
429 0, 0, 3, 8, 9, 12, 17, 20, 22, 25,
430 29, 33, 39, 40, 43, 48, 51, 54, 57, 62,
431 67, 70, 80, 86, 89, 90, 93, 96, 97, 100,
432 103, 106, 108, 109, 112, 115, 116, 119, 122, 125
433 };
434
435 /* YYRHS -- A `-1'-separated list of the rules' RHS. */
436 static const yytype_int8 yyrhs[] =
437 {
438 26, 0, -1, 3, 13, 27, 30, -1, -1, 28,
439 27, -1, 4, 29, 29, 13, -1, 10, 28, -1,
440 6, -1, 14, 31, -1, 30, 14, 31, -1, 30,
441 11, 31, -1, 15, 32, 39, 16, 13, -1, -1,
442 32, 33, -1, 5, 17, 34, 13, -1, 5, 13,
443 -1, 10, 33, -1, 35, 9, -1, 35, 18, 36,
444 19, -1, 35, 20, 38, 21, -1, 35, 11, -1,
445 35, 12, 22, 9, 23, 29, 23, 29, 24, -1,
446 35, 12, 22, 9, 24, -1, 34, 10, -1, -1,
447 34, 23, -1, 35, 10, -1, -1, 36, 37, -1,
448 36, 11, -1, 36, 10, -1, 6, -1, -1, 38,
449 8, -1, 38, 10, -1, -1, 40, 39, -1, 40,
450 33, -1, 5, 31, -1, 10, 40, -1
451 };
452
453 /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
454 static const yytype_uint16 yyrline[] =
455 {
456 0, 86, 86, 95, 98, 105, 109, 117, 124, 128,
457 132, 145, 153, 156, 163, 167, 171, 179, 183, 187,
458 191, 195, 212, 222, 230, 233, 237, 245, 248, 252,
459 257, 264, 272, 275, 279, 287, 290, 294, 302, 306
460 };
461 #endif
462
463 #if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE
464 /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
465 First, the terminals, then, starting at YYNTOKENS, nonterminals. */
466 static const char *const yytname[] =
467 {
468 "$end", "error", "$undefined", "DT_V1", "DT_MEMRESERVE",
469 "DT_PROPNODENAME", "DT_LITERAL", "DT_BASE", "DT_BYTE", "DT_STRING",
470 "DT_LABEL", "DT_REF", "DT_INCBIN", "';'", "'/'", "'{'", "'}'", "'='",
471 "'<'", "'>'", "'['", "']'", "'('", "','", "')'", "$accept", "sourcefile",
472 "memreserves", "memreserve", "addr", "devicetree", "nodedef", "proplist",
473 "propdef", "propdata", "propdataprefix", "celllist", "cellval",
474 "bytestring", "subnodes", "subnode", 0
475 };
476 #endif
477
478 # ifdef YYPRINT
479 /* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
480 token YYLEX-NUM. */
481 static const yytype_uint16 yytoknum[] =
482 {
483 0, 256, 257, 258, 259, 260, 261, 262, 263, 264,
484 265, 266, 267, 59, 47, 123, 125, 61, 60, 62,
485 91, 93, 40, 44, 41
486 };
487 # endif
488
489 /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
490 static const yytype_uint8 yyr1[] =
491 {
492 0, 25, 26, 27, 27, 28, 28, 29, 30, 30,
493 30, 31, 32, 32, 33, 33, 33, 34, 34, 34,
494 34, 34, 34, 34, 35, 35, 35, 36, 36, 36,
495 36, 37, 38, 38, 38, 39, 39, 39, 40, 40
496 };
497
498 /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
499 static const yytype_uint8 yyr2[] =
500 {
501 0, 2, 4, 0, 2, 4, 2, 1, 2, 3,
502 3, 5, 0, 2, 4, 2, 2, 2, 4, 4,
503 2, 9, 5, 2, 0, 2, 2, 0, 2, 2,
504 2, 1, 0, 2, 2, 0, 2, 2, 2, 2
505 };
506
507 /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
508 STATE-NUM when YYTABLE doesn't specify something else to do. Zero
509 means the default is an error. */
510 static const yytype_uint8 yydefact[] =
511 {
512 0, 0, 0, 3, 1, 0, 0, 0, 3, 7,
513 0, 6, 0, 2, 4, 0, 12, 8, 0, 0,
514 5, 35, 10, 9, 0, 0, 13, 0, 35, 15,
515 24, 38, 16, 39, 0, 37, 36, 0, 0, 11,
516 23, 14, 25, 17, 26, 20, 0, 27, 32, 0,
517 0, 0, 0, 31, 30, 29, 18, 28, 33, 34,
518 19, 0, 22, 0, 0, 0, 21
519 };
520
521 /* YYDEFGOTO[NTERM-NUM]. */
522 static const yytype_int8 yydefgoto[] =
523 {
524 -1, 2, 7, 8, 10, 13, 17, 21, 26, 37,
525 38, 50, 57, 51, 27, 28
526 };
527
528 /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
529 STATE-NUM. */
530 #define YYPACT_NINF -12
531 static const yytype_int8 yypact[] =
532 {
533 10, -11, 18, -1, -12, 22, -1, 15, -1, -12,
534 22, -12, 20, 1, -12, 17, -12, -12, 20, 20,
535 -12, 6, -12, -12, 21, 6, -12, 23, 6, -12,
536 -12, -12, -12, -12, 28, -12, -12, -6, 13, -12,
537 -12, -12, -12, -12, -12, -12, 24, -12, -12, 33,
538 -5, 0, -4, -12, -12, -12, -12, -12, -12, -12,
539 -12, 22, -12, 25, 22, 19, -12
540 };
541
542 /* YYPGOTO[NTERM-NUM]. */
543 static const yytype_int8 yypgoto[] =
544 {
545 -12, -12, 36, 39, -10, -12, 8, -12, 12, -12,
546 -12, -12, -12, -12, 27, 31
547 };
548
549 /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
550 positive, shift that token. If negative, reduce the rule which
551 number is the opposite. If zero, do what YYDEFACT says.
552 If YYTABLE_NINF, syntax error. */
553 #define YYTABLE_NINF -1
554 static const yytype_uint8 yytable[] =
555 {
556 15, 53, 3, 5, 40, 54, 55, 41, 58, 6,
557 59, 24, 18, 1, 56, 19, 25, 42, 4, 61,
558 62, 60, 43, 44, 45, 46, 22, 23, 9, 12,
559 20, 47, 31, 48, 29, 16, 16, 32, 30, 34,
560 35, 39, 52, 66, 14, 11, 49, 0, 64, 0,
561 0, 63, 0, 0, 65, 36, 33
562 };
563
564 static const yytype_int8 yycheck[] =
565 {
566 10, 6, 13, 4, 10, 10, 11, 13, 8, 10,
567 10, 5, 11, 3, 19, 14, 10, 23, 0, 23,
568 24, 21, 9, 10, 11, 12, 18, 19, 6, 14,
569 13, 18, 24, 20, 13, 15, 15, 25, 17, 16,
570 28, 13, 9, 24, 8, 6, 22, -1, 23, -1,
571 -1, 61, -1, -1, 64, 28, 25
572 };
573
574 /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
575 symbol of state STATE-NUM. */
576 static const yytype_uint8 yystos[] =
577 {
578 0, 3, 26, 13, 0, 4, 10, 27, 28, 6,
579 29, 28, 14, 30, 27, 29, 15, 31, 11, 14,
580 13, 32, 31, 31, 5, 10, 33, 39, 40, 13,
581 17, 31, 33, 40, 16, 33, 39, 34, 35, 13,
582 10, 13, 23, 9, 10, 11, 12, 18, 20, 22,
583 36, 38, 9, 6, 10, 11, 19, 37, 8, 10,
584 21, 23, 24, 29, 23, 29, 24
585 };
586
587 #define yyerrok (yyerrstatus = 0)
588 #define yyclearin (yychar = YYEMPTY)
589 #define YYEMPTY (-2)
590 #define YYEOF 0
591
592 #define YYACCEPT goto yyacceptlab
593 #define YYABORT goto yyabortlab
594 #define YYERROR goto yyerrorlab
595
596
597 /* Like YYERROR except do call yyerror. This remains here temporarily
598 to ease the transition to the new meaning of YYERROR, for GCC.
599 Once GCC version 2 has supplanted version 1, this can go. However,
600 YYFAIL appears to be in use. Nevertheless, it is formally deprecated
601 in Bison 2.4.2's NEWS entry, where a plan to phase it out is
602 discussed. */
603
604 #define YYFAIL goto yyerrlab
605 #if defined YYFAIL
606 /* This is here to suppress warnings from the GCC cpp's
607 -Wunused-macros. Normally we don't worry about that warning, but
608 some users do, and we want to make it easy for users to remove
609 YYFAIL uses, which will produce warnings from Bison 2.5. */
610 #endif
611
612 #define YYRECOVERING() (!!yyerrstatus)
613
614 #define YYBACKUP(Token, Value) \
615 do \
616 if (yychar == YYEMPTY && yylen == 1) \
617 { \
618 yychar = (Token); \
619 yylval = (Value); \
620 yytoken = YYTRANSLATE (yychar); \
621 YYPOPSTACK (1); \
622 goto yybackup; \
623 } \
624 else \
625 { \
626 yyerror (YY_("syntax error: cannot back up")); \
627 YYERROR; \
628 } \
629 while (YYID (0))
630
631
632 #define YYTERROR 1
633 #define YYERRCODE 256
634
635
636 /* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
637 If N is 0, then set CURRENT to the empty location which ends
638 the previous symbol: RHS[0] (always defined). */
639
640 #define YYRHSLOC(Rhs, K) ((Rhs)[K])
641 #ifndef YYLLOC_DEFAULT
642 # define YYLLOC_DEFAULT(Current, Rhs, N) \
643 do \
644 if (YYID (N)) \
645 { \
646 (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \
647 (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \
648 (Current).last_line = YYRHSLOC (Rhs, N).last_line; \
649 (Current).last_column = YYRHSLOC (Rhs, N).last_column; \
650 } \
651 else \
652 { \
653 (Current).first_line = (Current).last_line = \
654 YYRHSLOC (Rhs, 0).last_line; \
655 (Current).first_column = (Current).last_column = \
656 YYRHSLOC (Rhs, 0).last_column; \
657 } \
658 while (YYID (0))
659 #endif
660
661
662 /* YY_LOCATION_PRINT -- Print the location on the stream.
663 This macro was not mandated originally: define only if we know
664 we won't break user code: when these are the locations we know. */
665
666 #ifndef YY_LOCATION_PRINT
667 # if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL
668 # define YY_LOCATION_PRINT(File, Loc) \
669 fprintf (File, "%d.%d-%d.%d", \
670 (Loc).first_line, (Loc).first_column, \
671 (Loc).last_line, (Loc).last_column)
672 # else
673 # define YY_LOCATION_PRINT(File, Loc) ((void) 0)
674 # endif
675 #endif
676
677
678 /* YYLEX -- calling `yylex' with the right arguments. */
679
680 #ifdef YYLEX_PARAM
681 # define YYLEX yylex (YYLEX_PARAM)
682 #else
683 # define YYLEX yylex ()
684 #endif
685
686 /* Enable debugging if requested. */
687 #if YYDEBUG
688
689 # ifndef YYFPRINTF
690 # include <stdio.h> /* INFRINGES ON USER NAME SPACE */
691 # define YYFPRINTF fprintf
692 # endif
693
694 # define YYDPRINTF(Args) \
695 do { \
696 if (yydebug) \
697 YYFPRINTF Args; \
698 } while (YYID (0))
699
700 # define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
701 do { \
702 if (yydebug) \
703 { \
704 YYFPRINTF (stderr, "%s ", Title); \
705 yy_symbol_print (stderr, \
706 Type, Value); \
707 YYFPRINTF (stderr, "\n"); \
708 } \
709 } while (YYID (0))
710
711
712 /*--------------------------------.
713 | Print this symbol on YYOUTPUT. |
714 `--------------------------------*/
715
716 /*ARGSUSED*/
717 #if (defined __STDC__ || defined __C99__FUNC__ \
718 || defined __cplusplus || defined _MSC_VER)
719 static void
720 yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
721 #else
722 static void
723 yy_symbol_value_print (yyoutput, yytype, yyvaluep)
724 FILE *yyoutput;
725 int yytype;
726 YYSTYPE const * const yyvaluep;
727 #endif
728 {
729 if (!yyvaluep)
730 return;
731 # ifdef YYPRINT
732 if (yytype < YYNTOKENS)
733 YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
734 # else
735 YYUSE (yyoutput);
736 # endif
737 switch (yytype)
738 {
739 default:
740 break;
741 }
742 }
743
744
745 /*--------------------------------.
746 | Print this symbol on YYOUTPUT. |
747 `--------------------------------*/
748
749 #if (defined __STDC__ || defined __C99__FUNC__ \
750 || defined __cplusplus || defined _MSC_VER)
751 static void
752 yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
753 #else
754 static void
755 yy_symbol_print (yyoutput, yytype, yyvaluep)
756 FILE *yyoutput;
757 int yytype;
758 YYSTYPE const * const yyvaluep;
759 #endif
760 {
761 if (yytype < YYNTOKENS)
762 YYFPRINTF (yyoutput, "token %s (", yytname[yytype]);
763 else
764 YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]);
765
766 yy_symbol_value_print (yyoutput, yytype, yyvaluep);
767 YYFPRINTF (yyoutput, ")");
768 }
769
770 /*------------------------------------------------------------------.
771 | yy_stack_print -- Print the state stack from its BOTTOM up to its |
772 | TOP (included). |
773 `------------------------------------------------------------------*/
774
775 #if (defined __STDC__ || defined __C99__FUNC__ \
776 || defined __cplusplus || defined _MSC_VER)
777 static void
778 yy_stack_print (yytype_int16 *yybottom, yytype_int16 *yytop)
779 #else
780 static void
781 yy_stack_print (yybottom, yytop)
782 yytype_int16 *yybottom;
783 yytype_int16 *yytop;
784 #endif
785 {
786 YYFPRINTF (stderr, "Stack now");
787 for (; yybottom <= yytop; yybottom++)
788 {
789 int yybot = *yybottom;
790 YYFPRINTF (stderr, " %d", yybot);
791 }
792 YYFPRINTF (stderr, "\n");
793 }
794
795 # define YY_STACK_PRINT(Bottom, Top) \
796 do { \
797 if (yydebug) \
798 yy_stack_print ((Bottom), (Top)); \
799 } while (YYID (0))
800
801
802 /*------------------------------------------------.
803 | Report that the YYRULE is going to be reduced. |
804 `------------------------------------------------*/
805
806 #if (defined __STDC__ || defined __C99__FUNC__ \
807 || defined __cplusplus || defined _MSC_VER)
808 static void
809 yy_reduce_print (YYSTYPE *yyvsp, int yyrule)
810 #else
811 static void
812 yy_reduce_print (yyvsp, yyrule)
813 YYSTYPE *yyvsp;
814 int yyrule;
815 #endif
816 {
817 int yynrhs = yyr2[yyrule];
818 int yyi;
819 unsigned long int yylno = yyrline[yyrule];
820 YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n",
821 yyrule - 1, yylno);
822 /* The symbols being reduced. */
823 for (yyi = 0; yyi < yynrhs; yyi++)
824 {
825 YYFPRINTF (stderr, " $%d = ", yyi + 1);
826 yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi],
827 &(yyvsp[(yyi + 1) - (yynrhs)])
828 );
829 YYFPRINTF (stderr, "\n");
830 }
831 }
832
833 # define YY_REDUCE_PRINT(Rule) \
834 do { \
835 if (yydebug) \
836 yy_reduce_print (yyvsp, Rule); \
837 } while (YYID (0))
838
839 /* Nonzero means print parse trace. It is left uninitialized so that
840 multiple parsers can coexist. */
841 int yydebug;
842 #else /* !YYDEBUG */
843 # define YYDPRINTF(Args)
844 # define YY_SYMBOL_PRINT(Title, Type, Value, Location)
845 # define YY_STACK_PRINT(Bottom, Top)
846 # define YY_REDUCE_PRINT(Rule)
847 #endif /* !YYDEBUG */
848
849
850 /* YYINITDEPTH -- initial size of the parser's stacks. */
851 #ifndef YYINITDEPTH
852 # define YYINITDEPTH 200
853 #endif
854
855 /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
856 if the built-in stack extension method is used).
857
858 Do not make this value too large; the results are undefined if
859 YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
860 evaluated with infinite-precision integer arithmetic. */
861
862 #ifndef YYMAXDEPTH
863 # define YYMAXDEPTH 10000
864 #endif
865
866 \f
867
868 #if YYERROR_VERBOSE
869
870 # ifndef yystrlen
871 # if defined __GLIBC__ && defined _STRING_H
872 # define yystrlen strlen
873 # else
874 /* Return the length of YYSTR. */
875 #if (defined __STDC__ || defined __C99__FUNC__ \
876 || defined __cplusplus || defined _MSC_VER)
877 static YYSIZE_T
878 yystrlen (const char *yystr)
879 #else
880 static YYSIZE_T
881 yystrlen (yystr)
882 const char *yystr;
883 #endif
884 {
885 YYSIZE_T yylen;
886 for (yylen = 0; yystr[yylen]; yylen++)
887 continue;
888 return yylen;
889 }
890 # endif
891 # endif
892
893 # ifndef yystpcpy
894 # if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
895 # define yystpcpy stpcpy
896 # else
897 /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
898 YYDEST. */
899 #if (defined __STDC__ || defined __C99__FUNC__ \
900 || defined __cplusplus || defined _MSC_VER)
901 static char *
902 yystpcpy (char *yydest, const char *yysrc)
903 #else
904 static char *
905 yystpcpy (yydest, yysrc)
906 char *yydest;
907 const char *yysrc;
908 #endif
909 {
910 char *yyd = yydest;
911 const char *yys = yysrc;
912
913 while ((*yyd++ = *yys++) != '\0')
914 continue;
915
916 return yyd - 1;
917 }
918 # endif
919 # endif
920
921 # ifndef yytnamerr
922 /* Copy to YYRES the contents of YYSTR after stripping away unnecessary
923 quotes and backslashes, so that it's suitable for yyerror. The
924 heuristic is that double-quoting is unnecessary unless the string
925 contains an apostrophe, a comma, or backslash (other than
926 backslash-backslash). YYSTR is taken from yytname. If YYRES is
927 null, do not copy; instead, return the length of what the result
928 would have been. */
929 static YYSIZE_T
930 yytnamerr (char *yyres, const char *yystr)
931 {
932 if (*yystr == '"')
933 {
934 YYSIZE_T yyn = 0;
935 char const *yyp = yystr;
936
937 for (;;)
938 switch (*++yyp)
939 {
940 case '\'':
941 case ',':
942 goto do_not_strip_quotes;
943
944 case '\\':
945 if (*++yyp != '\\')
946 goto do_not_strip_quotes;
947 /* Fall through. */
948 default:
949 if (yyres)
950 yyres[yyn] = *yyp;
951 yyn++;
952 break;
953
954 case '"':
955 if (yyres)
956 yyres[yyn] = '\0';
957 return yyn;
958 }
959 do_not_strip_quotes: ;
960 }
961
962 if (! yyres)
963 return yystrlen (yystr);
964
965 return yystpcpy (yyres, yystr) - yyres;
966 }
967 # endif
968
969 /* Copy into YYRESULT an error message about the unexpected token
970 YYCHAR while in state YYSTATE. Return the number of bytes copied,
971 including the terminating null byte. If YYRESULT is null, do not
972 copy anything; just return the number of bytes that would be
973 copied. As a special case, return 0 if an ordinary "syntax error"
974 message will do. Return YYSIZE_MAXIMUM if overflow occurs during
975 size calculation. */
976 static YYSIZE_T
977 yysyntax_error (char *yyresult, int yystate, int yychar)
978 {
979 int yyn = yypact[yystate];
980
981 if (! (YYPACT_NINF < yyn && yyn <= YYLAST))
982 return 0;
983 else
984 {
985 int yytype = YYTRANSLATE (yychar);
986 YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]);
987 YYSIZE_T yysize = yysize0;
988 YYSIZE_T yysize1;
989 int yysize_overflow = 0;
990 enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
991 char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
992 int yyx;
993
994 # if 0
995 /* This is so xgettext sees the translatable formats that are
996 constructed on the fly. */
997 YY_("syntax error, unexpected %s");
998 YY_("syntax error, unexpected %s, expecting %s");
999 YY_("syntax error, unexpected %s, expecting %s or %s");
1000 YY_("syntax error, unexpected %s, expecting %s or %s or %s");
1001 YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s");
1002 # endif
1003 char *yyfmt;
1004 char const *yyf;
1005 static char const yyunexpected[] = "syntax error, unexpected %s";
1006 static char const yyexpecting[] = ", expecting %s";
1007 static char const yyor[] = " or %s";
1008 char yyformat[sizeof yyunexpected
1009 + sizeof yyexpecting - 1
1010 + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2)
1011 * (sizeof yyor - 1))];
1012 char const *yyprefix = yyexpecting;
1013
1014 /* Start YYX at -YYN if negative to avoid negative indexes in
1015 YYCHECK. */
1016 int yyxbegin = yyn < 0 ? -yyn : 0;
1017
1018 /* Stay within bounds of both yycheck and yytname. */
1019 int yychecklim = YYLAST - yyn + 1;
1020 int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
1021 int yycount = 1;
1022
1023 yyarg[0] = yytname[yytype];
1024 yyfmt = yystpcpy (yyformat, yyunexpected);
1025
1026 for (yyx = yyxbegin; yyx < yyxend; ++yyx)
1027 if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
1028 {
1029 if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
1030 {
1031 yycount = 1;
1032 yysize = yysize0;
1033 yyformat[sizeof yyunexpected - 1] = '\0';
1034 break;
1035 }
1036 yyarg[yycount++] = yytname[yyx];
1037 yysize1 = yysize + yytnamerr (0, yytname[yyx]);
1038 yysize_overflow |= (yysize1 < yysize);
1039 yysize = yysize1;
1040 yyfmt = yystpcpy (yyfmt, yyprefix);
1041 yyprefix = yyor;
1042 }
1043
1044 yyf = YY_(yyformat);
1045 yysize1 = yysize + yystrlen (yyf);
1046 yysize_overflow |= (yysize1 < yysize);
1047 yysize = yysize1;
1048
1049 if (yysize_overflow)
1050 return YYSIZE_MAXIMUM;
1051
1052 if (yyresult)
1053 {
1054 /* Avoid sprintf, as that infringes on the user's name space.
1055 Don't have undefined behavior even if the translation
1056 produced a string with the wrong number of "%s"s. */
1057 char *yyp = yyresult;
1058 int yyi = 0;
1059 while ((*yyp = *yyf) != '\0')
1060 {
1061 if (*yyp == '%' && yyf[1] == 's' && yyi < yycount)
1062 {
1063 yyp += yytnamerr (yyp, yyarg[yyi++]);
1064 yyf += 2;
1065 }
1066 else
1067 {
1068 yyp++;
1069 yyf++;
1070 }
1071 }
1072 }
1073 return yysize;
1074 }
1075 }
1076 #endif /* YYERROR_VERBOSE */
1077 \f
1078
1079 /*-----------------------------------------------.
1080 | Release the memory associated to this symbol. |
1081 `-----------------------------------------------*/
1082
1083 /*ARGSUSED*/
1084 #if (defined __STDC__ || defined __C99__FUNC__ \
1085 || defined __cplusplus || defined _MSC_VER)
1086 static void
1087 yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep)
1088 #else
1089 static void
1090 yydestruct (yymsg, yytype, yyvaluep)
1091 const char *yymsg;
1092 int yytype;
1093 YYSTYPE *yyvaluep;
1094 #endif
1095 {
1096 YYUSE (yyvaluep);
1097
1098 if (!yymsg)
1099 yymsg = "Deleting";
1100 YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
1101
1102 switch (yytype)
1103 {
1104
1105 default:
1106 break;
1107 }
1108 }
1109
1110 /* Prevent warnings from -Wmissing-prototypes. */
1111 #ifdef YYPARSE_PARAM
1112 #if defined __STDC__ || defined __cplusplus
1113 int yyparse (void *YYPARSE_PARAM);
1114 #else
1115 int yyparse ();
1116 #endif
1117 #else /* ! YYPARSE_PARAM */
1118 #if defined __STDC__ || defined __cplusplus
1119 int yyparse (void);
1120 #else
1121 int yyparse ();
1122 #endif
1123 #endif /* ! YYPARSE_PARAM */
1124
1125
1126 /* The lookahead symbol. */
1127 int yychar;
1128
1129 /* The semantic value of the lookahead symbol. */
1130 YYSTYPE yylval;
1131
1132 /* Number of syntax errors so far. */
1133 int yynerrs;
1134
1135
1136
1137 /*-------------------------.
1138 | yyparse or yypush_parse. |
1139 `-------------------------*/
1140
1141 #ifdef YYPARSE_PARAM
1142 #if (defined __STDC__ || defined __C99__FUNC__ \
1143 || defined __cplusplus || defined _MSC_VER)
1144 int
1145 yyparse (void *YYPARSE_PARAM)
1146 #else
1147 int
1148 yyparse (YYPARSE_PARAM)
1149 void *YYPARSE_PARAM;
1150 #endif
1151 #else /* ! YYPARSE_PARAM */
1152 #if (defined __STDC__ || defined __C99__FUNC__ \
1153 || defined __cplusplus || defined _MSC_VER)
1154 int
1155 yyparse (void)
1156 #else
1157 int
1158 yyparse ()
1159
1160 #endif
1161 #endif
1162 {
1163
1164
1165 int yystate;
1166 /* Number of tokens to shift before error messages enabled. */
1167 int yyerrstatus;
1168
1169 /* The stacks and their tools:
1170 `yyss': related to states.
1171 `yyvs': related to semantic values.
1172
1173 Refer to the stacks thru separate pointers, to allow yyoverflow
1174 to reallocate them elsewhere. */
1175
1176 /* The state stack. */
1177 yytype_int16 yyssa[YYINITDEPTH];
1178 yytype_int16 *yyss;
1179 yytype_int16 *yyssp;
1180
1181 /* The semantic value stack. */
1182 YYSTYPE yyvsa[YYINITDEPTH];
1183 YYSTYPE *yyvs;
1184 YYSTYPE *yyvsp;
1185
1186 YYSIZE_T yystacksize;
1187
1188 int yyn;
1189 int yyresult;
1190 /* Lookahead token as an internal (translated) token number. */
1191 int yytoken;
1192 /* The variables used to return semantic value and location from the
1193 action routines. */
1194 YYSTYPE yyval;
1195
1196 #if YYERROR_VERBOSE
1197 /* Buffer for error messages, and its allocated size. */
1198 char yymsgbuf[128];
1199 char *yymsg = yymsgbuf;
1200 YYSIZE_T yymsg_alloc = sizeof yymsgbuf;
1201 #endif
1202
1203 #define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N))
1204
1205 /* The number of symbols on the RHS of the reduced rule.
1206 Keep to zero when no symbol should be popped. */
1207 int yylen = 0;
1208
1209 yytoken = 0;
1210 yyss = yyssa;
1211 yyvs = yyvsa;
1212 yystacksize = YYINITDEPTH;
1213
1214 YYDPRINTF ((stderr, "Starting parse\n"));
1215
1216 yystate = 0;
1217 yyerrstatus = 0;
1218 yynerrs = 0;
1219 yychar = YYEMPTY; /* Cause a token to be read. */
1220
1221 /* Initialize stack pointers.
1222 Waste one element of value and location stack
1223 so that they stay on the same level as the state stack.
1224 The wasted elements are never initialized. */
1225 yyssp = yyss;
1226 yyvsp = yyvs;
1227
1228 goto yysetstate;
1229
1230 /*------------------------------------------------------------.
1231 | yynewstate -- Push a new state, which is found in yystate. |
1232 `------------------------------------------------------------*/
1233 yynewstate:
1234 /* In all cases, when you get here, the value and location stacks
1235 have just been pushed. So pushing a state here evens the stacks. */
1236 yyssp++;
1237
1238 yysetstate:
1239 *yyssp = yystate;
1240
1241 if (yyss + yystacksize - 1 <= yyssp)
1242 {
1243 /* Get the current used size of the three stacks, in elements. */
1244 YYSIZE_T yysize = yyssp - yyss + 1;
1245
1246 #ifdef yyoverflow
1247 {
1248 /* Give user a chance to reallocate the stack. Use copies of
1249 these so that the &'s don't force the real ones into
1250 memory. */
1251 YYSTYPE *yyvs1 = yyvs;
1252 yytype_int16 *yyss1 = yyss;
1253
1254 /* Each stack pointer address is followed by the size of the
1255 data in use in that stack, in bytes. This used to be a
1256 conditional around just the two extra args, but that might
1257 be undefined if yyoverflow is a macro. */
1258 yyoverflow (YY_("memory exhausted"),
1259 &yyss1, yysize * sizeof (*yyssp),
1260 &yyvs1, yysize * sizeof (*yyvsp),
1261 &yystacksize);
1262
1263 yyss = yyss1;
1264 yyvs = yyvs1;
1265 }
1266 #else /* no yyoverflow */
1267 # ifndef YYSTACK_RELOCATE
1268 goto yyexhaustedlab;
1269 # else
1270 /* Extend the stack our own way. */
1271 if (YYMAXDEPTH <= yystacksize)
1272 goto yyexhaustedlab;
1273 yystacksize *= 2;
1274 if (YYMAXDEPTH < yystacksize)
1275 yystacksize = YYMAXDEPTH;
1276
1277 {
1278 yytype_int16 *yyss1 = yyss;
1279 union yyalloc *yyptr =
1280 (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
1281 if (! yyptr)
1282 goto yyexhaustedlab;
1283 YYSTACK_RELOCATE (yyss_alloc, yyss);
1284 YYSTACK_RELOCATE (yyvs_alloc, yyvs);
1285 # undef YYSTACK_RELOCATE
1286 if (yyss1 != yyssa)
1287 YYSTACK_FREE (yyss1);
1288 }
1289 # endif
1290 #endif /* no yyoverflow */
1291
1292 yyssp = yyss + yysize - 1;
1293 yyvsp = yyvs + yysize - 1;
1294
1295 YYDPRINTF ((stderr, "Stack size increased to %lu\n",
1296 (unsigned long int) yystacksize));
1297
1298 if (yyss + yystacksize - 1 <= yyssp)
1299 YYABORT;
1300 }
1301
1302 YYDPRINTF ((stderr, "Entering state %d\n", yystate));
1303
1304 if (yystate == YYFINAL)
1305 YYACCEPT;
1306
1307 goto yybackup;
1308
1309 /*-----------.
1310 | yybackup. |
1311 `-----------*/
1312 yybackup:
1313
1314 /* Do appropriate processing given the current state. Read a
1315 lookahead token if we need one and don't already have one. */
1316
1317 /* First try to decide what to do without reference to lookahead token. */
1318 yyn = yypact[yystate];
1319 if (yyn == YYPACT_NINF)
1320 goto yydefault;
1321
1322 /* Not known => get a lookahead token if don't already have one. */
1323
1324 /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
1325 if (yychar == YYEMPTY)
1326 {
1327 YYDPRINTF ((stderr, "Reading a token: "));
1328 yychar = YYLEX;
1329 }
1330
1331 if (yychar <= YYEOF)
1332 {
1333 yychar = yytoken = YYEOF;
1334 YYDPRINTF ((stderr, "Now at end of input.\n"));
1335 }
1336 else
1337 {
1338 yytoken = YYTRANSLATE (yychar);
1339 YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
1340 }
1341
1342 /* If the proper action on seeing token YYTOKEN is to reduce or to
1343 detect an error, take that action. */
1344 yyn += yytoken;
1345 if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
1346 goto yydefault;
1347 yyn = yytable[yyn];
1348 if (yyn <= 0)
1349 {
1350 if (yyn == 0 || yyn == YYTABLE_NINF)
1351 goto yyerrlab;
1352 yyn = -yyn;
1353 goto yyreduce;
1354 }
1355
1356 /* Count tokens shifted since error; after three, turn off error
1357 status. */
1358 if (yyerrstatus)
1359 yyerrstatus--;
1360
1361 /* Shift the lookahead token. */
1362 YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
1363
1364 /* Discard the shifted token. */
1365 yychar = YYEMPTY;
1366
1367 yystate = yyn;
1368 *++yyvsp = yylval;
1369
1370 goto yynewstate;
1371
1372
1373 /*-----------------------------------------------------------.
1374 | yydefault -- do the default action for the current state. |
1375 `-----------------------------------------------------------*/
1376 yydefault:
1377 yyn = yydefact[yystate];
1378 if (yyn == 0)
1379 goto yyerrlab;
1380 goto yyreduce;
1381
1382
1383 /*-----------------------------.
1384 | yyreduce -- Do a reduction. |
1385 `-----------------------------*/
1386 yyreduce:
1387 /* yyn is the number of a rule to reduce with. */
1388 yylen = yyr2[yyn];
1389
1390 /* If YYLEN is nonzero, implement the default value of the action:
1391 `$$ = $1'.
1392
1393 Otherwise, the following line sets YYVAL to garbage.
1394 This behavior is undocumented and Bison
1395 users should not rely upon it. Assigning to YYVAL
1396 unconditionally makes the parser a bit smaller, and it avoids a
1397 GCC warning that YYVAL may be used uninitialized. */
1398 yyval = yyvsp[1-yylen];
1399
1400
1401 YY_REDUCE_PRINT (yyn);
1402 switch (yyn)
1403 {
1404 case 2:
1405
1406 {
1407 the_boot_info = build_boot_info((yyvsp[(3) - (4)].re), (yyvsp[(4) - (4)].node),
1408 guess_boot_cpuid((yyvsp[(4) - (4)].node)));
1409 ;}
1410 break;
1411
1412 case 3:
1413
1414 {
1415 (yyval.re) = NULL;
1416 ;}
1417 break;
1418
1419 case 4:
1420
1421 {
1422 (yyval.re) = chain_reserve_entry((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].re));
1423 ;}
1424 break;
1425
1426 case 5:
1427
1428 {
1429 (yyval.re) = build_reserve_entry((yyvsp[(2) - (4)].addr), (yyvsp[(3) - (4)].addr));
1430 ;}
1431 break;
1432
1433 case 6:
1434
1435 {
1436 add_label(&(yyvsp[(2) - (2)].re)->labels, (yyvsp[(1) - (2)].labelref));
1437 (yyval.re) = (yyvsp[(2) - (2)].re);
1438 ;}
1439 break;
1440
1441 case 7:
1442
1443 {
1444 (yyval.addr) = eval_literal((yyvsp[(1) - (1)].literal), 0, 64);
1445 ;}
1446 break;
1447
1448 case 8:
1449
1450 {
1451 (yyval.node) = name_node((yyvsp[(2) - (2)].node), "");
1452 ;}
1453 break;
1454
1455 case 9:
1456
1457 {
1458 (yyval.node) = merge_nodes((yyvsp[(1) - (3)].node), (yyvsp[(3) - (3)].node));
1459 ;}
1460 break;
1461
1462 case 10:
1463
1464 {
1465 struct node *target = get_node_by_ref((yyvsp[(1) - (3)].node), (yyvsp[(2) - (3)].labelref));
1466
1467 if (target)
1468 merge_nodes(target, (yyvsp[(3) - (3)].node));
1469 else
1470 print_error("label or path, '%s', not found", (yyvsp[(2) - (3)].labelref));
1471 (yyval.node) = (yyvsp[(1) - (3)].node);
1472 ;}
1473 break;
1474
1475 case 11:
1476
1477 {
1478 (yyval.node) = build_node((yyvsp[(2) - (5)].proplist), (yyvsp[(3) - (5)].nodelist));
1479 ;}
1480 break;
1481
1482 case 12:
1483
1484 {
1485 (yyval.proplist) = NULL;
1486 ;}
1487 break;
1488
1489 case 13:
1490
1491 {
1492 (yyval.proplist) = chain_property((yyvsp[(2) - (2)].prop), (yyvsp[(1) - (2)].proplist));
1493 ;}
1494 break;
1495
1496 case 14:
1497
1498 {
1499 (yyval.prop) = build_property((yyvsp[(1) - (4)].propnodename), (yyvsp[(3) - (4)].data));
1500 ;}
1501 break;
1502
1503 case 15:
1504
1505 {
1506 (yyval.prop) = build_property((yyvsp[(1) - (2)].propnodename), empty_data);
1507 ;}
1508 break;
1509
1510 case 16:
1511
1512 {
1513 add_label(&(yyvsp[(2) - (2)].prop)->labels, (yyvsp[(1) - (2)].labelref));
1514 (yyval.prop) = (yyvsp[(2) - (2)].prop);
1515 ;}
1516 break;
1517
1518 case 17:
1519
1520 {
1521 (yyval.data) = data_merge((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].data));
1522 ;}
1523 break;
1524
1525 case 18:
1526
1527 {
1528 (yyval.data) = data_merge((yyvsp[(1) - (4)].data), (yyvsp[(3) - (4)].data));
1529 ;}
1530 break;
1531
1532 case 19:
1533
1534 {
1535 (yyval.data) = data_merge((yyvsp[(1) - (4)].data), (yyvsp[(3) - (4)].data));
1536 ;}
1537 break;
1538
1539 case 20:
1540
1541 {
1542 (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), REF_PATH, (yyvsp[(2) - (2)].labelref));
1543 ;}
1544 break;
1545
1546 case 21:
1547
1548 {
1549 FILE *f = srcfile_relative_open((yyvsp[(4) - (9)].data).val, NULL);
1550 struct data d;
1551
1552 if ((yyvsp[(6) - (9)].addr) != 0)
1553 if (fseek(f, (yyvsp[(6) - (9)].addr), SEEK_SET) != 0)
1554 print_error("Couldn't seek to offset %llu in \"%s\": %s",
1555 (unsigned long long)(yyvsp[(6) - (9)].addr),
1556 (yyvsp[(4) - (9)].data).val,
1557 strerror(errno));
1558
1559 d = data_copy_file(f, (yyvsp[(8) - (9)].addr));
1560
1561 (yyval.data) = data_merge((yyvsp[(1) - (9)].data), d);
1562 fclose(f);
1563 ;}
1564 break;
1565
1566 case 22:
1567
1568 {
1569 FILE *f = srcfile_relative_open((yyvsp[(4) - (5)].data).val, NULL);
1570 struct data d = empty_data;
1571
1572 d = data_copy_file(f, -1);
1573
1574 (yyval.data) = data_merge((yyvsp[(1) - (5)].data), d);
1575 fclose(f);
1576 ;}
1577 break;
1578
1579 case 23:
1580
1581 {
1582 (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref));
1583 ;}
1584 break;
1585
1586 case 24:
1587
1588 {
1589 (yyval.data) = empty_data;
1590 ;}
1591 break;
1592
1593 case 25:
1594
1595 {
1596 (yyval.data) = (yyvsp[(1) - (2)].data);
1597 ;}
1598 break;
1599
1600 case 26:
1601
1602 {
1603 (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref));
1604 ;}
1605 break;
1606
1607 case 27:
1608
1609 {
1610 (yyval.data) = empty_data;
1611 ;}
1612 break;
1613
1614 case 28:
1615
1616 {
1617 (yyval.data) = data_append_cell((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].cell));
1618 ;}
1619 break;
1620
1621 case 29:
1622
1623 {
1624 (yyval.data) = data_append_cell(data_add_marker((yyvsp[(1) - (2)].data), REF_PHANDLE,
1625 (yyvsp[(2) - (2)].labelref)), -1);
1626 ;}
1627 break;
1628
1629 case 30:
1630
1631 {
1632 (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref));
1633 ;}
1634 break;
1635
1636 case 31:
1637
1638 {
1639 (yyval.cell) = eval_literal((yyvsp[(1) - (1)].literal), 0, 32);
1640 ;}
1641 break;
1642
1643 case 32:
1644
1645 {
1646 (yyval.data) = empty_data;
1647 ;}
1648 break;
1649
1650 case 33:
1651
1652 {
1653 (yyval.data) = data_append_byte((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].byte));
1654 ;}
1655 break;
1656
1657 case 34:
1658
1659 {
1660 (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref));
1661 ;}
1662 break;
1663
1664 case 35:
1665
1666 {
1667 (yyval.nodelist) = NULL;
1668 ;}
1669 break;
1670
1671 case 36:
1672
1673 {
1674 (yyval.nodelist) = chain_node((yyvsp[(1) - (2)].node), (yyvsp[(2) - (2)].nodelist));
1675 ;}
1676 break;
1677
1678 case 37:
1679
1680 {
1681 print_error("syntax error: properties must precede subnodes");
1682 YYERROR;
1683 ;}
1684 break;
1685
1686 case 38:
1687
1688 {
1689 (yyval.node) = name_node((yyvsp[(2) - (2)].node), (yyvsp[(1) - (2)].propnodename));
1690 ;}
1691 break;
1692
1693 case 39:
1694
1695 {
1696 add_label(&(yyvsp[(2) - (2)].node)->labels, (yyvsp[(1) - (2)].labelref));
1697 (yyval.node) = (yyvsp[(2) - (2)].node);
1698 ;}
1699 break;
1700
1701
1702
1703 default: break;
1704 }
1705 YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
1706
1707 YYPOPSTACK (yylen);
1708 yylen = 0;
1709 YY_STACK_PRINT (yyss, yyssp);
1710
1711 *++yyvsp = yyval;
1712
1713 /* Now `shift' the result of the reduction. Determine what state
1714 that goes to, based on the state we popped back to and the rule
1715 number reduced by. */
1716
1717 yyn = yyr1[yyn];
1718
1719 yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
1720 if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
1721 yystate = yytable[yystate];
1722 else
1723 yystate = yydefgoto[yyn - YYNTOKENS];
1724
1725 goto yynewstate;
1726
1727
1728 /*------------------------------------.
1729 | yyerrlab -- here on detecting error |
1730 `------------------------------------*/
1731 yyerrlab:
1732 /* If not already recovering from an error, report this error. */
1733 if (!yyerrstatus)
1734 {
1735 ++yynerrs;
1736 #if ! YYERROR_VERBOSE
1737 yyerror (YY_("syntax error"));
1738 #else
1739 {
1740 YYSIZE_T yysize = yysyntax_error (0, yystate, yychar);
1741 if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM)
1742 {
1743 YYSIZE_T yyalloc = 2 * yysize;
1744 if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM))
1745 yyalloc = YYSTACK_ALLOC_MAXIMUM;
1746 if (yymsg != yymsgbuf)
1747 YYSTACK_FREE (yymsg);
1748 yymsg = (char *) YYSTACK_ALLOC (yyalloc);
1749 if (yymsg)
1750 yymsg_alloc = yyalloc;
1751 else
1752 {
1753 yymsg = yymsgbuf;
1754 yymsg_alloc = sizeof yymsgbuf;
1755 }
1756 }
1757
1758 if (0 < yysize && yysize <= yymsg_alloc)
1759 {
1760 (void) yysyntax_error (yymsg, yystate, yychar);
1761 yyerror (yymsg);
1762 }
1763 else
1764 {
1765 yyerror (YY_("syntax error"));
1766 if (yysize != 0)
1767 goto yyexhaustedlab;
1768 }
1769 }
1770 #endif
1771 }
1772
1773
1774
1775 if (yyerrstatus == 3)
1776 {
1777 /* If just tried and failed to reuse lookahead token after an
1778 error, discard it. */
1779
1780 if (yychar <= YYEOF)
1781 {
1782 /* Return failure if at end of input. */
1783 if (yychar == YYEOF)
1784 YYABORT;
1785 }
1786 else
1787 {
1788 yydestruct ("Error: discarding",
1789 yytoken, &yylval);
1790 yychar = YYEMPTY;
1791 }
1792 }
1793
1794 /* Else will try to reuse lookahead token after shifting the error
1795 token. */
1796 goto yyerrlab1;
1797
1798
1799 /*---------------------------------------------------.
1800 | yyerrorlab -- error raised explicitly by YYERROR. |
1801 `---------------------------------------------------*/
1802 yyerrorlab:
1803
1804 /* Pacify compilers like GCC when the user code never invokes
1805 YYERROR and the label yyerrorlab therefore never appears in user
1806 code. */
1807 if (/*CONSTCOND*/ 0)
1808 goto yyerrorlab;
1809
1810 /* Do not reclaim the symbols of the rule which action triggered
1811 this YYERROR. */
1812 YYPOPSTACK (yylen);
1813 yylen = 0;
1814 YY_STACK_PRINT (yyss, yyssp);
1815 yystate = *yyssp;
1816 goto yyerrlab1;
1817
1818
1819 /*-------------------------------------------------------------.
1820 | yyerrlab1 -- common code for both syntax error and YYERROR. |
1821 `-------------------------------------------------------------*/
1822 yyerrlab1:
1823 yyerrstatus = 3; /* Each real token shifted decrements this. */
1824
1825 for (;;)
1826 {
1827 yyn = yypact[yystate];
1828 if (yyn != YYPACT_NINF)
1829 {
1830 yyn += YYTERROR;
1831 if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
1832 {
1833 yyn = yytable[yyn];
1834 if (0 < yyn)
1835 break;
1836 }
1837 }
1838
1839 /* Pop the current state because it cannot handle the error token. */
1840 if (yyssp == yyss)
1841 YYABORT;
1842
1843
1844 yydestruct ("Error: popping",
1845 yystos[yystate], yyvsp);
1846 YYPOPSTACK (1);
1847 yystate = *yyssp;
1848 YY_STACK_PRINT (yyss, yyssp);
1849 }
1850
1851 *++yyvsp = yylval;
1852
1853
1854 /* Shift the error token. */
1855 YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
1856
1857 yystate = yyn;
1858 goto yynewstate;
1859
1860
1861 /*-------------------------------------.
1862 | yyacceptlab -- YYACCEPT comes here. |
1863 `-------------------------------------*/
1864 yyacceptlab:
1865 yyresult = 0;
1866 goto yyreturn;
1867
1868 /*-----------------------------------.
1869 | yyabortlab -- YYABORT comes here. |
1870 `-----------------------------------*/
1871 yyabortlab:
1872 yyresult = 1;
1873 goto yyreturn;
1874
1875 #if !defined(yyoverflow) || YYERROR_VERBOSE
1876 /*-------------------------------------------------.
1877 | yyexhaustedlab -- memory exhaustion comes here. |
1878 `-------------------------------------------------*/
1879 yyexhaustedlab:
1880 yyerror (YY_("memory exhausted"));
1881 yyresult = 2;
1882 /* Fall through. */
1883 #endif
1884
1885 yyreturn:
1886 if (yychar != YYEMPTY)
1887 yydestruct ("Cleanup: discarding lookahead",
1888 yytoken, &yylval);
1889 /* Do not reclaim the symbols of the rule which action triggered
1890 this YYABORT or YYACCEPT. */
1891 YYPOPSTACK (yylen);
1892 YY_STACK_PRINT (yyss, yyssp);
1893 while (yyssp != yyss)
1894 {
1895 yydestruct ("Cleanup: popping",
1896 yystos[*yyssp], yyvsp);
1897 YYPOPSTACK (1);
1898 }
1899 #ifndef yyoverflow
1900 if (yyss != yyssa)
1901 YYSTACK_FREE (yyss);
1902 #endif
1903 #if YYERROR_VERBOSE
1904 if (yymsg != yymsgbuf)
1905 YYSTACK_FREE (yymsg);
1906 #endif
1907 /* Make sure YYID is used. */
1908 return YYID (yyresult);
1909 }
1910
1911
1912
1913
1914
1915 void print_error(char const *fmt, ...)
1916 {
1917 va_list va;
1918
1919 va_start(va, fmt);
1920 srcpos_verror(&yylloc, fmt, va);
1921 va_end(va);
1922
1923 treesource_error = 1;
1924 }
1925
1926 void yyerror(char const *s) {
1927 print_error("%s", s);
1928 }
1929
1930 static unsigned long long eval_literal(const char *s, int base, int bits)
1931 {
1932 unsigned long long val;
1933 char *e;
1934
1935 errno = 0;
1936 val = strtoull(s, &e, base);
1937 if (*e)
1938 print_error("bad characters in literal");
1939 else if ((errno == ERANGE)
1940 || ((bits < 64) && (val >= (1ULL << bits))))
1941 print_error("literal out of range");
1942 else if (errno != 0)
1943 print_error("bad literal");
1944 return val;
1945 }
1946