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


HyperKWIC - Version 7.20DA executed at 11:37 on 27 Oct 2017 | Polyhedron Solutions - INTERNAL USE | COMMERCIAL (Any O/S) SN 4AKIed