mirror of
				https://github.com/stedolan/jq.git
				synced 2024-05-11 05:55:39 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			3674 lines
		
	
	
		
			123 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			3674 lines
		
	
	
		
			123 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* A Bison parser, made by GNU Bison 3.0.2.  */
 | |
| 
 | |
| /* Bison implementation for Yacc-like parsers in C
 | |
| 
 | |
|    Copyright (C) 1984, 1989-1990, 2000-2013 Free Software Foundation, Inc.
 | |
| 
 | |
|    This program is free software: you can redistribute it and/or modify
 | |
|    it under the terms of the GNU General Public License as published by
 | |
|    the Free Software Foundation, either version 3 of the License, or
 | |
|    (at your option) any later version.
 | |
| 
 | |
|    This program is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|    GNU General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU General Public License
 | |
|    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
 | |
| 
 | |
| /* As a special exception, you may create a larger work that contains
 | |
|    part or all of the Bison parser skeleton and distribute that work
 | |
|    under terms of your choice, so long as that work isn't itself a
 | |
|    parser generator using the skeleton or a modified version thereof
 | |
|    as a parser skeleton.  Alternatively, if you modify or redistribute
 | |
|    the parser skeleton itself, you may (at your option) remove this
 | |
|    special exception, which will cause the skeleton and the resulting
 | |
|    Bison output files to be licensed under the GNU General Public
 | |
|    License without this special exception.
 | |
| 
 | |
|    This special exception was added by the Free Software Foundation in
 | |
|    version 2.2 of Bison.  */
 | |
| 
 | |
| /* C LALR(1) parser skeleton written by Richard Stallman, by
 | |
|    simplifying the original so-called "semantic" parser.  */
 | |
| 
 | |
| /* All symbols defined below should begin with yy or YY, to avoid
 | |
|    infringing on user name space.  This should be done even for local
 | |
|    variables, as they might otherwise be expanded by user macros.
 | |
|    There are some unavoidable exceptions within include files to
 | |
|    define necessary library symbols; they are noted "INFRINGES ON
 | |
|    USER NAME SPACE" below.  */
 | |
| 
 | |
| /* Identify Bison output.  */
 | |
| #define YYBISON 1
 | |
| 
 | |
| /* Bison version.  */
 | |
| #define YYBISON_VERSION "3.0.2"
 | |
| 
 | |
| /* Skeleton name.  */
 | |
| #define YYSKELETON_NAME "yacc.c"
 | |
| 
 | |
| /* Pure parsers.  */
 | |
| #define YYPURE 1
 | |
| 
 | |
| /* Push parsers.  */
 | |
| #define YYPUSH 0
 | |
| 
 | |
| /* Pull parsers.  */
 | |
| #define YYPULL 1
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| /* Copy the first part of user declarations.  */
 | |
| #line 1 "parser.y" /* yacc.c:339  */
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <string.h>
 | |
| #include <assert.h>
 | |
| #include "compile.h"
 | |
| #include "jv_alloc.h"
 | |
| #define YYMALLOC jv_mem_alloc
 | |
| #define YYFREE jv_mem_free
 | |
| 
 | |
| #line 76 "parser.c" /* yacc.c:339  */
 | |
| 
 | |
| # ifndef YY_NULLPTR
 | |
| #  if defined __cplusplus && 201103L <= __cplusplus
 | |
| #   define YY_NULLPTR nullptr
 | |
| #  else
 | |
| #   define YY_NULLPTR 0
 | |
| #  endif
 | |
| # endif
 | |
| 
 | |
| /* Enabling verbose error messages.  */
 | |
| #ifdef YYERROR_VERBOSE
 | |
| # undef YYERROR_VERBOSE
 | |
| # define YYERROR_VERBOSE 1
 | |
| #else
 | |
| # define YYERROR_VERBOSE 1
 | |
| #endif
 | |
| 
 | |
| /* In a future release of Bison, this section will be replaced
 | |
|    by #include "y.tab.h".  */
 | |
| #ifndef YY_YY_PARSER_H_INCLUDED
 | |
| # define YY_YY_PARSER_H_INCLUDED
 | |
| /* Debug traces.  */
 | |
| #ifndef YYDEBUG
 | |
| # define YYDEBUG 0
 | |
| #endif
 | |
| #if YYDEBUG
 | |
| extern int yydebug;
 | |
| #endif
 | |
| /* "%code requires" blocks.  */
 | |
| #line 10 "parser.y" /* yacc.c:355  */
 | |
| 
 | |
| #include "locfile.h"
 | |
| struct lexer_param;
 | |
| 
 | |
| #define YYLTYPE location
 | |
| #define YYLLOC_DEFAULT(Loc, Rhs, N)             \
 | |
|   do {                                          \
 | |
|     if (N) {                                    \
 | |
|       (Loc).start = YYRHSLOC(Rhs, 1).start;     \
 | |
|       (Loc).end = YYRHSLOC(Rhs, N).end;         \
 | |
|     } else {                                    \
 | |
|       (Loc).start = YYRHSLOC(Rhs, 0).end;       \
 | |
|       (Loc).end = YYRHSLOC(Rhs, 0).end;         \
 | |
|     }                                           \
 | |
|   } while (0)
 | |
|  
 | |
| 
 | |
| #line 124 "parser.c" /* yacc.c:355  */
 | |
| 
 | |
| /* Token type.  */
 | |
| #ifndef YYTOKENTYPE
 | |
| # define YYTOKENTYPE
 | |
|   enum yytokentype
 | |
|   {
 | |
|     INVALID_CHARACTER = 258,
 | |
|     IDENT = 259,
 | |
|     FIELD = 260,
 | |
|     LITERAL = 261,
 | |
|     FORMAT = 262,
 | |
|     REC = 263,
 | |
|     SETMOD = 264,
 | |
|     EQ = 265,
 | |
|     NEQ = 266,
 | |
|     DEFINEDOR = 267,
 | |
|     AS = 268,
 | |
|     DEF = 269,
 | |
|     MODULE = 270,
 | |
|     IMPORT = 271,
 | |
|     IF = 272,
 | |
|     THEN = 273,
 | |
|     ELSE = 274,
 | |
|     ELSE_IF = 275,
 | |
|     REDUCE = 276,
 | |
|     FOREACH = 277,
 | |
|     END = 278,
 | |
|     AND = 279,
 | |
|     OR = 280,
 | |
|     TRY = 281,
 | |
|     CATCH = 282,
 | |
|     LABEL = 283,
 | |
|     BREAK = 284,
 | |
|     LOC = 285,
 | |
|     SETPIPE = 286,
 | |
|     SETPLUS = 287,
 | |
|     SETMINUS = 288,
 | |
|     SETMULT = 289,
 | |
|     SETDIV = 290,
 | |
|     SETDEFINEDOR = 291,
 | |
|     LESSEQ = 292,
 | |
|     GREATEREQ = 293,
 | |
|     QQSTRING_START = 294,
 | |
|     QQSTRING_TEXT = 295,
 | |
|     QQSTRING_INTERP_START = 296,
 | |
|     QQSTRING_INTERP_END = 297,
 | |
|     QQSTRING_END = 298
 | |
|   };
 | |
| #endif
 | |
| /* Tokens.  */
 | |
| #define INVALID_CHARACTER 258
 | |
| #define IDENT 259
 | |
| #define FIELD 260
 | |
| #define LITERAL 261
 | |
| #define FORMAT 262
 | |
| #define REC 263
 | |
| #define SETMOD 264
 | |
| #define EQ 265
 | |
| #define NEQ 266
 | |
| #define DEFINEDOR 267
 | |
| #define AS 268
 | |
| #define DEF 269
 | |
| #define MODULE 270
 | |
| #define IMPORT 271
 | |
| #define IF 272
 | |
| #define THEN 273
 | |
| #define ELSE 274
 | |
| #define ELSE_IF 275
 | |
| #define REDUCE 276
 | |
| #define FOREACH 277
 | |
| #define END 278
 | |
| #define AND 279
 | |
| #define OR 280
 | |
| #define TRY 281
 | |
| #define CATCH 282
 | |
| #define LABEL 283
 | |
| #define BREAK 284
 | |
| #define LOC 285
 | |
| #define SETPIPE 286
 | |
| #define SETPLUS 287
 | |
| #define SETMINUS 288
 | |
| #define SETMULT 289
 | |
| #define SETDIV 290
 | |
| #define SETDEFINEDOR 291
 | |
| #define LESSEQ 292
 | |
| #define GREATEREQ 293
 | |
| #define QQSTRING_START 294
 | |
| #define QQSTRING_TEXT 295
 | |
| #define QQSTRING_INTERP_START 296
 | |
| #define QQSTRING_INTERP_END 297
 | |
| #define QQSTRING_END 298
 | |
| 
 | |
| /* Value type.  */
 | |
| #if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
 | |
| typedef union YYSTYPE YYSTYPE;
 | |
| union YYSTYPE
 | |
| {
 | |
| #line 30 "parser.y" /* yacc.c:355  */
 | |
| 
 | |
|   jv literal;
 | |
|   block blk;
 | |
| 
 | |
| #line 227 "parser.c" /* yacc.c:355  */
 | |
| };
 | |
| # define YYSTYPE_IS_TRIVIAL 1
 | |
| # define YYSTYPE_IS_DECLARED 1
 | |
| #endif
 | |
| 
 | |
| /* Location type.  */
 | |
| #if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED
 | |
| typedef struct YYLTYPE YYLTYPE;
 | |
| struct YYLTYPE
 | |
| {
 | |
|   int first_line;
 | |
|   int first_column;
 | |
|   int last_line;
 | |
|   int last_column;
 | |
| };
 | |
| # define YYLTYPE_IS_DECLARED 1
 | |
| # define YYLTYPE_IS_TRIVIAL 1
 | |
| #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| int yyparse (block* answer, int* errors, struct locfile* locations, struct lexer_param* lexer_param_ptr);
 | |
| 
 | |
| #endif /* !YY_YY_PARSER_H_INCLUDED  */
 | |
| 
 | |
| /* Copy the second part of user declarations.  */
 | |
| #line 112 "parser.y" /* yacc.c:358  */
 | |
| 
 | |
| #include "lexer.h"
 | |
| struct lexer_param {
 | |
|   yyscan_t lexer;
 | |
| };
 | |
| #define FAIL(loc, msg)                                             \
 | |
|   do {                                                             \
 | |
|     location l = loc;                                              \
 | |
|     yyerror(&l, answer, errors, locations, lexer_param_ptr, msg);  \
 | |
|     /*YYERROR*/;                                                   \
 | |
|   } while (0)
 | |
| 
 | |
| void yyerror(YYLTYPE* loc, block* answer, int* errors, 
 | |
|              struct locfile* locations, struct lexer_param* lexer_param_ptr, const char *s){
 | |
|   (*errors)++;
 | |
|   if (strstr(s, "unexpected")) {
 | |
| #ifdef WIN32
 | |
|       locfile_locate(locations, *loc, "jq: error: %s (Windows cmd shell quoting issues?)", s);
 | |
| #else
 | |
|       locfile_locate(locations, *loc, "jq: error: %s (Unix shell quoting issues?)", s);
 | |
| #endif
 | |
|   } else {
 | |
|       locfile_locate(locations, *loc, "jq: error: %s", s);
 | |
|   }
 | |
| }
 | |
| 
 | |
| int yylex(YYSTYPE* yylval, YYLTYPE* yylloc, block* answer, int* errors, 
 | |
|           struct locfile* locations, struct lexer_param* lexer_param_ptr) {
 | |
|   yyscan_t lexer = lexer_param_ptr->lexer;
 | |
|   int tok = jq_yylex(yylval, yylloc, lexer);
 | |
|   if ((tok == LITERAL || tok == QQSTRING_TEXT) && !jv_is_valid(yylval->literal)) {
 | |
|     jv msg = jv_invalid_get_msg(jv_copy(yylval->literal));
 | |
|     if (jv_get_kind(msg) == JV_KIND_STRING) {
 | |
|       FAIL(*yylloc, jv_string_value(msg));
 | |
|     } else {
 | |
|       FAIL(*yylloc, "Invalid literal");
 | |
|     }
 | |
|     jv_free(msg);
 | |
|     jv_free(yylval->literal);
 | |
|     yylval->literal = jv_null();
 | |
|   }
 | |
|   return tok;
 | |
| }
 | |
| 
 | |
| static block gen_dictpair(block k, block v) {
 | |
|   return BLOCK(gen_subexp(k), gen_subexp(v), gen_op_simple(INSERT));
 | |
| }
 | |
| 
 | |
| static block gen_index(block obj, block key) {
 | |
|   return BLOCK(gen_subexp(key), obj, gen_op_simple(INDEX));
 | |
| }
 | |
| 
 | |
| static block gen_index_opt(block obj, block key) {
 | |
|   return BLOCK(gen_subexp(key), obj, gen_op_simple(INDEX_OPT));
 | |
| }
 | |
| 
 | |
| static block gen_slice_index(block obj, block start, block end, opcode idx_op) {
 | |
|   block key = BLOCK(gen_subexp(gen_const(jv_object())),
 | |
|                     gen_subexp(gen_const(jv_string("start"))),
 | |
|                     gen_subexp(start),
 | |
|                     gen_op_simple(INSERT),
 | |
|                     gen_subexp(gen_const(jv_string("end"))),
 | |
|                     gen_subexp(end),
 | |
|                     gen_op_simple(INSERT));
 | |
|   return BLOCK(key, obj, gen_op_simple(idx_op));
 | |
| }
 | |
| 
 | |
| static block constant_fold(block a, block b, int op) {
 | |
|   if (!block_is_single(a) || !block_is_const(a) ||
 | |
|       !block_is_single(b) || !block_is_const(b))
 | |
|     return gen_noop();
 | |
|   if (block_const_kind(a) != block_const_kind(b))
 | |
|     return gen_noop();
 | |
| 
 | |
|   jv res = jv_invalid();
 | |
| 
 | |
|   if (block_const_kind(a) == JV_KIND_NUMBER) {
 | |
|     double na = jv_number_value(block_const(a));
 | |
|     double nb = jv_number_value(block_const(b));
 | |
|     switch (op) {
 | |
|     case '+': res = jv_number(na + nb); break;
 | |
|     case '-': res = jv_number(na - nb); break;
 | |
|     case '*': res = jv_number(na * nb); break;
 | |
|     case '/': res = jv_number(na / nb); break;
 | |
|     case EQ:  res = (na == nb ? jv_true() : jv_false()); break;
 | |
|     case NEQ: res = (na != nb ? jv_true() : jv_false()); break;
 | |
|     case '<': res = (na < nb ? jv_true() : jv_false()); break;
 | |
|     case '>': res = (na > nb ? jv_true() : jv_false()); break;
 | |
|     case LESSEQ: res = (na <= nb ? jv_true() : jv_false()); break;
 | |
|     case GREATEREQ: res = (na >= nb ? jv_true() : jv_false()); break;
 | |
|     default: break;
 | |
|     }
 | |
|   } else if (op == '+' && block_const_kind(a) == JV_KIND_STRING) {
 | |
|     res = jv_string_concat(block_const(a),  block_const(b));
 | |
|   } else {
 | |
|     return gen_noop();
 | |
|   }
 | |
| 
 | |
|   if (jv_get_kind(res) == JV_KIND_INVALID)
 | |
|     return gen_noop();
 | |
| 
 | |
|   block_free(a);
 | |
|   block_free(b);
 | |
|   return gen_const(res);
 | |
| }
 | |
| 
 | |
| static block gen_binop(block a, block b, int op) {
 | |
|   block folded = constant_fold(a, b, op);
 | |
|   if (!block_is_noop(folded))
 | |
|     return folded;
 | |
| 
 | |
|   const char* funcname = 0;
 | |
|   switch (op) {
 | |
|   case '+': funcname = "_plus"; break;
 | |
|   case '-': funcname = "_minus"; break;
 | |
|   case '*': funcname = "_multiply"; break;
 | |
|   case '/': funcname = "_divide"; break;
 | |
|   case '%': funcname = "_mod"; break;
 | |
|   case EQ: funcname = "_equal"; break;
 | |
|   case NEQ: funcname = "_notequal"; break;
 | |
|   case '<': funcname = "_less"; break;
 | |
|   case '>': funcname = "_greater"; break;
 | |
|   case LESSEQ: funcname = "_lesseq"; break;
 | |
|   case GREATEREQ: funcname = "_greatereq"; break;
 | |
|   }
 | |
|   assert(funcname);
 | |
| 
 | |
|   return gen_call(funcname, BLOCK(gen_lambda(a), gen_lambda(b)));
 | |
| }
 | |
| 
 | |
| static block gen_format(block a, jv fmt) {
 | |
|   return BLOCK(a, gen_call("format", BLOCK(gen_lambda(gen_const(fmt)))));
 | |
| }
 | |
| 
 | |
| static block gen_definedor_assign(block object, block val) {
 | |
|   block tmp = gen_op_var_fresh(STOREV, "tmp");
 | |
|   return BLOCK(gen_op_simple(DUP),
 | |
|                val, tmp,
 | |
|                gen_call("_modify", BLOCK(gen_lambda(object),
 | |
|                                          gen_lambda(gen_definedor(gen_noop(), 
 | |
|                                                                   gen_op_bound(LOADV, tmp))))));
 | |
| }
 | |
|  
 | |
| static block gen_update(block object, block val, int optype) {
 | |
|   block tmp = gen_op_var_fresh(STOREV, "tmp");
 | |
|   return BLOCK(gen_op_simple(DUP),
 | |
|                val,
 | |
|                tmp,
 | |
|                gen_call("_modify", BLOCK(gen_lambda(object), 
 | |
|                                          gen_lambda(gen_binop(gen_noop(),
 | |
|                                                               gen_op_bound(LOADV, tmp),
 | |
|                                                               optype)))));
 | |
| }
 | |
| 
 | |
| 
 | |
| #line 410 "parser.c" /* yacc.c:358  */
 | |
| 
 | |
| #ifdef short
 | |
| # undef short
 | |
| #endif
 | |
| 
 | |
| #ifdef YYTYPE_UINT8
 | |
| typedef YYTYPE_UINT8 yytype_uint8;
 | |
| #else
 | |
| typedef unsigned char yytype_uint8;
 | |
| #endif
 | |
| 
 | |
| #ifdef YYTYPE_INT8
 | |
| typedef YYTYPE_INT8 yytype_int8;
 | |
| #else
 | |
| typedef signed char yytype_int8;
 | |
| #endif
 | |
| 
 | |
| #ifdef YYTYPE_UINT16
 | |
| typedef YYTYPE_UINT16 yytype_uint16;
 | |
| #else
 | |
| typedef unsigned short int yytype_uint16;
 | |
| #endif
 | |
| 
 | |
| #ifdef YYTYPE_INT16
 | |
| typedef YYTYPE_INT16 yytype_int16;
 | |
| #else
 | |
| typedef short int yytype_int16;
 | |
| #endif
 | |
| 
 | |
| #ifndef YYSIZE_T
 | |
| # ifdef __SIZE_TYPE__
 | |
| #  define YYSIZE_T __SIZE_TYPE__
 | |
| # elif defined size_t
 | |
| #  define YYSIZE_T size_t
 | |
| # elif ! defined YYSIZE_T
 | |
| #  include <stddef.h> /* INFRINGES ON USER NAME SPACE */
 | |
| #  define YYSIZE_T size_t
 | |
| # else
 | |
| #  define YYSIZE_T unsigned int
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| #define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
 | |
| 
 | |
| #ifndef YY_
 | |
| # if defined YYENABLE_NLS && YYENABLE_NLS
 | |
| #  if ENABLE_NLS
 | |
| #   include <libintl.h> /* INFRINGES ON USER NAME SPACE */
 | |
| #   define YY_(Msgid) dgettext ("bison-runtime", Msgid)
 | |
| #  endif
 | |
| # endif
 | |
| # ifndef YY_
 | |
| #  define YY_(Msgid) Msgid
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| #ifndef YY_ATTRIBUTE
 | |
| # if (defined __GNUC__                                               \
 | |
|       && (2 < __GNUC__ || (__GNUC__ == 2 && 96 <= __GNUC_MINOR__)))  \
 | |
|      || defined __SUNPRO_C && 0x5110 <= __SUNPRO_C
 | |
| #  define YY_ATTRIBUTE(Spec) __attribute__(Spec)
 | |
| # else
 | |
| #  define YY_ATTRIBUTE(Spec) /* empty */
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| #ifndef YY_ATTRIBUTE_PURE
 | |
| # define YY_ATTRIBUTE_PURE   YY_ATTRIBUTE ((__pure__))
 | |
| #endif
 | |
| 
 | |
| #ifndef YY_ATTRIBUTE_UNUSED
 | |
| # define YY_ATTRIBUTE_UNUSED YY_ATTRIBUTE ((__unused__))
 | |
| #endif
 | |
| 
 | |
| #if !defined _Noreturn \
 | |
|      && (!defined __STDC_VERSION__ || __STDC_VERSION__ < 201112)
 | |
| # if defined _MSC_VER && 1200 <= _MSC_VER
 | |
| #  define _Noreturn __declspec (noreturn)
 | |
| # else
 | |
| #  define _Noreturn YY_ATTRIBUTE ((__noreturn__))
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| /* Suppress unused-variable warnings by "using" E.  */
 | |
| #if ! defined lint || defined __GNUC__
 | |
| # define YYUSE(E) ((void) (E))
 | |
| #else
 | |
| # define YYUSE(E) /* empty */
 | |
| #endif
 | |
| 
 | |
| #if defined __GNUC__ && 407 <= __GNUC__ * 100 + __GNUC_MINOR__
 | |
| /* Suppress an incorrect diagnostic about yylval being uninitialized.  */
 | |
| # define YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN \
 | |
|     _Pragma ("GCC diagnostic push") \
 | |
|     _Pragma ("GCC diagnostic ignored \"-Wuninitialized\"")\
 | |
|     _Pragma ("GCC diagnostic ignored \"-Wmaybe-uninitialized\"")
 | |
| # define YY_IGNORE_MAYBE_UNINITIALIZED_END \
 | |
|     _Pragma ("GCC diagnostic pop")
 | |
| #else
 | |
| # define YY_INITIAL_VALUE(Value) Value
 | |
| #endif
 | |
| #ifndef YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
 | |
| # define YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
 | |
| # define YY_IGNORE_MAYBE_UNINITIALIZED_END
 | |
| #endif
 | |
| #ifndef YY_INITIAL_VALUE
 | |
| # define YY_INITIAL_VALUE(Value) /* Nothing. */
 | |
| #endif
 | |
| 
 | |
| 
 | |
| #if ! defined yyoverflow || YYERROR_VERBOSE
 | |
| 
 | |
| /* The parser invokes alloca or malloc; define the necessary symbols.  */
 | |
| 
 | |
| # ifdef YYSTACK_USE_ALLOCA
 | |
| #  if YYSTACK_USE_ALLOCA
 | |
| #   ifdef __GNUC__
 | |
| #    define YYSTACK_ALLOC __builtin_alloca
 | |
| #   elif defined __BUILTIN_VA_ARG_INCR
 | |
| #    include <alloca.h> /* INFRINGES ON USER NAME SPACE */
 | |
| #   elif defined _AIX
 | |
| #    define YYSTACK_ALLOC __alloca
 | |
| #   elif defined _MSC_VER
 | |
| #    include <malloc.h> /* INFRINGES ON USER NAME SPACE */
 | |
| #    define alloca _alloca
 | |
| #   else
 | |
| #    define YYSTACK_ALLOC alloca
 | |
| #    if ! defined _ALLOCA_H && ! defined EXIT_SUCCESS
 | |
| #     include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
 | |
|       /* Use EXIT_SUCCESS as a witness for stdlib.h.  */
 | |
| #     ifndef EXIT_SUCCESS
 | |
| #      define EXIT_SUCCESS 0
 | |
| #     endif
 | |
| #    endif
 | |
| #   endif
 | |
| #  endif
 | |
| # endif
 | |
| 
 | |
| # ifdef YYSTACK_ALLOC
 | |
|    /* Pacify GCC's 'empty if-body' warning.  */
 | |
| #  define YYSTACK_FREE(Ptr) do { /* empty */; } while (0)
 | |
| #  ifndef YYSTACK_ALLOC_MAXIMUM
 | |
|     /* The OS might guarantee only one guard page at the bottom of the stack,
 | |
|        and a page size can be as small as 4096 bytes.  So we cannot safely
 | |
|        invoke alloca (N) if N exceeds 4096.  Use a slightly smaller number
 | |
|        to allow for a few compiler-allocated temporary stack slots.  */
 | |
| #   define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
 | |
| #  endif
 | |
| # else
 | |
| #  define YYSTACK_ALLOC YYMALLOC
 | |
| #  define YYSTACK_FREE YYFREE
 | |
| #  ifndef YYSTACK_ALLOC_MAXIMUM
 | |
| #   define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
 | |
| #  endif
 | |
| #  if (defined __cplusplus && ! defined EXIT_SUCCESS \
 | |
|        && ! ((defined YYMALLOC || defined malloc) \
 | |
|              && (defined YYFREE || defined free)))
 | |
| #   include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
 | |
| #   ifndef EXIT_SUCCESS
 | |
| #    define EXIT_SUCCESS 0
 | |
| #   endif
 | |
| #  endif
 | |
| #  ifndef YYMALLOC
 | |
| #   define YYMALLOC malloc
 | |
| #   if ! defined malloc && ! defined EXIT_SUCCESS
 | |
| void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */
 | |
| #   endif
 | |
| #  endif
 | |
| #  ifndef YYFREE
 | |
| #   define YYFREE free
 | |
| #   if ! defined free && ! defined EXIT_SUCCESS
 | |
| void free (void *); /* INFRINGES ON USER NAME SPACE */
 | |
| #   endif
 | |
| #  endif
 | |
| # endif
 | |
| #endif /* ! defined yyoverflow || YYERROR_VERBOSE */
 | |
| 
 | |
| 
 | |
| #if (! defined yyoverflow \
 | |
|      && (! defined __cplusplus \
 | |
|          || (defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL \
 | |
|              && defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
 | |
| 
 | |
| /* A type that is properly aligned for any stack member.  */
 | |
| union yyalloc
 | |
| {
 | |
|   yytype_int16 yyss_alloc;
 | |
|   YYSTYPE yyvs_alloc;
 | |
|   YYLTYPE yyls_alloc;
 | |
| };
 | |
| 
 | |
| /* The size of the maximum gap between one aligned stack and the next.  */
 | |
| # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
 | |
| 
 | |
| /* The size of an array large to enough to hold all stacks, each with
 | |
|    N elements.  */
 | |
| # define YYSTACK_BYTES(N) \
 | |
|      ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \
 | |
|       + 2 * YYSTACK_GAP_MAXIMUM)
 | |
| 
 | |
| # define YYCOPY_NEEDED 1
 | |
| 
 | |
| /* Relocate STACK from its old location to the new one.  The
 | |
|    local variables YYSIZE and YYSTACKSIZE give the old and new number of
 | |
|    elements in the stack, and YYPTR gives the new location of the
 | |
|    stack.  Advance YYPTR to a properly aligned location for the next
 | |
|    stack.  */
 | |
| # define YYSTACK_RELOCATE(Stack_alloc, Stack)                           \
 | |
|     do                                                                  \
 | |
|       {                                                                 \
 | |
|         YYSIZE_T yynewbytes;                                            \
 | |
|         YYCOPY (&yyptr->Stack_alloc, Stack, yysize);                    \
 | |
|         Stack = &yyptr->Stack_alloc;                                    \
 | |
|         yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
 | |
|         yyptr += yynewbytes / sizeof (*yyptr);                          \
 | |
|       }                                                                 \
 | |
|     while (0)
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #if defined YYCOPY_NEEDED && YYCOPY_NEEDED
 | |
| /* Copy COUNT objects from SRC to DST.  The source and destination do
 | |
|    not overlap.  */
 | |
| # ifndef YYCOPY
 | |
| #  if defined __GNUC__ && 1 < __GNUC__
 | |
| #   define YYCOPY(Dst, Src, Count) \
 | |
|       __builtin_memcpy (Dst, Src, (Count) * sizeof (*(Src)))
 | |
| #  else
 | |
| #   define YYCOPY(Dst, Src, Count)              \
 | |
|       do                                        \
 | |
|         {                                       \
 | |
|           YYSIZE_T yyi;                         \
 | |
|           for (yyi = 0; yyi < (Count); yyi++)   \
 | |
|             (Dst)[yyi] = (Src)[yyi];            \
 | |
|         }                                       \
 | |
|       while (0)
 | |
| #  endif
 | |
| # endif
 | |
| #endif /* !YYCOPY_NEEDED */
 | |
| 
 | |
| /* YYFINAL -- State number of the termination state.  */
 | |
| #define YYFINAL  27
 | |
| /* YYLAST -- Last index in YYTABLE.  */
 | |
| #define YYLAST   1830
 | |
| 
 | |
| /* YYNTOKENS -- Number of terminals.  */
 | |
| #define YYNTOKENS  65
 | |
| /* YYNNTS -- Number of nonterminals.  */
 | |
| #define YYNNTS  22
 | |
| /* YYNRULES -- Number of rules.  */
 | |
| #define YYNRULES  140
 | |
| /* YYNSTATES -- Number of states.  */
 | |
| #define YYNSTATES  275
 | |
| 
 | |
| /* YYTRANSLATE[YYX] -- Symbol number corresponding to YYX as returned
 | |
|    by yylex, with out-of-bounds checking.  */
 | |
| #define YYUNDEFTOK  2
 | |
| #define YYMAXUTOK   298
 | |
| 
 | |
| #define YYTRANSLATE(YYX)                                                \
 | |
|   ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
 | |
| 
 | |
| /* YYTRANSLATE[TOKEN-NUM] -- Symbol number corresponding to TOKEN-NUM
 | |
|    as returned by yylex, without out-of-bounds checking.  */
 | |
| static const yytype_uint8 yytranslate[] =
 | |
| {
 | |
|        0,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,    56,    53,     2,     2,
 | |
|       57,    58,    51,    49,    45,    50,    60,    52,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,    59,    55,
 | |
|       47,    46,    48,    54,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,    61,     2,    62,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,    63,    44,    64,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
 | |
|        2,     2,     2,     2,     2,     2,     1,     2,     3,     4,
 | |
|        5,     6,     7,     8,     9,    10,    11,    12,    13,    14,
 | |
|       15,    16,    17,    18,    19,    20,    21,    22,    23,    24,
 | |
|       25,    26,    27,    28,    29,    30,    31,    32,    33,    34,
 | |
|       35,    36,    37,    38,    39,    40,    41,    42,    43
 | |
| };
 | |
| 
 | |
| #if YYDEBUG
 | |
|   /* YYRLINE[YYN] -- Source line where rule number YYN was defined.  */
 | |
| static const yytype_uint16 yyrline[] =
 | |
| {
 | |
|        0,   270,   270,   273,   278,   281,   291,   294,   299,   302,
 | |
|      307,   311,   316,   321,   326,   331,   334,   339,   343,   347,
 | |
|      352,   364,   368,   372,   376,   380,   384,   388,   392,   396,
 | |
|      400,   404,   408,   412,   416,   420,   424,   428,   432,   436,
 | |
|      440,   444,   448,   452,   456,   460,   464,   468,   473,   482,
 | |
|      489,   501,   515,   520,   526,   529,   534,   539,   546,   546,
 | |
|      550,   550,   557,   560,   563,   569,   572,   577,   580,   583,
 | |
|      589,   592,   595,   603,   607,   610,   613,   616,   619,   622,
 | |
|      625,   628,   631,   635,   641,   644,   647,   650,   653,   656,
 | |
|      659,   662,   665,   668,   671,   674,   677,   680,   683,   686,
 | |
|      689,   696,   700,   704,   716,   721,   722,   723,   724,   727,
 | |
|      730,   735,   740,   743,   746,   749,   752,   755,   758,   761,
 | |
|      764,   767,   770,   773,   776,   779,   782,   785,   788,   791,
 | |
|      796,   799,   800,   801,   804,   807,   810,   813,   817,   821,
 | |
|      824
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if YYDEBUG || YYERROR_VERBOSE || 1
 | |
| /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
 | |
|    First, the terminals, then, starting at YYNTOKENS, nonterminals.  */
 | |
| static const char *const yytname[] =
 | |
| {
 | |
|   "$end", "error", "$undefined", "INVALID_CHARACTER", "IDENT", "FIELD",
 | |
|   "LITERAL", "FORMAT", "\"..\"", "\"%=\"", "\"==\"", "\"!=\"", "\"//\"",
 | |
|   "\"as\"", "\"def\"", "\"module\"", "\"import\"", "\"if\"", "\"then\"",
 | |
|   "\"else\"", "\"elif\"", "\"reduce\"", "\"foreach\"", "\"end\"",
 | |
|   "\"and\"", "\"or\"", "\"try\"", "\"catch\"", "\"label\"", "\"break\"",
 | |
|   "\"__loc__\"", "\"|=\"", "\"+=\"", "\"-=\"", "\"*=\"", "\"/=\"",
 | |
|   "\"//=\"", "\"<=\"", "\">=\"", "QQSTRING_START", "QQSTRING_TEXT",
 | |
|   "QQSTRING_INTERP_START", "QQSTRING_INTERP_END", "QQSTRING_END", "'|'",
 | |
|   "','", "'='", "'<'", "'>'", "'+'", "'-'", "'*'", "'/'", "'%'", "'?'",
 | |
|   "';'", "'$'", "'('", "')'", "':'", "'.'", "'['", "']'", "'{'", "'}'",
 | |
|   "$accept", "TopLevel", "Module", "Imports", "FuncDefs", "Exp", "Import",
 | |
|   "FuncDef", "Params", "Param", "String", "@1", "@2", "QQString",
 | |
|   "ElseBody", "ExpD", "Term", "Args", "Arg", "Keyword", "MkDict",
 | |
|   "MkDictPair", YY_NULLPTR
 | |
| };
 | |
| #endif
 | |
| 
 | |
| # ifdef YYPRINT
 | |
| /* YYTOKNUM[NUM] -- (External) token number corresponding to the
 | |
|    (internal) symbol number NUM (which must be that of a token).  */
 | |
| static const yytype_uint16 yytoknum[] =
 | |
| {
 | |
|        0,   256,   257,   258,   259,   260,   261,   262,   263,   264,
 | |
|      265,   266,   267,   268,   269,   270,   271,   272,   273,   274,
 | |
|      275,   276,   277,   278,   279,   280,   281,   282,   283,   284,
 | |
|      285,   286,   287,   288,   289,   290,   291,   292,   293,   294,
 | |
|      295,   296,   297,   298,   124,    44,    61,    60,    62,    43,
 | |
|       45,    42,    47,    37,    63,    59,    36,    40,    41,    58,
 | |
|       46,    91,    93,   123,   125
 | |
| };
 | |
| # endif
 | |
| 
 | |
| #define YYPACT_NINF -111
 | |
| 
 | |
| #define yypact_value_is_default(Yystate) \
 | |
|   (!!((Yystate) == (-111)))
 | |
| 
 | |
| #define YYTABLE_NINF -131
 | |
| 
 | |
| #define yytable_value_is_error(Yytable_value) \
 | |
|   (!!((Yytable_value) == (-131)))
 | |
| 
 | |
|   /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
 | |
|      STATE-NUM.  */
 | |
| static const yytype_int16 yypact[] =
 | |
| {
 | |
|      -11,   775,    40,    27,    -7,     7,  -111,    15,  -111,    51,
 | |
|      775,   610,   610,   775,     3,     0,  -111,   775,    23,   456,
 | |
|      249,   393,   311,  1167,   775,  -111,    -3,  -111,    -4,   775,
 | |
|       27,   775,  -111,  -111,   -10,  1542,     6,     9,    37,    61,
 | |
|     -111,    64,  -111,   -15,  -111,  -111,    13,  1043,  -111,    71,
 | |
|       15,    19,    16,  -111,   855,   -32,    18,  -111,  -111,  -111,
 | |
|     -111,  -111,  -111,  -111,  -111,  -111,  -111,  -111,  -111,  -111,
 | |
|     -111,  -111,  -111,  -111,  -111,   482,    44,    46,    11,    62,
 | |
|      775,   775,   775,   775,   775,   775,   775,   775,   775,   775,
 | |
|      775,   775,   775,   775,   775,   775,   775,   775,   775,   775,
 | |
|      775,   775,   775,   775,  -111,  -111,  1696,    56,    55,    -4,
 | |
|      144,    99,  -111,  1696,   775,  -111,  1696,   -29,  -111,  -111,
 | |
|        4,   775,   543,    57,    58,   569,    72,  -111,     1,  -111,
 | |
|     -111,  -111,  -111,  -111,  -111,   363,  -111,   695,    59,  1074,
 | |
|      695,   695,  -111,   363,  1758,   306,   306,  1727,  1776,  1012,
 | |
|     1758,  1758,  1758,  1758,  1758,  1758,   306,   306,  1696,  1727,
 | |
|     1758,   306,   306,   -15,   -15,    65,    65,    65,  -111,   111,
 | |
|       68,    63,   775,    69,   809,    20,  -111,   775,  -111,     5,
 | |
|     -111,   114,   -24,  -111,  1214,  -111,  1496,   122,   123,  -111,
 | |
|     -111,   775,  -111,   775,  -111,    83,  -111,   695,    85,     2,
 | |
|       73,    74,    85,    85,  -111,    92,  -111,  -111,   901,  -111,
 | |
|      629,    88,   655,   133,  -111,  -111,  -111,     4,    84,  -111,
 | |
|      775,   775,  -111,    87,    89,  1696,  1573,  -111,   695,   695,
 | |
|      695,   775,    93,   100,   947,  -111,  -111,  1261,   715,  -111,
 | |
|      775,  1619,  1665,   775,   775,  -111,    85,    85,    85,  1696,
 | |
|     -111,  -111,   101,  -111,  -111,  1308,  1355,  -111,   775,  1402,
 | |
|     1449,  -111,  -111,  -111,  1496,   775,   775,  -111,  1105,   993,
 | |
|     -111,   775,  -111,  1136,  -111
 | |
| };
 | |
| 
 | |
|   /* YYDEFACT[STATE-NUM] -- Default reduction number in state STATE-NUM.
 | |
|      Performed when YYTABLE does not specify something else to do.  Zero
 | |
|      means the default is an error.  */
 | |
| static const yytype_uint8 yydefact[] =
 | |
| {
 | |
|        4,     0,     0,     6,   103,    79,    94,    96,    71,     0,
 | |
|        0,     0,     0,     0,     0,     0,    58,     0,     0,     0,
 | |
|        0,     0,     0,     0,     0,    95,    47,     1,     0,     8,
 | |
|        6,     0,    75,    60,     0,     0,     0,     0,    18,     0,
 | |
|       73,     0,    62,    32,   102,   101,     0,     0,    82,     0,
 | |
|        0,    81,     0,    99,     0,     0,   138,   112,   113,   114,
 | |
|      115,   116,   117,   118,   119,   120,   121,   122,   123,   124,
 | |
|      125,   126,   127,   128,   129,     0,   137,     0,     0,   131,
 | |
|        0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,     0,    21,     5,    10,    78,     0,     0,
 | |
|        0,     0,     3,     2,     8,     7,   111,     0,   109,    62,
 | |
|        0,     0,     0,     0,     0,     0,     0,    72,     0,   105,
 | |
|       97,    83,    77,   106,    98,     0,   108,     0,     0,     0,
 | |
|        0,     0,   100,     0,    40,    41,    42,    25,    24,    23,
 | |
|       27,    31,    34,    36,    39,    26,    45,    46,    28,    29,
 | |
|       22,    43,    44,    30,    33,    35,    37,    38,    74,     0,
 | |
|       80,     0,     0,    87,     0,     0,     9,     0,   104,     0,
 | |
|       57,     0,     0,    54,     0,    16,     0,     0,     0,    19,
 | |
|       17,     0,    63,     0,    59,     0,   133,     0,   134,    69,
 | |
|        0,     0,   136,   135,   132,     0,    76,   107,     0,    86,
 | |
|        0,    85,     0,     0,   110,    61,    56,     0,     0,    52,
 | |
|        0,     0,    15,     0,     0,    20,     0,    68,     0,     0,
 | |
|        0,     0,    93,    92,     0,    84,    49,     0,     0,    55,
 | |
|        0,     0,     0,     0,     0,    64,    67,   140,   139,    11,
 | |
|       90,    89,    91,    50,    48,     0,     0,    66,     0,     0,
 | |
|        0,    88,    51,    53,     0,     0,     0,    65,     0,     0,
 | |
|       12,     0,    14,     0,    13
 | |
| };
 | |
| 
 | |
|   /* YYPGOTO[NTERM-NUM].  */
 | |
| static const yytype_int8 yypgoto[] =
 | |
| {
 | |
|     -111,  -111,  -111,   126,    39,    -1,  -111,    -8,  -111,   -60,
 | |
|       -5,  -111,  -111,    41,  -105,   -89,    -6,  -111,   -14,  -111,
 | |
|     -110,  -111
 | |
| };
 | |
| 
 | |
|   /* YYDEFGOTO[NTERM-NUM].  */
 | |
| static const yytype_int16 yydefgoto[] =
 | |
| {
 | |
|       -1,     2,     3,    29,   112,   106,    30,    24,   182,   183,
 | |
|       25,    42,   119,   128,   222,   198,    26,   117,   118,    77,
 | |
|       78,    79
 | |
| };
 | |
| 
 | |
|   /* YYTABLE[YYPACT[STATE-NUM]] -- What to do in state STATE-NUM.  If
 | |
|      positive, shift that token.  If negative, reduce the rule whose
 | |
|      number is the opposite.  If YYTABLE_NINF, syntax error.  */
 | |
| static const yytype_int16 yytable[] =
 | |
| {
 | |
|       23,    40,   107,    50,     1,    36,    37,   107,   180,    35,
 | |
|      108,   107,    38,   135,   107,    51,    43,    76,    47,   123,
 | |
|       54,   114,   124,   111,   212,   196,   177,    44,   113,   178,
 | |
|      116,   217,   136,   204,   218,    16,   101,   102,   103,   104,
 | |
|       27,   192,   193,    28,   194,   192,   193,   120,   215,   121,
 | |
|       31,   202,   203,    45,    33,    34,    41,   109,   110,    39,
 | |
|      181,    32,   109,   110,   125,   126,   109,   110,   127,   109,
 | |
|      110,   129,   131,   132,   139,   142,   213,   137,   133,   144,
 | |
|      145,   146,   147,   148,   149,   150,   151,   152,   153,   154,
 | |
|      155,   156,   157,   158,   159,   160,   161,   162,   163,   164,
 | |
|      165,   166,   167,   140,   170,   141,   114,   143,   227,   174,
 | |
|      168,   169,   175,   187,   188,   205,   191,   200,   216,   104,
 | |
|      184,   186,   206,   209,   190,   207,   223,   224,   135,   228,
 | |
|       76,   199,   229,   230,   199,   199,   231,   238,    76,   246,
 | |
|      247,   248,   235,   240,   243,   171,   244,   250,     4,     5,
 | |
|        6,     7,     8,   176,   251,   261,   115,   239,     9,   267,
 | |
|      179,    10,     0,   214,     0,    11,    12,     0,     0,     0,
 | |
|       13,   208,    14,    15,     0,     0,   116,     0,     0,     0,
 | |
|        0,     0,     0,    16,     0,     0,     0,     0,     0,     0,
 | |
|      225,   199,   226,     0,    17,     0,     0,     0,     0,     0,
 | |
|       18,    19,     0,   172,    20,    21,   173,    22,     0,   234,
 | |
|        0,   237,     0,     0,     0,     0,     0,     0,     0,   241,
 | |
|      242,     0,   199,   199,   199,     0,     0,     0,     0,     0,
 | |
|      249,     0,     0,     0,     0,     0,     0,   255,     0,   256,
 | |
|        0,     0,   259,   260,     0,     0,     0,     0,     0,   -70,
 | |
|       48,     0,     0,    49,   -70,     0,    50,   264,   -70,   -70,
 | |
|      -70,   -70,   -70,     0,   268,   269,     0,   -70,   -70,   -70,
 | |
|      273,     0,   -70,   -70,   -70,     0,   -70,     0,     0,     0,
 | |
|      -70,   -70,   -70,   -70,   -70,   -70,   -70,   -70,    16,     0,
 | |
|        0,   -70,     0,   -70,   -70,   -70,   -70,   -70,   -70,   -70,
 | |
|      -70,   -70,   -70,   -70,   -70,     0,     0,   -70,   -70,   -70,
 | |
|      -70,   -70,    55,   -70,     0,    56,  -131,  -131,    50,     0,
 | |
|        0,     0,     0,     0,    57,    58,    59,    60,    61,    62,
 | |
|       63,    64,    65,    66,    67,    68,    69,    70,    71,    72,
 | |
|       73,    74,     0,  -131,  -131,     0,     0,     0,     0,     0,
 | |
|       16,     0,     0,  -131,  -131,    99,   100,   101,   102,   103,
 | |
|      104,     0,     0,     0,   195,     0,     0,    56,    75,     0,
 | |
|       50,     0,     0,     0,     0,  -130,    57,    58,    59,    60,
 | |
|       61,    62,    63,    64,    65,    66,    67,    68,    69,    70,
 | |
|       71,    72,    73,    74,    52,     0,     0,     4,     5,     6,
 | |
|        7,     8,    16,     0,     0,     0,     0,     9,     0,     0,
 | |
|       10,     0,     0,     0,    11,    12,     0,     0,     0,    13,
 | |
|       75,    14,    15,     0,     0,     0,     0,  -130,     0,     0,
 | |
|        0,     0,    16,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,    17,     0,     0,     0,     0,     0,    18,
 | |
|       19,     0,     0,    20,    21,    53,    22,    46,     0,     0,
 | |
|        4,     5,     6,     7,     8,     0,     0,     0,     0,     0,
 | |
|        9,     0,     0,    10,     0,     0,     0,    11,    12,     0,
 | |
|        0,     0,    13,   138,    14,    15,     4,     5,     6,     7,
 | |
|        8,     0,     0,     0,     0,    16,     9,     0,     0,    10,
 | |
|        0,     0,     0,    11,    12,     0,    17,     0,    13,     0,
 | |
|       14,    15,    18,    19,     0,     0,    20,    21,     0,    22,
 | |
|        0,    16,     0,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,    17,     0,     0,     0,     0,     0,    18,    19,
 | |
|        0,     0,    20,    21,   185,    22,     0,     4,     5,     6,
 | |
|        7,     8,     0,     0,     0,     0,     0,     9,     0,     0,
 | |
|       10,     0,     0,     0,    11,    12,     0,     0,     0,    13,
 | |
|      189,    14,    15,     4,     5,     6,     7,     8,     0,     0,
 | |
|        0,     0,    16,     9,     0,     0,    10,     0,     0,     0,
 | |
|       11,    12,     0,    17,     0,    13,     0,    14,    15,    18,
 | |
|       19,     0,     0,    20,    21,     0,    22,     0,    16,     0,
 | |
|        0,     0,     0,     0,     4,     5,     6,     7,     8,    17,
 | |
|        0,     0,     0,     0,     0,    18,    19,     0,     0,    20,
 | |
|       21,     0,    22,     4,     5,     6,     7,     8,     0,    15,
 | |
|        0,     0,     0,     9,     0,     0,    10,     0,     0,    16,
 | |
|       11,    12,     0,     0,     0,    13,     0,    14,    15,     4,
 | |
|        5,     6,     7,     8,     0,     0,    18,    19,    16,     9,
 | |
|       20,    21,    10,    22,     0,     0,    11,    12,     0,    17,
 | |
|        0,    13,     0,    14,    15,    18,    19,     0,     0,    20,
 | |
|       21,   233,    22,     0,    16,     0,     0,     0,     0,     4,
 | |
|        5,     6,     7,     8,     0,    17,     0,     0,     0,     0,
 | |
|      236,    18,    19,     0,     0,    20,    21,     0,    22,     4,
 | |
|        5,     6,     7,     8,    15,     0,     0,     0,     0,     9,
 | |
|        0,     0,    10,     0,    16,     0,    11,    12,     0,     0,
 | |
|        0,    13,     0,    14,    15,   197,     0,     0,     0,     0,
 | |
|        0,    18,    19,     0,    16,    20,    21,     0,    22,     0,
 | |
|        0,     0,     0,     0,     0,    17,     0,     0,     0,     0,
 | |
|      254,    18,    19,     0,     0,    20,    21,     0,    22,     4,
 | |
|        5,     6,     7,     8,     0,     0,     0,     0,     0,     9,
 | |
|        0,     0,    10,     0,     0,     0,    11,    12,     0,     0,
 | |
|        0,    13,     0,    14,    15,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,     0,    16,     0,     0,     0,    80,    81,
 | |
|       82,    83,     0,     0,     0,    17,     0,     0,     0,     0,
 | |
|        0,    18,    19,    84,    85,    20,    21,     0,    22,     0,
 | |
|       86,    87,    88,    89,    90,    91,    92,    93,     0,     0,
 | |
|        0,     0,     0,    94,    95,    96,    97,    98,    99,   100,
 | |
|      101,   102,   103,   104,    80,    81,    82,    83,   210,     0,
 | |
|        0,   211,     0,     0,     0,     0,     0,     0,     0,    84,
 | |
|       85,     0,     0,     0,     0,     0,    86,    87,    88,    89,
 | |
|       90,    91,    92,    93,     0,     0,     0,     0,     0,    94,
 | |
|       95,    96,    97,    98,    99,   100,   101,   102,   103,   104,
 | |
|       80,    81,    82,    83,     0,     0,     0,   134,     0,     0,
 | |
|        0,     0,     0,     0,     0,    84,    85,     0,     0,     0,
 | |
|        0,     0,    86,    87,    88,    89,    90,    91,    92,    93,
 | |
|        0,     0,     0,     0,     0,    94,    95,    96,    97,    98,
 | |
|       99,   100,   101,   102,   103,   104,    80,    81,    82,    83,
 | |
|        0,     0,     0,   232,     0,     0,     0,     0,     0,     0,
 | |
|        0,    84,    85,     0,     0,     0,     0,     0,    86,    87,
 | |
|       88,    89,    90,    91,    92,    93,     0,     0,     0,     0,
 | |
|        0,    94,    95,    96,    97,    98,    99,   100,   101,   102,
 | |
|      103,   104,    80,    81,    82,    83,     0,     0,     0,   252,
 | |
|        0,     0,     0,     0,     0,     0,     0,    84,    85,     0,
 | |
|        0,     0,    81,    82,    86,    87,    88,    89,    90,    91,
 | |
|       92,    93,     0,     0,     0,     0,    84,    94,    95,    96,
 | |
|       97,    98,    99,   100,   101,   102,   103,   104,   271,    92,
 | |
|       93,   272,    80,    81,    82,    83,     0,     0,     0,    97,
 | |
|       98,    99,   100,   101,   102,   103,   104,    84,    85,     0,
 | |
|        0,     0,     0,     0,    86,    87,    88,    89,    90,    91,
 | |
|       92,    93,     0,    80,    81,    82,    83,    94,    95,    96,
 | |
|       97,    98,    99,   100,   101,   102,   103,   104,    84,    85,
 | |
|        0,   130,     0,     0,     0,    86,    87,    88,    89,    90,
 | |
|       91,    92,    93,     0,    80,    81,    82,    83,    94,    95,
 | |
|       96,    97,    98,    99,   100,   101,   102,   103,   104,    84,
 | |
|       85,     0,   201,     0,     0,     0,    86,    87,    88,    89,
 | |
|       90,    91,    92,    93,     0,    80,    81,    82,    83,    94,
 | |
|       95,    96,    97,    98,    99,   100,   101,   102,   103,   104,
 | |
|       84,    85,     0,   270,     0,     0,     0,    86,    87,    88,
 | |
|       89,    90,    91,    92,    93,     0,    80,    81,    82,    83,
 | |
|       94,    95,    96,    97,    98,    99,   100,   101,   102,   103,
 | |
|      104,    84,    85,     0,   274,     0,     0,     0,    86,    87,
 | |
|       88,    89,    90,    91,    92,    93,     0,     0,     0,     0,
 | |
|        0,    94,    95,    96,    97,    98,    99,   100,   101,   102,
 | |
|      103,   104,   105,    80,    81,    82,    83,     0,     0,     0,
 | |
|        0,     0,     0,     0,     0,     0,     0,     0,    84,    85,
 | |
|        0,     0,     0,     0,     0,    86,    87,    88,    89,    90,
 | |
|       91,    92,    93,     0,     0,     0,     0,     0,    94,    95,
 | |
|       96,    97,    98,    99,   100,   101,   102,   103,   104,   219,
 | |
|       80,    81,    82,    83,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,     0,     0,    84,    85,     0,     0,     0,
 | |
|        0,     0,    86,    87,    88,    89,    90,    91,    92,    93,
 | |
|        0,     0,     0,     0,     0,    94,    95,    96,    97,    98,
 | |
|       99,   100,   101,   102,   103,   104,   253,    80,    81,    82,
 | |
|       83,     0,     0,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,    84,    85,     0,     0,     0,     0,     0,    86,
 | |
|       87,    88,    89,    90,    91,    92,    93,     0,     0,     0,
 | |
|        0,     0,    94,    95,    96,    97,    98,    99,   100,   101,
 | |
|      102,   103,   104,   262,    80,    81,    82,    83,     0,     0,
 | |
|        0,     0,     0,     0,     0,     0,     0,     0,     0,    84,
 | |
|       85,     0,     0,     0,     0,     0,    86,    87,    88,    89,
 | |
|       90,    91,    92,    93,     0,     0,     0,     0,     0,    94,
 | |
|       95,    96,    97,    98,    99,   100,   101,   102,   103,   104,
 | |
|      263,    80,    81,    82,    83,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,     0,     0,     0,    84,    85,     0,     0,
 | |
|        0,     0,     0,    86,    87,    88,    89,    90,    91,    92,
 | |
|       93,     0,     0,     0,     0,     0,    94,    95,    96,    97,
 | |
|       98,    99,   100,   101,   102,   103,   104,   265,    80,    81,
 | |
|       82,    83,     0,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,    84,    85,     0,     0,     0,     0,     0,
 | |
|       86,    87,    88,    89,    90,    91,    92,    93,     0,     0,
 | |
|        0,     0,     0,    94,    95,    96,    97,    98,    99,   100,
 | |
|      101,   102,   103,   104,   266,    80,    81,    82,    83,     0,
 | |
|        0,     0,     0,     0,     0,   220,   221,     0,     0,     0,
 | |
|       84,    85,     0,     0,     0,     0,     0,    86,    87,    88,
 | |
|       89,    90,    91,    92,    93,     0,     0,     0,     0,     0,
 | |
|       94,    95,    96,    97,    98,    99,   100,   101,   102,   103,
 | |
|      104,    80,    81,    82,    83,     0,     0,     0,     0,     0,
 | |
|      122,     0,     0,     0,     0,     0,    84,    85,     0,     0,
 | |
|        0,     0,     0,    86,    87,    88,    89,    90,    91,    92,
 | |
|       93,     0,    80,    81,    82,    83,    94,    95,    96,    97,
 | |
|       98,    99,   100,   101,   102,   103,   104,    84,    85,     0,
 | |
|        0,     0,     0,     0,    86,    87,    88,    89,    90,    91,
 | |
|       92,    93,     0,     0,     0,   245,     0,    94,    95,    96,
 | |
|       97,    98,    99,   100,   101,   102,   103,   104,    80,    81,
 | |
|       82,    83,     0,     0,     0,     0,     0,     0,     0,     0,
 | |
|        0,     0,   257,    84,    85,     0,     0,     0,     0,     0,
 | |
|       86,    87,    88,    89,    90,    91,    92,    93,     0,     0,
 | |
|        0,     0,     0,    94,    95,    96,    97,    98,    99,   100,
 | |
|      101,   102,   103,   104,    80,    81,    82,    83,     0,     0,
 | |
|        0,     0,     0,   258,     0,     0,     0,     0,     0,    84,
 | |
|       85,     0,     0,     0,     0,     0,    86,    87,    88,    89,
 | |
|       90,    91,    92,    93,     0,    80,    81,    82,    83,    94,
 | |
|       95,    96,    97,    98,    99,   100,   101,   102,   103,   104,
 | |
|       84,    85,     0,     0,     0,     0,     0,    86,    87,    88,
 | |
|       89,    90,    91,    92,    93,     0,    80,    81,    82,    83,
 | |
|       94,    95,    96,    97,    98,    99,   100,   101,   102,   103,
 | |
|      104,    84,    85,     0,     0,     0,     0,     0,    86,    87,
 | |
|       88,    89,    90,    91,    92,    93,     0,  -131,    81,    82,
 | |
|        0,     0,     0,    96,    97,    98,    99,   100,   101,   102,
 | |
|      103,   104,    84,    85,     0,     0,    81,    82,     0,  -131,
 | |
|     -131,  -131,  -131,  -131,  -131,    92,    93,     0,     0,     0,
 | |
|        0,     0,     0,     0,  -131,    97,    98,    99,   100,   101,
 | |
|      102,   103,   104,    92,    93,     0,     0,     0,     0,     0,
 | |
|        0,     0,     0,    97,    98,    99,   100,   101,   102,   103,
 | |
|      104
 | |
| };
 | |
| 
 | |
| static const yytype_int16 yycheck[] =
 | |
| {
 | |
|        1,     1,     5,     7,    15,    11,    12,     5,     4,    10,
 | |
|       13,     5,    13,    45,     5,    20,    17,    22,    19,    13,
 | |
|       21,    29,    13,    28,     4,   135,    55,     4,    29,    58,
 | |
|       31,    55,    64,   143,    58,    39,    51,    52,    53,    54,
 | |
|        0,    40,    41,    16,    43,    40,    41,    57,    43,    59,
 | |
|       57,   140,   141,    30,    39,     4,    56,    60,    61,    56,
 | |
|       56,    54,    60,    61,    27,     4,    60,    61,     4,    60,
 | |
|       61,    58,     1,    54,    75,    64,    56,    59,    62,    80,
 | |
|       81,    82,    83,    84,    85,    86,    87,    88,    89,    90,
 | |
|       91,    92,    93,    94,    95,    96,    97,    98,    99,   100,
 | |
|      101,   102,   103,    59,   109,    59,   114,    45,   197,   110,
 | |
|       54,    56,    13,    56,    56,     4,    44,    58,     4,    54,
 | |
|      121,   122,    54,    54,   125,    62,     4,     4,    45,    44,
 | |
|      135,   137,    59,    59,   140,   141,    44,     4,   143,   228,
 | |
|      229,   230,    54,    59,    57,     1,    57,    54,     4,     5,
 | |
|        6,     7,     8,   114,    54,    54,    30,   217,    14,   264,
 | |
|      119,    17,    -1,   177,    -1,    21,    22,    -1,    -1,    -1,
 | |
|       26,   172,    28,    29,    -1,    -1,   177,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    39,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|      191,   197,   193,    -1,    50,    -1,    -1,    -1,    -1,    -1,
 | |
|       56,    57,    -1,    59,    60,    61,    62,    63,    -1,   210,
 | |
|       -1,   212,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   220,
 | |
|      221,    -1,   228,   229,   230,    -1,    -1,    -1,    -1,    -1,
 | |
|      231,    -1,    -1,    -1,    -1,    -1,    -1,   238,    -1,   240,
 | |
|       -1,    -1,   243,   244,    -1,    -1,    -1,    -1,    -1,     0,
 | |
|        1,    -1,    -1,     4,     5,    -1,     7,   258,     9,    10,
 | |
|       11,    12,    13,    -1,   265,   266,    -1,    18,    19,    20,
 | |
|      271,    -1,    23,    24,    25,    -1,    27,    -1,    -1,    -1,
 | |
|       31,    32,    33,    34,    35,    36,    37,    38,    39,    -1,
 | |
|       -1,    42,    -1,    44,    45,    46,    47,    48,    49,    50,
 | |
|       51,    52,    53,    54,    55,    -1,    -1,    58,    59,    60,
 | |
|       61,    62,     1,    64,    -1,     4,    10,    11,     7,    -1,
 | |
|       -1,    -1,    -1,    -1,    13,    14,    15,    16,    17,    18,
 | |
|       19,    20,    21,    22,    23,    24,    25,    26,    27,    28,
 | |
|       29,    30,    -1,    37,    38,    -1,    -1,    -1,    -1,    -1,
 | |
|       39,    -1,    -1,    47,    48,    49,    50,    51,    52,    53,
 | |
|       54,    -1,    -1,    -1,     1,    -1,    -1,     4,    57,    -1,
 | |
|        7,    -1,    -1,    -1,    -1,    64,    13,    14,    15,    16,
 | |
|       17,    18,    19,    20,    21,    22,    23,    24,    25,    26,
 | |
|       27,    28,    29,    30,     1,    -1,    -1,     4,     5,     6,
 | |
|        7,     8,    39,    -1,    -1,    -1,    -1,    14,    -1,    -1,
 | |
|       17,    -1,    -1,    -1,    21,    22,    -1,    -1,    -1,    26,
 | |
|       57,    28,    29,    -1,    -1,    -1,    -1,    64,    -1,    -1,
 | |
|       -1,    -1,    39,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    50,    -1,    -1,    -1,    -1,    -1,    56,
 | |
|       57,    -1,    -1,    60,    61,    62,    63,     1,    -1,    -1,
 | |
|        4,     5,     6,     7,     8,    -1,    -1,    -1,    -1,    -1,
 | |
|       14,    -1,    -1,    17,    -1,    -1,    -1,    21,    22,    -1,
 | |
|       -1,    -1,    26,     1,    28,    29,     4,     5,     6,     7,
 | |
|        8,    -1,    -1,    -1,    -1,    39,    14,    -1,    -1,    17,
 | |
|       -1,    -1,    -1,    21,    22,    -1,    50,    -1,    26,    -1,
 | |
|       28,    29,    56,    57,    -1,    -1,    60,    61,    -1,    63,
 | |
|       -1,    39,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    50,    -1,    -1,    -1,    -1,    -1,    56,    57,
 | |
|       -1,    -1,    60,    61,     1,    63,    -1,     4,     5,     6,
 | |
|        7,     8,    -1,    -1,    -1,    -1,    -1,    14,    -1,    -1,
 | |
|       17,    -1,    -1,    -1,    21,    22,    -1,    -1,    -1,    26,
 | |
|        1,    28,    29,     4,     5,     6,     7,     8,    -1,    -1,
 | |
|       -1,    -1,    39,    14,    -1,    -1,    17,    -1,    -1,    -1,
 | |
|       21,    22,    -1,    50,    -1,    26,    -1,    28,    29,    56,
 | |
|       57,    -1,    -1,    60,    61,    -1,    63,    -1,    39,    -1,
 | |
|       -1,    -1,    -1,    -1,     4,     5,     6,     7,     8,    50,
 | |
|       -1,    -1,    -1,    -1,    -1,    56,    57,    -1,    -1,    60,
 | |
|       61,    -1,    63,     4,     5,     6,     7,     8,    -1,    29,
 | |
|       -1,    -1,    -1,    14,    -1,    -1,    17,    -1,    -1,    39,
 | |
|       21,    22,    -1,    -1,    -1,    26,    -1,    28,    29,     4,
 | |
|        5,     6,     7,     8,    -1,    -1,    56,    57,    39,    14,
 | |
|       60,    61,    17,    63,    -1,    -1,    21,    22,    -1,    50,
 | |
|       -1,    26,    -1,    28,    29,    56,    57,    -1,    -1,    60,
 | |
|       61,    62,    63,    -1,    39,    -1,    -1,    -1,    -1,     4,
 | |
|        5,     6,     7,     8,    -1,    50,    -1,    -1,    -1,    -1,
 | |
|       55,    56,    57,    -1,    -1,    60,    61,    -1,    63,     4,
 | |
|        5,     6,     7,     8,    29,    -1,    -1,    -1,    -1,    14,
 | |
|       -1,    -1,    17,    -1,    39,    -1,    21,    22,    -1,    -1,
 | |
|       -1,    26,    -1,    28,    29,    50,    -1,    -1,    -1,    -1,
 | |
|       -1,    56,    57,    -1,    39,    60,    61,    -1,    63,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    50,    -1,    -1,    -1,    -1,
 | |
|       55,    56,    57,    -1,    -1,    60,    61,    -1,    63,     4,
 | |
|        5,     6,     7,     8,    -1,    -1,    -1,    -1,    -1,    14,
 | |
|       -1,    -1,    17,    -1,    -1,    -1,    21,    22,    -1,    -1,
 | |
|       -1,    26,    -1,    28,    29,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    39,    -1,    -1,    -1,     9,    10,
 | |
|       11,    12,    -1,    -1,    -1,    50,    -1,    -1,    -1,    -1,
 | |
|       -1,    56,    57,    24,    25,    60,    61,    -1,    63,    -1,
 | |
|       31,    32,    33,    34,    35,    36,    37,    38,    -1,    -1,
 | |
|       -1,    -1,    -1,    44,    45,    46,    47,    48,    49,    50,
 | |
|       51,    52,    53,    54,     9,    10,    11,    12,    59,    -1,
 | |
|       -1,    62,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    24,
 | |
|       25,    -1,    -1,    -1,    -1,    -1,    31,    32,    33,    34,
 | |
|       35,    36,    37,    38,    -1,    -1,    -1,    -1,    -1,    44,
 | |
|       45,    46,    47,    48,    49,    50,    51,    52,    53,    54,
 | |
|        9,    10,    11,    12,    -1,    -1,    -1,    62,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    24,    25,    -1,    -1,    -1,
 | |
|       -1,    -1,    31,    32,    33,    34,    35,    36,    37,    38,
 | |
|       -1,    -1,    -1,    -1,    -1,    44,    45,    46,    47,    48,
 | |
|       49,    50,    51,    52,    53,    54,     9,    10,    11,    12,
 | |
|       -1,    -1,    -1,    62,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    24,    25,    -1,    -1,    -1,    -1,    -1,    31,    32,
 | |
|       33,    34,    35,    36,    37,    38,    -1,    -1,    -1,    -1,
 | |
|       -1,    44,    45,    46,    47,    48,    49,    50,    51,    52,
 | |
|       53,    54,     9,    10,    11,    12,    -1,    -1,    -1,    62,
 | |
|       -1,    -1,    -1,    -1,    -1,    -1,    -1,    24,    25,    -1,
 | |
|       -1,    -1,    10,    11,    31,    32,    33,    34,    35,    36,
 | |
|       37,    38,    -1,    -1,    -1,    -1,    24,    44,    45,    46,
 | |
|       47,    48,    49,    50,    51,    52,    53,    54,    55,    37,
 | |
|       38,    58,     9,    10,    11,    12,    -1,    -1,    -1,    47,
 | |
|       48,    49,    50,    51,    52,    53,    54,    24,    25,    -1,
 | |
|       -1,    -1,    -1,    -1,    31,    32,    33,    34,    35,    36,
 | |
|       37,    38,    -1,     9,    10,    11,    12,    44,    45,    46,
 | |
|       47,    48,    49,    50,    51,    52,    53,    54,    24,    25,
 | |
|       -1,    58,    -1,    -1,    -1,    31,    32,    33,    34,    35,
 | |
|       36,    37,    38,    -1,     9,    10,    11,    12,    44,    45,
 | |
|       46,    47,    48,    49,    50,    51,    52,    53,    54,    24,
 | |
|       25,    -1,    58,    -1,    -1,    -1,    31,    32,    33,    34,
 | |
|       35,    36,    37,    38,    -1,     9,    10,    11,    12,    44,
 | |
|       45,    46,    47,    48,    49,    50,    51,    52,    53,    54,
 | |
|       24,    25,    -1,    58,    -1,    -1,    -1,    31,    32,    33,
 | |
|       34,    35,    36,    37,    38,    -1,     9,    10,    11,    12,
 | |
|       44,    45,    46,    47,    48,    49,    50,    51,    52,    53,
 | |
|       54,    24,    25,    -1,    58,    -1,    -1,    -1,    31,    32,
 | |
|       33,    34,    35,    36,    37,    38,    -1,    -1,    -1,    -1,
 | |
|       -1,    44,    45,    46,    47,    48,    49,    50,    51,    52,
 | |
|       53,    54,    55,     9,    10,    11,    12,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    24,    25,
 | |
|       -1,    -1,    -1,    -1,    -1,    31,    32,    33,    34,    35,
 | |
|       36,    37,    38,    -1,    -1,    -1,    -1,    -1,    44,    45,
 | |
|       46,    47,    48,    49,    50,    51,    52,    53,    54,    55,
 | |
|        9,    10,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    24,    25,    -1,    -1,    -1,
 | |
|       -1,    -1,    31,    32,    33,    34,    35,    36,    37,    38,
 | |
|       -1,    -1,    -1,    -1,    -1,    44,    45,    46,    47,    48,
 | |
|       49,    50,    51,    52,    53,    54,    55,     9,    10,    11,
 | |
|       12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    24,    25,    -1,    -1,    -1,    -1,    -1,    31,
 | |
|       32,    33,    34,    35,    36,    37,    38,    -1,    -1,    -1,
 | |
|       -1,    -1,    44,    45,    46,    47,    48,    49,    50,    51,
 | |
|       52,    53,    54,    55,     9,    10,    11,    12,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    24,
 | |
|       25,    -1,    -1,    -1,    -1,    -1,    31,    32,    33,    34,
 | |
|       35,    36,    37,    38,    -1,    -1,    -1,    -1,    -1,    44,
 | |
|       45,    46,    47,    48,    49,    50,    51,    52,    53,    54,
 | |
|       55,     9,    10,    11,    12,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    -1,    24,    25,    -1,    -1,
 | |
|       -1,    -1,    -1,    31,    32,    33,    34,    35,    36,    37,
 | |
|       38,    -1,    -1,    -1,    -1,    -1,    44,    45,    46,    47,
 | |
|       48,    49,    50,    51,    52,    53,    54,    55,     9,    10,
 | |
|       11,    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    24,    25,    -1,    -1,    -1,    -1,    -1,
 | |
|       31,    32,    33,    34,    35,    36,    37,    38,    -1,    -1,
 | |
|       -1,    -1,    -1,    44,    45,    46,    47,    48,    49,    50,
 | |
|       51,    52,    53,    54,    55,     9,    10,    11,    12,    -1,
 | |
|       -1,    -1,    -1,    -1,    -1,    19,    20,    -1,    -1,    -1,
 | |
|       24,    25,    -1,    -1,    -1,    -1,    -1,    31,    32,    33,
 | |
|       34,    35,    36,    37,    38,    -1,    -1,    -1,    -1,    -1,
 | |
|       44,    45,    46,    47,    48,    49,    50,    51,    52,    53,
 | |
|       54,     9,    10,    11,    12,    -1,    -1,    -1,    -1,    -1,
 | |
|       18,    -1,    -1,    -1,    -1,    -1,    24,    25,    -1,    -1,
 | |
|       -1,    -1,    -1,    31,    32,    33,    34,    35,    36,    37,
 | |
|       38,    -1,     9,    10,    11,    12,    44,    45,    46,    47,
 | |
|       48,    49,    50,    51,    52,    53,    54,    24,    25,    -1,
 | |
|       -1,    -1,    -1,    -1,    31,    32,    33,    34,    35,    36,
 | |
|       37,    38,    -1,    -1,    -1,    42,    -1,    44,    45,    46,
 | |
|       47,    48,    49,    50,    51,    52,    53,    54,     9,    10,
 | |
|       11,    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    23,    24,    25,    -1,    -1,    -1,    -1,    -1,
 | |
|       31,    32,    33,    34,    35,    36,    37,    38,    -1,    -1,
 | |
|       -1,    -1,    -1,    44,    45,    46,    47,    48,    49,    50,
 | |
|       51,    52,    53,    54,     9,    10,    11,    12,    -1,    -1,
 | |
|       -1,    -1,    -1,    18,    -1,    -1,    -1,    -1,    -1,    24,
 | |
|       25,    -1,    -1,    -1,    -1,    -1,    31,    32,    33,    34,
 | |
|       35,    36,    37,    38,    -1,     9,    10,    11,    12,    44,
 | |
|       45,    46,    47,    48,    49,    50,    51,    52,    53,    54,
 | |
|       24,    25,    -1,    -1,    -1,    -1,    -1,    31,    32,    33,
 | |
|       34,    35,    36,    37,    38,    -1,     9,    10,    11,    12,
 | |
|       44,    45,    46,    47,    48,    49,    50,    51,    52,    53,
 | |
|       54,    24,    25,    -1,    -1,    -1,    -1,    -1,    31,    32,
 | |
|       33,    34,    35,    36,    37,    38,    -1,     9,    10,    11,
 | |
|       -1,    -1,    -1,    46,    47,    48,    49,    50,    51,    52,
 | |
|       53,    54,    24,    25,    -1,    -1,    10,    11,    -1,    31,
 | |
|       32,    33,    34,    35,    36,    37,    38,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    -1,    46,    47,    48,    49,    50,    51,
 | |
|       52,    53,    54,    37,    38,    -1,    -1,    -1,    -1,    -1,
 | |
|       -1,    -1,    -1,    47,    48,    49,    50,    51,    52,    53,
 | |
|       54
 | |
| };
 | |
| 
 | |
|   /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
 | |
|      symbol of state STATE-NUM.  */
 | |
| static const yytype_uint8 yystos[] =
 | |
| {
 | |
|        0,    15,    66,    67,     4,     5,     6,     7,     8,    14,
 | |
|       17,    21,    22,    26,    28,    29,    39,    50,    56,    57,
 | |
|       60,    61,    63,    70,    72,    75,    81,     0,    16,    68,
 | |
|       71,    57,    54,    39,     4,    70,    81,    81,    70,    56,
 | |
|        1,    56,    76,    70,     4,    30,     1,    70,     1,     4,
 | |
|        7,    75,     1,    62,    70,     1,     4,    13,    14,    15,
 | |
|       16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
 | |
|       26,    27,    28,    29,    30,    57,    75,    84,    85,    86,
 | |
|        9,    10,    11,    12,    24,    25,    31,    32,    33,    34,
 | |
|       35,    36,    37,    38,    44,    45,    46,    47,    48,    49,
 | |
|       50,    51,    52,    53,    54,    55,    70,     5,    13,    60,
 | |
|       61,    75,    69,    70,    72,    68,    70,    82,    83,    77,
 | |
|       57,    59,    18,    13,    13,    27,     4,     4,    78,    58,
 | |
|       58,     1,    54,    62,    62,    45,    64,    59,     1,    70,
 | |
|       59,    59,    64,    45,    70,    70,    70,    70,    70,    70,
 | |
|       70,    70,    70,    70,    70,    70,    70,    70,    70,    70,
 | |
|       70,    70,    70,    70,    70,    70,    70,    70,    54,    56,
 | |
|       75,     1,    59,    62,    70,    13,    69,    55,    58,    78,
 | |
|        4,    56,    73,    74,    70,     1,    70,    56,    56,     1,
 | |
|       70,    44,    40,    41,    43,     1,    85,    50,    80,    81,
 | |
|       58,    58,    80,    80,    85,     4,    54,    62,    70,    54,
 | |
|       59,    62,     4,    56,    83,    43,     4,    55,    58,    55,
 | |
|       19,    20,    79,     4,     4,    70,    70,    80,    44,    59,
 | |
|       59,    44,    62,    62,    70,    54,    55,    70,     4,    74,
 | |
|       59,    70,    70,    57,    57,    42,    80,    80,    80,    70,
 | |
|       54,    54,    62,    55,    55,    70,    70,    23,    18,    70,
 | |
|       70,    54,    55,    55,    70,    55,    55,    79,    70,    70,
 | |
|       58,    55,    58,    70,    58
 | |
| };
 | |
| 
 | |
|   /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives.  */
 | |
| static const yytype_uint8 yyr1[] =
 | |
| {
 | |
|        0,    65,    66,    66,    67,    67,    68,    68,    69,    69,
 | |
|       70,    70,    70,    70,    70,    70,    70,    70,    70,    70,
 | |
|       70,    70,    70,    70,    70,    70,    70,    70,    70,    70,
 | |
|       70,    70,    70,    70,    70,    70,    70,    70,    70,    70,
 | |
|       70,    70,    70,    70,    70,    70,    70,    70,    71,    71,
 | |
|       71,    71,    72,    72,    73,    73,    74,    74,    76,    75,
 | |
|       77,    75,    78,    78,    78,    79,    79,    80,    80,    80,
 | |
|       81,    81,    81,    81,    81,    81,    81,    81,    81,    81,
 | |
|       81,    81,    81,    81,    81,    81,    81,    81,    81,    81,
 | |
|       81,    81,    81,    81,    81,    81,    81,    81,    81,    81,
 | |
|       81,    81,    81,    81,    81,    81,    81,    81,    81,    82,
 | |
|       82,    83,    84,    84,    84,    84,    84,    84,    84,    84,
 | |
|       84,    84,    84,    84,    84,    84,    84,    84,    84,    84,
 | |
|       85,    85,    85,    85,    86,    86,    86,    86,    86,    86,
 | |
|       86
 | |
| };
 | |
| 
 | |
|   /* YYR2[YYN] -- Number of symbols on the right hand side of rule YYN.  */
 | |
| static const yytype_uint8 yyr2[] =
 | |
| {
 | |
|        0,     2,     3,     3,     0,     3,     0,     2,     0,     2,
 | |
|        2,     6,    10,    12,    10,     5,     4,     4,     2,     4,
 | |
|        5,     2,     3,     3,     3,     3,     3,     3,     3,     3,
 | |
|        3,     3,     2,     3,     3,     3,     3,     3,     3,     3,
 | |
|        3,     3,     3,     3,     3,     3,     3,     1,     6,     5,
 | |
|        6,     7,     5,     8,     1,     3,     2,     1,     0,     4,
 | |
|        0,     5,     0,     2,     4,     5,     3,     3,     2,     1,
 | |
|        1,     1,     3,     2,     3,     2,     4,     3,     2,     1,
 | |
|        3,     2,     2,     3,     5,     4,     4,     3,     7,     6,
 | |
|        6,     6,     5,     5,     1,     1,     1,     3,     3,     2,
 | |
|        3,     2,     2,     1,     4,     3,     3,     4,     3,     1,
 | |
|        3,     1,     1,     1,     1,     1,     1,     1,     1,     1,
 | |
|        1,     1,     1,     1,     1,     1,     1,     1,     1,     1,
 | |
|        0,     1,     3,     3,     3,     3,     3,     1,     1,     5,
 | |
|        5
 | |
| };
 | |
| 
 | |
| 
 | |
| #define yyerrok         (yyerrstatus = 0)
 | |
| #define yyclearin       (yychar = YYEMPTY)
 | |
| #define YYEMPTY         (-2)
 | |
| #define YYEOF           0
 | |
| 
 | |
| #define YYACCEPT        goto yyacceptlab
 | |
| #define YYABORT         goto yyabortlab
 | |
| #define YYERROR         goto yyerrorlab
 | |
| 
 | |
| 
 | |
| #define YYRECOVERING()  (!!yyerrstatus)
 | |
| 
 | |
| #define YYBACKUP(Token, Value)                                  \
 | |
| do                                                              \
 | |
|   if (yychar == YYEMPTY)                                        \
 | |
|     {                                                           \
 | |
|       yychar = (Token);                                         \
 | |
|       yylval = (Value);                                         \
 | |
|       YYPOPSTACK (yylen);                                       \
 | |
|       yystate = *yyssp;                                         \
 | |
|       goto yybackup;                                            \
 | |
|     }                                                           \
 | |
|   else                                                          \
 | |
|     {                                                           \
 | |
|       yyerror (&yylloc, answer, errors, locations, lexer_param_ptr, YY_("syntax error: cannot back up")); \
 | |
|       YYERROR;                                                  \
 | |
|     }                                                           \
 | |
| while (0)
 | |
| 
 | |
| /* Error token number */
 | |
| #define YYTERROR        1
 | |
| #define YYERRCODE       256
 | |
| 
 | |
| 
 | |
| /* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
 | |
|    If N is 0, then set CURRENT to the empty location which ends
 | |
|    the previous symbol: RHS[0] (always defined).  */
 | |
| 
 | |
| #ifndef YYLLOC_DEFAULT
 | |
| # define YYLLOC_DEFAULT(Current, Rhs, N)                                \
 | |
|     do                                                                  \
 | |
|       if (N)                                                            \
 | |
|         {                                                               \
 | |
|           (Current).first_line   = YYRHSLOC (Rhs, 1).first_line;        \
 | |
|           (Current).first_column = YYRHSLOC (Rhs, 1).first_column;      \
 | |
|           (Current).last_line    = YYRHSLOC (Rhs, N).last_line;         \
 | |
|           (Current).last_column  = YYRHSLOC (Rhs, N).last_column;       \
 | |
|         }                                                               \
 | |
|       else                                                              \
 | |
|         {                                                               \
 | |
|           (Current).first_line   = (Current).last_line   =              \
 | |
|             YYRHSLOC (Rhs, 0).last_line;                                \
 | |
|           (Current).first_column = (Current).last_column =              \
 | |
|             YYRHSLOC (Rhs, 0).last_column;                              \
 | |
|         }                                                               \
 | |
|     while (0)
 | |
| #endif
 | |
| 
 | |
| #define YYRHSLOC(Rhs, K) ((Rhs)[K])
 | |
| 
 | |
| 
 | |
| /* Enable debugging if requested.  */
 | |
| #if YYDEBUG
 | |
| 
 | |
| # ifndef YYFPRINTF
 | |
| #  include <stdio.h> /* INFRINGES ON USER NAME SPACE */
 | |
| #  define YYFPRINTF fprintf
 | |
| # endif
 | |
| 
 | |
| # define YYDPRINTF(Args)                        \
 | |
| do {                                            \
 | |
|   if (yydebug)                                  \
 | |
|     YYFPRINTF Args;                             \
 | |
| } while (0)
 | |
| 
 | |
| 
 | |
| /* YY_LOCATION_PRINT -- Print the location on the stream.
 | |
|    This macro was not mandated originally: define only if we know
 | |
|    we won't break user code: when these are the locations we know.  */
 | |
| 
 | |
| #ifndef YY_LOCATION_PRINT
 | |
| # if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL
 | |
| 
 | |
| /* Print *YYLOCP on YYO.  Private, do not rely on its existence. */
 | |
| 
 | |
| YY_ATTRIBUTE_UNUSED
 | |
| static unsigned
 | |
| yy_location_print_ (FILE *yyo, YYLTYPE const * const yylocp)
 | |
| {
 | |
|   unsigned res = 0;
 | |
|   int end_col = 0 != yylocp->last_column ? yylocp->last_column - 1 : 0;
 | |
|   if (0 <= yylocp->first_line)
 | |
|     {
 | |
|       res += YYFPRINTF (yyo, "%d", yylocp->first_line);
 | |
|       if (0 <= yylocp->first_column)
 | |
|         res += YYFPRINTF (yyo, ".%d", yylocp->first_column);
 | |
|     }
 | |
|   if (0 <= yylocp->last_line)
 | |
|     {
 | |
|       if (yylocp->first_line < yylocp->last_line)
 | |
|         {
 | |
|           res += YYFPRINTF (yyo, "-%d", yylocp->last_line);
 | |
|           if (0 <= end_col)
 | |
|             res += YYFPRINTF (yyo, ".%d", end_col);
 | |
|         }
 | |
|       else if (0 <= end_col && yylocp->first_column < end_col)
 | |
|         res += YYFPRINTF (yyo, "-%d", end_col);
 | |
|     }
 | |
|   return res;
 | |
|  }
 | |
| 
 | |
| #  define YY_LOCATION_PRINT(File, Loc)          \
 | |
|   yy_location_print_ (File, &(Loc))
 | |
| 
 | |
| # else
 | |
| #  define YY_LOCATION_PRINT(File, Loc) ((void) 0)
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| 
 | |
| # define YY_SYMBOL_PRINT(Title, Type, Value, Location)                    \
 | |
| do {                                                                      \
 | |
|   if (yydebug)                                                            \
 | |
|     {                                                                     \
 | |
|       YYFPRINTF (stderr, "%s ", Title);                                   \
 | |
|       yy_symbol_print (stderr,                                            \
 | |
|                   Type, Value, Location, answer, errors, locations, lexer_param_ptr); \
 | |
|       YYFPRINTF (stderr, "\n");                                           \
 | |
|     }                                                                     \
 | |
| } while (0)
 | |
| 
 | |
| 
 | |
| /*----------------------------------------.
 | |
| | Print this symbol's value on YYOUTPUT.  |
 | |
| `----------------------------------------*/
 | |
| 
 | |
| static void
 | |
| yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep, YYLTYPE const * const yylocationp, block* answer, int* errors, struct locfile* locations, struct lexer_param* lexer_param_ptr)
 | |
| {
 | |
|   FILE *yyo = yyoutput;
 | |
|   YYUSE (yyo);
 | |
|   YYUSE (yylocationp);
 | |
|   YYUSE (answer);
 | |
|   YYUSE (errors);
 | |
|   YYUSE (locations);
 | |
|   YYUSE (lexer_param_ptr);
 | |
|   if (!yyvaluep)
 | |
|     return;
 | |
| # ifdef YYPRINT
 | |
|   if (yytype < YYNTOKENS)
 | |
|     YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
 | |
| # endif
 | |
|   YYUSE (yytype);
 | |
| }
 | |
| 
 | |
| 
 | |
| /*--------------------------------.
 | |
| | Print this symbol on YYOUTPUT.  |
 | |
| `--------------------------------*/
 | |
| 
 | |
| static void
 | |
| yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep, YYLTYPE const * const yylocationp, block* answer, int* errors, struct locfile* locations, struct lexer_param* lexer_param_ptr)
 | |
| {
 | |
|   YYFPRINTF (yyoutput, "%s %s (",
 | |
|              yytype < YYNTOKENS ? "token" : "nterm", yytname[yytype]);
 | |
| 
 | |
|   YY_LOCATION_PRINT (yyoutput, *yylocationp);
 | |
|   YYFPRINTF (yyoutput, ": ");
 | |
|   yy_symbol_value_print (yyoutput, yytype, yyvaluep, yylocationp, answer, errors, locations, lexer_param_ptr);
 | |
|   YYFPRINTF (yyoutput, ")");
 | |
| }
 | |
| 
 | |
| /*------------------------------------------------------------------.
 | |
| | yy_stack_print -- Print the state stack from its BOTTOM up to its |
 | |
| | TOP (included).                                                   |
 | |
| `------------------------------------------------------------------*/
 | |
| 
 | |
| static void
 | |
| yy_stack_print (yytype_int16 *yybottom, yytype_int16 *yytop)
 | |
| {
 | |
|   YYFPRINTF (stderr, "Stack now");
 | |
|   for (; yybottom <= yytop; yybottom++)
 | |
|     {
 | |
|       int yybot = *yybottom;
 | |
|       YYFPRINTF (stderr, " %d", yybot);
 | |
|     }
 | |
|   YYFPRINTF (stderr, "\n");
 | |
| }
 | |
| 
 | |
| # define YY_STACK_PRINT(Bottom, Top)                            \
 | |
| do {                                                            \
 | |
|   if (yydebug)                                                  \
 | |
|     yy_stack_print ((Bottom), (Top));                           \
 | |
| } while (0)
 | |
| 
 | |
| 
 | |
| /*------------------------------------------------.
 | |
| | Report that the YYRULE is going to be reduced.  |
 | |
| `------------------------------------------------*/
 | |
| 
 | |
| static void
 | |
| yy_reduce_print (yytype_int16 *yyssp, YYSTYPE *yyvsp, YYLTYPE *yylsp, int yyrule, block* answer, int* errors, struct locfile* locations, struct lexer_param* lexer_param_ptr)
 | |
| {
 | |
|   unsigned long int yylno = yyrline[yyrule];
 | |
|   int yynrhs = yyr2[yyrule];
 | |
|   int yyi;
 | |
|   YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n",
 | |
|              yyrule - 1, yylno);
 | |
|   /* The symbols being reduced.  */
 | |
|   for (yyi = 0; yyi < yynrhs; yyi++)
 | |
|     {
 | |
|       YYFPRINTF (stderr, "   $%d = ", yyi + 1);
 | |
|       yy_symbol_print (stderr,
 | |
|                        yystos[yyssp[yyi + 1 - yynrhs]],
 | |
|                        &(yyvsp[(yyi + 1) - (yynrhs)])
 | |
|                        , &(yylsp[(yyi + 1) - (yynrhs)])                       , answer, errors, locations, lexer_param_ptr);
 | |
|       YYFPRINTF (stderr, "\n");
 | |
|     }
 | |
| }
 | |
| 
 | |
| # define YY_REDUCE_PRINT(Rule)          \
 | |
| do {                                    \
 | |
|   if (yydebug)                          \
 | |
|     yy_reduce_print (yyssp, yyvsp, yylsp, Rule, answer, errors, locations, lexer_param_ptr); \
 | |
| } while (0)
 | |
| 
 | |
| /* Nonzero means print parse trace.  It is left uninitialized so that
 | |
|    multiple parsers can coexist.  */
 | |
| int yydebug;
 | |
| #else /* !YYDEBUG */
 | |
| # define YYDPRINTF(Args)
 | |
| # define YY_SYMBOL_PRINT(Title, Type, Value, Location)
 | |
| # define YY_STACK_PRINT(Bottom, Top)
 | |
| # define YY_REDUCE_PRINT(Rule)
 | |
| #endif /* !YYDEBUG */
 | |
| 
 | |
| 
 | |
| /* YYINITDEPTH -- initial size of the parser's stacks.  */
 | |
| #ifndef YYINITDEPTH
 | |
| # define YYINITDEPTH 200
 | |
| #endif
 | |
| 
 | |
| /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
 | |
|    if the built-in stack extension method is used).
 | |
| 
 | |
|    Do not make this value too large; the results are undefined if
 | |
|    YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
 | |
|    evaluated with infinite-precision integer arithmetic.  */
 | |
| 
 | |
| #ifndef YYMAXDEPTH
 | |
| # define YYMAXDEPTH 10000
 | |
| #endif
 | |
| 
 | |
| 
 | |
| #if YYERROR_VERBOSE
 | |
| 
 | |
| # ifndef yystrlen
 | |
| #  if defined __GLIBC__ && defined _STRING_H
 | |
| #   define yystrlen strlen
 | |
| #  else
 | |
| /* Return the length of YYSTR.  */
 | |
| static YYSIZE_T
 | |
| yystrlen (const char *yystr)
 | |
| {
 | |
|   YYSIZE_T yylen;
 | |
|   for (yylen = 0; yystr[yylen]; yylen++)
 | |
|     continue;
 | |
|   return yylen;
 | |
| }
 | |
| #  endif
 | |
| # endif
 | |
| 
 | |
| # ifndef yystpcpy
 | |
| #  if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
 | |
| #   define yystpcpy stpcpy
 | |
| #  else
 | |
| /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
 | |
|    YYDEST.  */
 | |
| static char *
 | |
| yystpcpy (char *yydest, const char *yysrc)
 | |
| {
 | |
|   char *yyd = yydest;
 | |
|   const char *yys = yysrc;
 | |
| 
 | |
|   while ((*yyd++ = *yys++) != '\0')
 | |
|     continue;
 | |
| 
 | |
|   return yyd - 1;
 | |
| }
 | |
| #  endif
 | |
| # endif
 | |
| 
 | |
| # ifndef yytnamerr
 | |
| /* Copy to YYRES the contents of YYSTR after stripping away unnecessary
 | |
|    quotes and backslashes, so that it's suitable for yyerror.  The
 | |
|    heuristic is that double-quoting is unnecessary unless the string
 | |
|    contains an apostrophe, a comma, or backslash (other than
 | |
|    backslash-backslash).  YYSTR is taken from yytname.  If YYRES is
 | |
|    null, do not copy; instead, return the length of what the result
 | |
|    would have been.  */
 | |
| static YYSIZE_T
 | |
| yytnamerr (char *yyres, const char *yystr)
 | |
| {
 | |
|   if (*yystr == '"')
 | |
|     {
 | |
|       YYSIZE_T yyn = 0;
 | |
|       char const *yyp = yystr;
 | |
| 
 | |
|       for (;;)
 | |
|         switch (*++yyp)
 | |
|           {
 | |
|           case '\'':
 | |
|           case ',':
 | |
|             goto do_not_strip_quotes;
 | |
| 
 | |
|           case '\\':
 | |
|             if (*++yyp != '\\')
 | |
|               goto do_not_strip_quotes;
 | |
|             /* Fall through.  */
 | |
|           default:
 | |
|             if (yyres)
 | |
|               yyres[yyn] = *yyp;
 | |
|             yyn++;
 | |
|             break;
 | |
| 
 | |
|           case '"':
 | |
|             if (yyres)
 | |
|               yyres[yyn] = '\0';
 | |
|             return yyn;
 | |
|           }
 | |
|     do_not_strip_quotes: ;
 | |
|     }
 | |
| 
 | |
|   if (! yyres)
 | |
|     return yystrlen (yystr);
 | |
| 
 | |
|   return yystpcpy (yyres, yystr) - yyres;
 | |
| }
 | |
| # endif
 | |
| 
 | |
| /* Copy into *YYMSG, which is of size *YYMSG_ALLOC, an error message
 | |
|    about the unexpected token YYTOKEN for the state stack whose top is
 | |
|    YYSSP.
 | |
| 
 | |
|    Return 0 if *YYMSG was successfully written.  Return 1 if *YYMSG is
 | |
|    not large enough to hold the message.  In that case, also set
 | |
|    *YYMSG_ALLOC to the required number of bytes.  Return 2 if the
 | |
|    required number of bytes is too large to store.  */
 | |
| static int
 | |
| yysyntax_error (YYSIZE_T *yymsg_alloc, char **yymsg,
 | |
|                 yytype_int16 *yyssp, int yytoken)
 | |
| {
 | |
|   YYSIZE_T yysize0 = yytnamerr (YY_NULLPTR, yytname[yytoken]);
 | |
|   YYSIZE_T yysize = yysize0;
 | |
|   enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
 | |
|   /* Internationalized format string. */
 | |
|   const char *yyformat = YY_NULLPTR;
 | |
|   /* Arguments of yyformat. */
 | |
|   char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
 | |
|   /* Number of reported tokens (one for the "unexpected", one per
 | |
|      "expected"). */
 | |
|   int yycount = 0;
 | |
| 
 | |
|   /* There are many possibilities here to consider:
 | |
|      - If this state is a consistent state with a default action, then
 | |
|        the only way this function was invoked is if the default action
 | |
|        is an error action.  In that case, don't check for expected
 | |
|        tokens because there are none.
 | |
|      - The only way there can be no lookahead present (in yychar) is if
 | |
|        this state is a consistent state with a default action.  Thus,
 | |
|        detecting the absence of a lookahead is sufficient to determine
 | |
|        that there is no unexpected or expected token to report.  In that
 | |
|        case, just report a simple "syntax error".
 | |
|      - Don't assume there isn't a lookahead just because this state is a
 | |
|        consistent state with a default action.  There might have been a
 | |
|        previous inconsistent state, consistent state with a non-default
 | |
|        action, or user semantic action that manipulated yychar.
 | |
|      - Of course, the expected token list depends on states to have
 | |
|        correct lookahead information, and it depends on the parser not
 | |
|        to perform extra reductions after fetching a lookahead from the
 | |
|        scanner and before detecting a syntax error.  Thus, state merging
 | |
|        (from LALR or IELR) and default reductions corrupt the expected
 | |
|        token list.  However, the list is correct for canonical LR with
 | |
|        one exception: it will still contain any token that will not be
 | |
|        accepted due to an error action in a later state.
 | |
|   */
 | |
|   if (yytoken != YYEMPTY)
 | |
|     {
 | |
|       int yyn = yypact[*yyssp];
 | |
|       yyarg[yycount++] = yytname[yytoken];
 | |
|       if (!yypact_value_is_default (yyn))
 | |
|         {
 | |
|           /* Start YYX at -YYN if negative to avoid negative indexes in
 | |
|              YYCHECK.  In other words, skip the first -YYN actions for
 | |
|              this state because they are default actions.  */
 | |
|           int yyxbegin = yyn < 0 ? -yyn : 0;
 | |
|           /* Stay within bounds of both yycheck and yytname.  */
 | |
|           int yychecklim = YYLAST - yyn + 1;
 | |
|           int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
 | |
|           int yyx;
 | |
| 
 | |
|           for (yyx = yyxbegin; yyx < yyxend; ++yyx)
 | |
|             if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR
 | |
|                 && !yytable_value_is_error (yytable[yyx + yyn]))
 | |
|               {
 | |
|                 if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
 | |
|                   {
 | |
|                     yycount = 1;
 | |
|                     yysize = yysize0;
 | |
|                     break;
 | |
|                   }
 | |
|                 yyarg[yycount++] = yytname[yyx];
 | |
|                 {
 | |
|                   YYSIZE_T yysize1 = yysize + yytnamerr (YY_NULLPTR, yytname[yyx]);
 | |
|                   if (! (yysize <= yysize1
 | |
|                          && yysize1 <= YYSTACK_ALLOC_MAXIMUM))
 | |
|                     return 2;
 | |
|                   yysize = yysize1;
 | |
|                 }
 | |
|               }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|   switch (yycount)
 | |
|     {
 | |
| # define YYCASE_(N, S)                      \
 | |
|       case N:                               \
 | |
|         yyformat = S;                       \
 | |
|       break
 | |
|       YYCASE_(0, YY_("syntax error"));
 | |
|       YYCASE_(1, YY_("syntax error, unexpected %s"));
 | |
|       YYCASE_(2, YY_("syntax error, unexpected %s, expecting %s"));
 | |
|       YYCASE_(3, YY_("syntax error, unexpected %s, expecting %s or %s"));
 | |
|       YYCASE_(4, YY_("syntax error, unexpected %s, expecting %s or %s or %s"));
 | |
|       YYCASE_(5, YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"));
 | |
| # undef YYCASE_
 | |
|     }
 | |
| 
 | |
|   {
 | |
|     YYSIZE_T yysize1 = yysize + yystrlen (yyformat);
 | |
|     if (! (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM))
 | |
|       return 2;
 | |
|     yysize = yysize1;
 | |
|   }
 | |
| 
 | |
|   if (*yymsg_alloc < yysize)
 | |
|     {
 | |
|       *yymsg_alloc = 2 * yysize;
 | |
|       if (! (yysize <= *yymsg_alloc
 | |
|              && *yymsg_alloc <= YYSTACK_ALLOC_MAXIMUM))
 | |
|         *yymsg_alloc = YYSTACK_ALLOC_MAXIMUM;
 | |
|       return 1;
 | |
|     }
 | |
| 
 | |
|   /* Avoid sprintf, as that infringes on the user's name space.
 | |
|      Don't have undefined behavior even if the translation
 | |
|      produced a string with the wrong number of "%s"s.  */
 | |
|   {
 | |
|     char *yyp = *yymsg;
 | |
|     int yyi = 0;
 | |
|     while ((*yyp = *yyformat) != '\0')
 | |
|       if (*yyp == '%' && yyformat[1] == 's' && yyi < yycount)
 | |
|         {
 | |
|           yyp += yytnamerr (yyp, yyarg[yyi++]);
 | |
|           yyformat += 2;
 | |
|         }
 | |
|       else
 | |
|         {
 | |
|           yyp++;
 | |
|           yyformat++;
 | |
|         }
 | |
|   }
 | |
|   return 0;
 | |
| }
 | |
| #endif /* YYERROR_VERBOSE */
 | |
| 
 | |
| /*-----------------------------------------------.
 | |
| | Release the memory associated to this symbol.  |
 | |
| `-----------------------------------------------*/
 | |
| 
 | |
| static void
 | |
| yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep, YYLTYPE *yylocationp, block* answer, int* errors, struct locfile* locations, struct lexer_param* lexer_param_ptr)
 | |
| {
 | |
|   YYUSE (yyvaluep);
 | |
|   YYUSE (yylocationp);
 | |
|   YYUSE (answer);
 | |
|   YYUSE (errors);
 | |
|   YYUSE (locations);
 | |
|   YYUSE (lexer_param_ptr);
 | |
|   if (!yymsg)
 | |
|     yymsg = "Deleting";
 | |
|   YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
 | |
| 
 | |
|   YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
 | |
|   switch (yytype)
 | |
|     {
 | |
|           case 4: /* IDENT  */
 | |
| #line 35 "parser.y" /* yacc.c:1257  */
 | |
|       { jv_free(((*yyvaluep).literal)); }
 | |
| #line 1816 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 5: /* FIELD  */
 | |
| #line 35 "parser.y" /* yacc.c:1257  */
 | |
|       { jv_free(((*yyvaluep).literal)); }
 | |
| #line 1822 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 6: /* LITERAL  */
 | |
| #line 35 "parser.y" /* yacc.c:1257  */
 | |
|       { jv_free(((*yyvaluep).literal)); }
 | |
| #line 1828 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 7: /* FORMAT  */
 | |
| #line 35 "parser.y" /* yacc.c:1257  */
 | |
|       { jv_free(((*yyvaluep).literal)); }
 | |
| #line 1834 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 40: /* QQSTRING_TEXT  */
 | |
| #line 35 "parser.y" /* yacc.c:1257  */
 | |
|       { jv_free(((*yyvaluep).literal)); }
 | |
| #line 1840 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 67: /* Module  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1846 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 68: /* Imports  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1852 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 69: /* FuncDefs  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1858 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 70: /* Exp  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1864 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 71: /* Import  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1870 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 72: /* FuncDef  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1876 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 73: /* Params  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1882 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 74: /* Param  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1888 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 75: /* String  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1894 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 78: /* QQString  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1900 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 79: /* ElseBody  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1906 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 80: /* ExpD  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1912 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 81: /* Term  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1918 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 82: /* Args  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1924 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 83: /* Arg  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1930 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 84: /* Keyword  */
 | |
| #line 35 "parser.y" /* yacc.c:1257  */
 | |
|       { jv_free(((*yyvaluep).literal)); }
 | |
| #line 1936 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 85: /* MkDict  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1942 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
|     case 86: /* MkDictPair  */
 | |
| #line 36 "parser.y" /* yacc.c:1257  */
 | |
|       { block_free(((*yyvaluep).blk)); }
 | |
| #line 1948 "parser.c" /* yacc.c:1257  */
 | |
|         break;
 | |
| 
 | |
| 
 | |
|       default:
 | |
|         break;
 | |
|     }
 | |
|   YY_IGNORE_MAYBE_UNINITIALIZED_END
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| /*----------.
 | |
| | yyparse.  |
 | |
| `----------*/
 | |
| 
 | |
| int
 | |
| yyparse (block* answer, int* errors, struct locfile* locations, struct lexer_param* lexer_param_ptr)
 | |
| {
 | |
| /* The lookahead symbol.  */
 | |
| int yychar;
 | |
| 
 | |
| 
 | |
| /* The semantic value of the lookahead symbol.  */
 | |
| /* Default value used for initialization, for pacifying older GCCs
 | |
|    or non-GCC compilers.  */
 | |
| YY_INITIAL_VALUE (static YYSTYPE yyval_default;)
 | |
| YYSTYPE yylval YY_INITIAL_VALUE (= yyval_default);
 | |
| 
 | |
| /* Location data for the lookahead symbol.  */
 | |
| static YYLTYPE yyloc_default
 | |
| # if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL
 | |
|   = { 1, 1, 1, 1 }
 | |
| # endif
 | |
| ;
 | |
| YYLTYPE yylloc = yyloc_default;
 | |
| 
 | |
|     /* Number of syntax errors so far.  */
 | |
|     int yynerrs;
 | |
| 
 | |
|     int yystate;
 | |
|     /* Number of tokens to shift before error messages enabled.  */
 | |
|     int yyerrstatus;
 | |
| 
 | |
|     /* The stacks and their tools:
 | |
|        'yyss': related to states.
 | |
|        'yyvs': related to semantic values.
 | |
|        'yyls': related to locations.
 | |
| 
 | |
|        Refer to the stacks through separate pointers, to allow yyoverflow
 | |
|        to reallocate them elsewhere.  */
 | |
| 
 | |
|     /* The state stack.  */
 | |
|     yytype_int16 yyssa[YYINITDEPTH];
 | |
|     yytype_int16 *yyss;
 | |
|     yytype_int16 *yyssp;
 | |
| 
 | |
|     /* The semantic value stack.  */
 | |
|     YYSTYPE yyvsa[YYINITDEPTH];
 | |
|     YYSTYPE *yyvs;
 | |
|     YYSTYPE *yyvsp;
 | |
| 
 | |
|     /* The location stack.  */
 | |
|     YYLTYPE yylsa[YYINITDEPTH];
 | |
|     YYLTYPE *yyls;
 | |
|     YYLTYPE *yylsp;
 | |
| 
 | |
|     /* The locations where the error started and ended.  */
 | |
|     YYLTYPE yyerror_range[3];
 | |
| 
 | |
|     YYSIZE_T yystacksize;
 | |
| 
 | |
|   int yyn;
 | |
|   int yyresult;
 | |
|   /* Lookahead token as an internal (translated) token number.  */
 | |
|   int yytoken = 0;
 | |
|   /* The variables used to return semantic value and location from the
 | |
|      action routines.  */
 | |
|   YYSTYPE yyval;
 | |
|   YYLTYPE yyloc;
 | |
| 
 | |
| #if YYERROR_VERBOSE
 | |
|   /* Buffer for error messages, and its allocated size.  */
 | |
|   char yymsgbuf[128];
 | |
|   char *yymsg = yymsgbuf;
 | |
|   YYSIZE_T yymsg_alloc = sizeof yymsgbuf;
 | |
| #endif
 | |
| 
 | |
| #define YYPOPSTACK(N)   (yyvsp -= (N), yyssp -= (N), yylsp -= (N))
 | |
| 
 | |
|   /* The number of symbols on the RHS of the reduced rule.
 | |
|      Keep to zero when no symbol should be popped.  */
 | |
|   int yylen = 0;
 | |
| 
 | |
|   yyssp = yyss = yyssa;
 | |
|   yyvsp = yyvs = yyvsa;
 | |
|   yylsp = yyls = yylsa;
 | |
|   yystacksize = YYINITDEPTH;
 | |
| 
 | |
|   YYDPRINTF ((stderr, "Starting parse\n"));
 | |
| 
 | |
|   yystate = 0;
 | |
|   yyerrstatus = 0;
 | |
|   yynerrs = 0;
 | |
|   yychar = YYEMPTY; /* Cause a token to be read.  */
 | |
|   yylsp[0] = yylloc;
 | |
|   goto yysetstate;
 | |
| 
 | |
| /*------------------------------------------------------------.
 | |
| | yynewstate -- Push a new state, which is found in yystate.  |
 | |
| `------------------------------------------------------------*/
 | |
|  yynewstate:
 | |
|   /* In all cases, when you get here, the value and location stacks
 | |
|      have just been pushed.  So pushing a state here evens the stacks.  */
 | |
|   yyssp++;
 | |
| 
 | |
|  yysetstate:
 | |
|   *yyssp = yystate;
 | |
| 
 | |
|   if (yyss + yystacksize - 1 <= yyssp)
 | |
|     {
 | |
|       /* Get the current used size of the three stacks, in elements.  */
 | |
|       YYSIZE_T yysize = yyssp - yyss + 1;
 | |
| 
 | |
| #ifdef yyoverflow
 | |
|       {
 | |
|         /* Give user a chance to reallocate the stack.  Use copies of
 | |
|            these so that the &'s don't force the real ones into
 | |
|            memory.  */
 | |
|         YYSTYPE *yyvs1 = yyvs;
 | |
|         yytype_int16 *yyss1 = yyss;
 | |
|         YYLTYPE *yyls1 = yyls;
 | |
| 
 | |
|         /* Each stack pointer address is followed by the size of the
 | |
|            data in use in that stack, in bytes.  This used to be a
 | |
|            conditional around just the two extra args, but that might
 | |
|            be undefined if yyoverflow is a macro.  */
 | |
|         yyoverflow (YY_("memory exhausted"),
 | |
|                     &yyss1, yysize * sizeof (*yyssp),
 | |
|                     &yyvs1, yysize * sizeof (*yyvsp),
 | |
|                     &yyls1, yysize * sizeof (*yylsp),
 | |
|                     &yystacksize);
 | |
| 
 | |
|         yyls = yyls1;
 | |
|         yyss = yyss1;
 | |
|         yyvs = yyvs1;
 | |
|       }
 | |
| #else /* no yyoverflow */
 | |
| # ifndef YYSTACK_RELOCATE
 | |
|       goto yyexhaustedlab;
 | |
| # else
 | |
|       /* Extend the stack our own way.  */
 | |
|       if (YYMAXDEPTH <= yystacksize)
 | |
|         goto yyexhaustedlab;
 | |
|       yystacksize *= 2;
 | |
|       if (YYMAXDEPTH < yystacksize)
 | |
|         yystacksize = YYMAXDEPTH;
 | |
| 
 | |
|       {
 | |
|         yytype_int16 *yyss1 = yyss;
 | |
|         union yyalloc *yyptr =
 | |
|           (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
 | |
|         if (! yyptr)
 | |
|           goto yyexhaustedlab;
 | |
|         YYSTACK_RELOCATE (yyss_alloc, yyss);
 | |
|         YYSTACK_RELOCATE (yyvs_alloc, yyvs);
 | |
|         YYSTACK_RELOCATE (yyls_alloc, yyls);
 | |
| #  undef YYSTACK_RELOCATE
 | |
|         if (yyss1 != yyssa)
 | |
|           YYSTACK_FREE (yyss1);
 | |
|       }
 | |
| # endif
 | |
| #endif /* no yyoverflow */
 | |
| 
 | |
|       yyssp = yyss + yysize - 1;
 | |
|       yyvsp = yyvs + yysize - 1;
 | |
|       yylsp = yyls + yysize - 1;
 | |
| 
 | |
|       YYDPRINTF ((stderr, "Stack size increased to %lu\n",
 | |
|                   (unsigned long int) yystacksize));
 | |
| 
 | |
|       if (yyss + yystacksize - 1 <= yyssp)
 | |
|         YYABORT;
 | |
|     }
 | |
| 
 | |
|   YYDPRINTF ((stderr, "Entering state %d\n", yystate));
 | |
| 
 | |
|   if (yystate == YYFINAL)
 | |
|     YYACCEPT;
 | |
| 
 | |
|   goto yybackup;
 | |
| 
 | |
| /*-----------.
 | |
| | yybackup.  |
 | |
| `-----------*/
 | |
| yybackup:
 | |
| 
 | |
|   /* Do appropriate processing given the current state.  Read a
 | |
|      lookahead token if we need one and don't already have one.  */
 | |
| 
 | |
|   /* First try to decide what to do without reference to lookahead token.  */
 | |
|   yyn = yypact[yystate];
 | |
|   if (yypact_value_is_default (yyn))
 | |
|     goto yydefault;
 | |
| 
 | |
|   /* Not known => get a lookahead token if don't already have one.  */
 | |
| 
 | |
|   /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol.  */
 | |
|   if (yychar == YYEMPTY)
 | |
|     {
 | |
|       YYDPRINTF ((stderr, "Reading a token: "));
 | |
|       yychar = yylex (&yylval, &yylloc, answer, errors, locations, lexer_param_ptr);
 | |
|     }
 | |
| 
 | |
|   if (yychar <= YYEOF)
 | |
|     {
 | |
|       yychar = yytoken = YYEOF;
 | |
|       YYDPRINTF ((stderr, "Now at end of input.\n"));
 | |
|     }
 | |
|   else
 | |
|     {
 | |
|       yytoken = YYTRANSLATE (yychar);
 | |
|       YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
 | |
|     }
 | |
| 
 | |
|   /* If the proper action on seeing token YYTOKEN is to reduce or to
 | |
|      detect an error, take that action.  */
 | |
|   yyn += yytoken;
 | |
|   if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
 | |
|     goto yydefault;
 | |
|   yyn = yytable[yyn];
 | |
|   if (yyn <= 0)
 | |
|     {
 | |
|       if (yytable_value_is_error (yyn))
 | |
|         goto yyerrlab;
 | |
|       yyn = -yyn;
 | |
|       goto yyreduce;
 | |
|     }
 | |
| 
 | |
|   /* Count tokens shifted since error; after three, turn off error
 | |
|      status.  */
 | |
|   if (yyerrstatus)
 | |
|     yyerrstatus--;
 | |
| 
 | |
|   /* Shift the lookahead token.  */
 | |
|   YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
 | |
| 
 | |
|   /* Discard the shifted token.  */
 | |
|   yychar = YYEMPTY;
 | |
| 
 | |
|   yystate = yyn;
 | |
|   YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
 | |
|   *++yyvsp = yylval;
 | |
|   YY_IGNORE_MAYBE_UNINITIALIZED_END
 | |
|   *++yylsp = yylloc;
 | |
|   goto yynewstate;
 | |
| 
 | |
| 
 | |
| /*-----------------------------------------------------------.
 | |
| | yydefault -- do the default action for the current state.  |
 | |
| `-----------------------------------------------------------*/
 | |
| yydefault:
 | |
|   yyn = yydefact[yystate];
 | |
|   if (yyn == 0)
 | |
|     goto yyerrlab;
 | |
|   goto yyreduce;
 | |
| 
 | |
| 
 | |
| /*-----------------------------.
 | |
| | yyreduce -- Do a reduction.  |
 | |
| `-----------------------------*/
 | |
| yyreduce:
 | |
|   /* yyn is the number of a rule to reduce with.  */
 | |
|   yylen = yyr2[yyn];
 | |
| 
 | |
|   /* If YYLEN is nonzero, implement the default value of the action:
 | |
|      '$$ = $1'.
 | |
| 
 | |
|      Otherwise, the following line sets YYVAL to garbage.
 | |
|      This behavior is undocumented and Bison
 | |
|      users should not rely upon it.  Assigning to YYVAL
 | |
|      unconditionally makes the parser a bit smaller, and it avoids a
 | |
|      GCC warning that YYVAL may be used uninitialized.  */
 | |
|   yyval = yyvsp[1-yylen];
 | |
| 
 | |
|   /* Default location.  */
 | |
|   YYLLOC_DEFAULT (yyloc, (yylsp - yylen), yylen);
 | |
|   YY_REDUCE_PRINT (yyn);
 | |
|   switch (yyn)
 | |
|     {
 | |
|         case 2:
 | |
| #line 270 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   *answer = BLOCK((yyvsp[-2].blk), (yyvsp[-1].blk), gen_op_simple(TOP), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2244 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 3:
 | |
| #line 273 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   *answer = BLOCK((yyvsp[-2].blk), (yyvsp[-1].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2252 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 4:
 | |
| #line 278 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_noop();
 | |
| }
 | |
| #line 2260 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 5:
 | |
| #line 281 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   if (!block_is_const((yyvsp[-1].blk))) {
 | |
|     FAIL((yyloc), "Module metadata must be constant.");
 | |
|     (yyval.blk) = gen_noop();
 | |
|   } else {
 | |
|     (yyval.blk) = gen_module((yyvsp[-1].blk));
 | |
|   }
 | |
| }
 | |
| #line 2273 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 6:
 | |
| #line 291 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_noop();
 | |
| }
 | |
| #line 2281 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 7:
 | |
| #line 294 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = BLOCK((yyvsp[-1].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2289 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 8:
 | |
| #line 299 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_noop();
 | |
| }
 | |
| #line 2297 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 9:
 | |
| #line 302 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = block_bind((yyvsp[-1].blk), (yyvsp[0].blk), OP_IS_CALL_PSEUDO);
 | |
| }
 | |
| #line 2305 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 10:
 | |
| #line 307 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = block_bind_referenced((yyvsp[-1].blk), (yyvsp[0].blk), OP_IS_CALL_PSEUDO);
 | |
| }
 | |
| #line 2313 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 11:
 | |
| #line 311 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_var_binding((yyvsp[-5].blk), jv_string_value((yyvsp[-2].literal)), (yyvsp[0].blk));
 | |
|   jv_free((yyvsp[-2].literal));
 | |
| }
 | |
| #line 2322 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 12:
 | |
| #line 316 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_reduce(jv_string_value((yyvsp[-5].literal)), (yyvsp[-8].blk), (yyvsp[-3].blk), (yyvsp[-1].blk));
 | |
|   jv_free((yyvsp[-5].literal));
 | |
| }
 | |
| #line 2331 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 13:
 | |
| #line 321 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_foreach(jv_string_value((yyvsp[-7].literal)), (yyvsp[-10].blk), (yyvsp[-5].blk), (yyvsp[-3].blk), (yyvsp[-1].blk));
 | |
|   jv_free((yyvsp[-7].literal));
 | |
| }
 | |
| #line 2340 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 14:
 | |
| #line 326 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_foreach(jv_string_value((yyvsp[-5].literal)), (yyvsp[-8].blk), (yyvsp[-3].blk), (yyvsp[-1].blk), gen_noop());
 | |
|   jv_free((yyvsp[-5].literal));
 | |
| }
 | |
| #line 2349 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 15:
 | |
| #line 331 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_cond((yyvsp[-3].blk), (yyvsp[-1].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2357 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 16:
 | |
| #line 334 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   FAIL((yyloc), "Possibly unterminated 'if' statement");
 | |
|   (yyval.blk) = (yyvsp[-2].blk);
 | |
| }
 | |
| #line 2366 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 17:
 | |
| #line 339 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   //$$ = BLOCK(gen_op_target(FORK_OPT, $2), $2, $4);
 | |
|   (yyval.blk) = gen_try((yyvsp[-2].blk), gen_try_handler((yyvsp[0].blk)));
 | |
| }
 | |
| #line 2375 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 18:
 | |
| #line 343 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   //$$ = BLOCK(gen_op_target(FORK_OPT, $2), $2, gen_op_simple(BACKTRACK));
 | |
|   (yyval.blk) = gen_try((yyvsp[0].blk), gen_op_simple(BACKTRACK));
 | |
| }
 | |
| #line 2384 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 19:
 | |
| #line 347 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   FAIL((yyloc), "Possibly unterminated 'try' statement");
 | |
|   (yyval.blk) = (yyvsp[-2].blk);
 | |
| }
 | |
| #line 2393 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 20:
 | |
| #line 352 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   jv v = jv_string_fmt("*label-%s", jv_string_value((yyvsp[-2].literal)));
 | |
|   (yyval.blk) = gen_location((yyloc), locations, gen_label(jv_string_value(v), (yyvsp[0].blk)));
 | |
|   jv_free((yyvsp[-2].literal));
 | |
|   jv_free(v);
 | |
| }
 | |
| #line 2404 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 21:
 | |
| #line 364 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_try((yyvsp[-1].blk), gen_op_simple(BACKTRACK));
 | |
| }
 | |
| #line 2412 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 22:
 | |
| #line 368 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_call("_assign", BLOCK(gen_lambda((yyvsp[-2].blk)), gen_lambda((yyvsp[0].blk))));
 | |
| }
 | |
| #line 2420 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 23:
 | |
| #line 372 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_or((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2428 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 24:
 | |
| #line 376 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_and((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2436 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 25:
 | |
| #line 380 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_definedor((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2444 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 26:
 | |
| #line 384 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_definedor_assign((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2452 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 27:
 | |
| #line 388 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_call("_modify", BLOCK(gen_lambda((yyvsp[-2].blk)), gen_lambda((yyvsp[0].blk))));
 | |
| }
 | |
| #line 2460 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 28:
 | |
| #line 392 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = block_join((yyvsp[-2].blk), (yyvsp[0].blk)); 
 | |
| }
 | |
| #line 2468 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 29:
 | |
| #line 396 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = gen_both((yyvsp[-2].blk), (yyvsp[0].blk)); 
 | |
| }
 | |
| #line 2476 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 30:
 | |
| #line 400 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '+');
 | |
| }
 | |
| #line 2484 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 31:
 | |
| #line 404 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_update((yyvsp[-2].blk), (yyvsp[0].blk), '+');
 | |
| }
 | |
| #line 2492 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 32:
 | |
| #line 408 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = BLOCK((yyvsp[0].blk), gen_call("_negate", gen_noop()));
 | |
| }
 | |
| #line 2500 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 33:
 | |
| #line 412 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '-');
 | |
| }
 | |
| #line 2508 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 34:
 | |
| #line 416 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_update((yyvsp[-2].blk), (yyvsp[0].blk), '-');
 | |
| }
 | |
| #line 2516 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 35:
 | |
| #line 420 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '*');
 | |
| }
 | |
| #line 2524 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 36:
 | |
| #line 424 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_update((yyvsp[-2].blk), (yyvsp[0].blk), '*');
 | |
| }
 | |
| #line 2532 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 37:
 | |
| #line 428 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '/');
 | |
| }
 | |
| #line 2540 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 38:
 | |
| #line 432 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '%');
 | |
| }
 | |
| #line 2548 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 39:
 | |
| #line 436 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_update((yyvsp[-2].blk), (yyvsp[0].blk), '/');
 | |
| }
 | |
| #line 2556 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 40:
 | |
| #line 440 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_update((yyvsp[-2].blk), (yyvsp[0].blk), '%');
 | |
| }
 | |
| #line 2564 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 41:
 | |
| #line 444 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), EQ);
 | |
| }
 | |
| #line 2572 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 42:
 | |
| #line 448 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), NEQ);
 | |
| }
 | |
| #line 2580 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 43:
 | |
| #line 452 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '<');
 | |
| }
 | |
| #line 2588 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 44:
 | |
| #line 456 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), '>');
 | |
| }
 | |
| #line 2596 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 45:
 | |
| #line 460 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), LESSEQ);
 | |
| }
 | |
| #line 2604 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 46:
 | |
| #line 464 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-2].blk), (yyvsp[0].blk), GREATEREQ);
 | |
| }
 | |
| #line 2612 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 47:
 | |
| #line 468 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = (yyvsp[0].blk); 
 | |
| }
 | |
| #line 2620 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 48:
 | |
| #line 473 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   jv v = block_const((yyvsp[-4].blk));
 | |
|   // XXX Make gen_import take only blocks and the int is_data so we
 | |
|   // don't have to free so much stuff here
 | |
|   (yyval.blk) = gen_import(jv_string_value(v), gen_noop(), jv_string_value((yyvsp[-1].literal)), 1);
 | |
|   block_free((yyvsp[-4].blk));
 | |
|   jv_free((yyvsp[-1].literal));
 | |
|   jv_free(v);
 | |
| }
 | |
| #line 2634 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 49:
 | |
| #line 482 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   jv v = block_const((yyvsp[-3].blk));
 | |
|   (yyval.blk) = gen_import(jv_string_value(v), gen_noop(), jv_string_value((yyvsp[-1].literal)), 0);
 | |
|   block_free((yyvsp[-3].blk));
 | |
|   jv_free((yyvsp[-1].literal));
 | |
|   jv_free(v);
 | |
| }
 | |
| #line 2646 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 50:
 | |
| #line 489 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   if (!block_is_const((yyvsp[-1].blk))) {
 | |
|     FAIL((yyloc), "Module metadata must be constant.");
 | |
|     (yyval.blk) = gen_noop();
 | |
|   } else {
 | |
|     jv v = block_const((yyvsp[-4].blk));
 | |
|     (yyval.blk) = gen_import(jv_string_value(v), (yyvsp[-1].blk), jv_string_value((yyvsp[-2].literal)), 0);
 | |
|     jv_free(v);
 | |
|   }
 | |
|   block_free((yyvsp[-4].blk));
 | |
|   jv_free((yyvsp[-2].literal));
 | |
| }
 | |
| #line 2663 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 51:
 | |
| #line 501 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   if (!block_is_const((yyvsp[-1].blk))) {
 | |
|     FAIL((yyloc), "Module metadata must be constant.");
 | |
|     (yyval.blk) = gen_noop();
 | |
|   } else {
 | |
|     jv v = block_const((yyvsp[-5].blk));
 | |
|     (yyval.blk) = gen_import(jv_string_value(v), (yyvsp[-1].blk), jv_string_value((yyvsp[-2].literal)), 1);
 | |
|     jv_free(v);
 | |
|   }
 | |
|   block_free((yyvsp[-5].blk));
 | |
|   jv_free((yyvsp[-2].literal));
 | |
| }
 | |
| #line 2680 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 52:
 | |
| #line 515 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_function(jv_string_value((yyvsp[-3].literal)), gen_noop(), (yyvsp[-1].blk));
 | |
|   jv_free((yyvsp[-3].literal));
 | |
| }
 | |
| #line 2689 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 53:
 | |
| #line 520 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_function(jv_string_value((yyvsp[-6].literal)), (yyvsp[-4].blk), (yyvsp[-1].blk));
 | |
|   jv_free((yyvsp[-6].literal));
 | |
| }
 | |
| #line 2698 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 54:
 | |
| #line 526 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[0].blk);
 | |
| }
 | |
| #line 2706 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 55:
 | |
| #line 529 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = BLOCK((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2714 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 56:
 | |
| #line 534 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_param_regular(jv_string_value((yyvsp[0].literal)));
 | |
|   jv_free((yyvsp[0].literal));
 | |
| }
 | |
| #line 2723 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 57:
 | |
| #line 539 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_param(jv_string_value((yyvsp[0].literal)));
 | |
|   jv_free((yyvsp[0].literal));
 | |
| }
 | |
| #line 2732 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 58:
 | |
| #line 546 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.literal) = jv_string("text"); }
 | |
| #line 2738 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 59:
 | |
| #line 546 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[-1].blk);
 | |
|   jv_free((yyvsp[-2].literal));
 | |
| }
 | |
| #line 2747 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 60:
 | |
| #line 550 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.literal) = (yyvsp[-1].literal); }
 | |
| #line 2753 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 61:
 | |
| #line 550 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[-1].blk);
 | |
|   jv_free((yyvsp[-2].literal));
 | |
| }
 | |
| #line 2762 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 62:
 | |
| #line 557 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_const(jv_string(""));
 | |
| }
 | |
| #line 2770 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 63:
 | |
| #line 560 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-1].blk), gen_const((yyvsp[0].literal)), '+');
 | |
| }
 | |
| #line 2778 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 64:
 | |
| #line 563 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_binop((yyvsp[-3].blk), gen_format((yyvsp[-1].blk), jv_copy((yyvsp[-4].literal))), '+');
 | |
| }
 | |
| #line 2786 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 65:
 | |
| #line 569 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_cond((yyvsp[-3].blk), (yyvsp[-1].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2794 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 66:
 | |
| #line 572 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[-1].blk);
 | |
| }
 | |
| #line 2802 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 67:
 | |
| #line 577 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = block_join((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2810 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 68:
 | |
| #line 580 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = BLOCK((yyvsp[0].blk), gen_call("_negate", gen_noop()));
 | |
| }
 | |
| #line 2818 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 69:
 | |
| #line 583 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[0].blk);
 | |
| }
 | |
| #line 2826 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 70:
 | |
| #line 589 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_noop(); 
 | |
| }
 | |
| #line 2834 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 71:
 | |
| #line 592 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_call("recurse", gen_noop());
 | |
| }
 | |
| #line 2842 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 72:
 | |
| #line 595 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   jv v = jv_string_fmt("*label-%s", jv_string_value((yyvsp[0].literal)));     // impossible symbol
 | |
|   (yyval.blk) = gen_location((yyloc), locations,
 | |
|                     BLOCK(gen_op_unbound(LOADV, jv_string_value(v)),
 | |
|                     gen_call("error", gen_noop())));
 | |
|   jv_free(v);
 | |
|   jv_free((yyvsp[0].literal));
 | |
| }
 | |
| #line 2855 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 73:
 | |
| #line 603 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   FAIL((yyloc), "break requires a label to break to");
 | |
|   (yyval.blk) = gen_noop();
 | |
| }
 | |
| #line 2864 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 74:
 | |
| #line 607 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index_opt((yyvsp[-2].blk), gen_const((yyvsp[-1].literal)));
 | |
| }
 | |
| #line 2872 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 75:
 | |
| #line 610 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = gen_index_opt(gen_noop(), gen_const((yyvsp[-1].literal))); 
 | |
| }
 | |
| #line 2880 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 76:
 | |
| #line 613 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index_opt((yyvsp[-3].blk), (yyvsp[-1].blk));
 | |
| }
 | |
| #line 2888 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 77:
 | |
| #line 616 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index_opt(gen_noop(), (yyvsp[-1].blk));
 | |
| }
 | |
| #line 2896 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 78:
 | |
| #line 619 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index((yyvsp[-1].blk), gen_const((yyvsp[0].literal)));
 | |
| }
 | |
| #line 2904 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 79:
 | |
| #line 622 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = gen_index(gen_noop(), gen_const((yyvsp[0].literal))); 
 | |
| }
 | |
| #line 2912 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 80:
 | |
| #line 625 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2920 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 81:
 | |
| #line 628 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index(gen_noop(), (yyvsp[0].blk));
 | |
| }
 | |
| #line 2928 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 82:
 | |
| #line 631 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   FAIL((yyloc), "try .[\"field\"] instead of .field for unusually named fields");
 | |
|   (yyval.blk) = gen_noop();
 | |
| }
 | |
| #line 2937 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 83:
 | |
| #line 635 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   jv_free((yyvsp[-1].literal));
 | |
|   FAIL((yyloc), "try .[\"field\"] instead of .field for unusually named fields");
 | |
|   (yyval.blk) = gen_noop();
 | |
| }
 | |
| #line 2947 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 84:
 | |
| #line 641 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index_opt((yyvsp[-4].blk), (yyvsp[-2].blk)); 
 | |
| }
 | |
| #line 2955 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 85:
 | |
| #line 644 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_index((yyvsp[-3].blk), (yyvsp[-1].blk)); 
 | |
| }
 | |
| #line 2963 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 86:
 | |
| #line 647 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = block_join((yyvsp[-3].blk), gen_op_simple(EACH_OPT)); 
 | |
| }
 | |
| #line 2971 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 87:
 | |
| #line 650 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = block_join((yyvsp[-2].blk), gen_op_simple(EACH)); 
 | |
| }
 | |
| #line 2979 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 88:
 | |
| #line 653 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_slice_index((yyvsp[-6].blk), (yyvsp[-4].blk), (yyvsp[-2].blk), INDEX_OPT);
 | |
| }
 | |
| #line 2987 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 89:
 | |
| #line 656 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_slice_index((yyvsp[-5].blk), (yyvsp[-3].blk), gen_const(jv_null()), INDEX_OPT);
 | |
| }
 | |
| #line 2995 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 90:
 | |
| #line 659 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_slice_index((yyvsp[-5].blk), gen_const(jv_null()), (yyvsp[-2].blk), INDEX_OPT);
 | |
| }
 | |
| #line 3003 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 91:
 | |
| #line 662 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_slice_index((yyvsp[-5].blk), (yyvsp[-3].blk), (yyvsp[-1].blk), INDEX);
 | |
| }
 | |
| #line 3011 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 92:
 | |
| #line 665 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_slice_index((yyvsp[-4].blk), (yyvsp[-2].blk), gen_const(jv_null()), INDEX);
 | |
| }
 | |
| #line 3019 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 93:
 | |
| #line 668 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_slice_index((yyvsp[-4].blk), gen_const(jv_null()), (yyvsp[-1].blk), INDEX);
 | |
| }
 | |
| #line 3027 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 94:
 | |
| #line 671 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_const((yyvsp[0].literal)); 
 | |
| }
 | |
| #line 3035 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 95:
 | |
| #line 674 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[0].blk);
 | |
| }
 | |
| #line 3043 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 96:
 | |
| #line 677 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_format(gen_noop(), (yyvsp[0].literal));
 | |
| }
 | |
| #line 3051 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 97:
 | |
| #line 680 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = (yyvsp[-1].blk); 
 | |
| }
 | |
| #line 3059 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 98:
 | |
| #line 683 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = gen_collect((yyvsp[-1].blk)); 
 | |
| }
 | |
| #line 3067 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 99:
 | |
| #line 686 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = gen_const(jv_array()); 
 | |
| }
 | |
| #line 3075 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 100:
 | |
| #line 689 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   block o = gen_const_object((yyvsp[-1].blk));
 | |
|   if (o.first != NULL)
 | |
|     (yyval.blk) = o;
 | |
|   else
 | |
|     (yyval.blk) = BLOCK(gen_subexp(gen_const(jv_object())), (yyvsp[-1].blk), gen_op_simple(POP));
 | |
| }
 | |
| #line 3087 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 101:
 | |
| #line 696 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_const(JV_OBJECT(jv_string("file"), jv_copy(locations->fname),
 | |
|                            jv_string("line"), jv_number(locfile_get_line(locations, (yyloc).start) + 1)));
 | |
| }
 | |
| #line 3096 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 102:
 | |
| #line 700 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_location((yyloc), locations, gen_op_unbound(LOADV, jv_string_value((yyvsp[0].literal))));
 | |
|   jv_free((yyvsp[0].literal));
 | |
| }
 | |
| #line 3105 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 103:
 | |
| #line 704 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   const char *s = jv_string_value((yyvsp[0].literal));
 | |
|   if (strcmp(s, "false") == 0)
 | |
|     (yyval.blk) = gen_const(jv_false());
 | |
|   else if (strcmp(s, "true") == 0)
 | |
|     (yyval.blk) = gen_const(jv_true());
 | |
|   else if (strcmp(s, "null") == 0)
 | |
|     (yyval.blk) = gen_const(jv_null());
 | |
|   else
 | |
|     (yyval.blk) = gen_location((yyloc), locations, gen_call(s, gen_noop()));
 | |
|   jv_free((yyvsp[0].literal));
 | |
| }
 | |
| #line 3122 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 104:
 | |
| #line 716 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_call(jv_string_value((yyvsp[-3].literal)), (yyvsp[-1].blk));
 | |
|   (yyval.blk) = gen_location((yylsp[-3]), locations, (yyval.blk));
 | |
|   jv_free((yyvsp[-3].literal));
 | |
| }
 | |
| #line 3132 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 105:
 | |
| #line 721 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = gen_noop(); }
 | |
| #line 3138 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 106:
 | |
| #line 722 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = gen_noop(); }
 | |
| #line 3144 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 107:
 | |
| #line 723 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = (yyvsp[-3].blk); }
 | |
| #line 3150 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 108:
 | |
| #line 724 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = gen_noop(); }
 | |
| #line 3156 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 109:
 | |
| #line 727 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = (yyvsp[0].blk);
 | |
| }
 | |
| #line 3164 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 110:
 | |
| #line 730 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = BLOCK((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
| }
 | |
| #line 3172 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 111:
 | |
| #line 735 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_lambda((yyvsp[0].blk));
 | |
| }
 | |
| #line 3180 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 112:
 | |
| #line 740 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("as");
 | |
| }
 | |
| #line 3188 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 113:
 | |
| #line 743 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("def");
 | |
| }
 | |
| #line 3196 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 114:
 | |
| #line 746 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("module");
 | |
| }
 | |
| #line 3204 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 115:
 | |
| #line 749 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("import");
 | |
| }
 | |
| #line 3212 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 116:
 | |
| #line 752 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("if");
 | |
| }
 | |
| #line 3220 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 117:
 | |
| #line 755 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("then");
 | |
| }
 | |
| #line 3228 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 118:
 | |
| #line 758 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("else");
 | |
| }
 | |
| #line 3236 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 119:
 | |
| #line 761 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("elif");
 | |
| }
 | |
| #line 3244 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 120:
 | |
| #line 764 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("reduce");
 | |
| }
 | |
| #line 3252 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 121:
 | |
| #line 767 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("foreach");
 | |
| }
 | |
| #line 3260 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 122:
 | |
| #line 770 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("end");
 | |
| }
 | |
| #line 3268 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 123:
 | |
| #line 773 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("and");
 | |
| }
 | |
| #line 3276 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 124:
 | |
| #line 776 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("or");
 | |
| }
 | |
| #line 3284 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 125:
 | |
| #line 779 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("try");
 | |
| }
 | |
| #line 3292 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 126:
 | |
| #line 782 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("catch");
 | |
| }
 | |
| #line 3300 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 127:
 | |
| #line 785 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("label");
 | |
| }
 | |
| #line 3308 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 128:
 | |
| #line 788 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("break");
 | |
| }
 | |
| #line 3316 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 129:
 | |
| #line 791 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.literal) = jv_string("__loc__");
 | |
| }
 | |
| #line 3324 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 130:
 | |
| #line 796 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk)=gen_noop(); 
 | |
| }
 | |
| #line 3332 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 131:
 | |
| #line 799 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = (yyvsp[0].blk); }
 | |
| #line 3338 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 132:
 | |
| #line 800 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk)=block_join((yyvsp[-2].blk), (yyvsp[0].blk)); }
 | |
| #line 3344 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 133:
 | |
| #line 801 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = (yyvsp[0].blk); }
 | |
| #line 3350 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 134:
 | |
| #line 804 "parser.y" /* yacc.c:1646  */
 | |
|     { 
 | |
|   (yyval.blk) = gen_dictpair(gen_const((yyvsp[-2].literal)), (yyvsp[0].blk));
 | |
|  }
 | |
| #line 3358 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 135:
 | |
| #line 807 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_dictpair(gen_const((yyvsp[-2].literal)), (yyvsp[0].blk));
 | |
|   }
 | |
| #line 3366 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 136:
 | |
| #line 810 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_dictpair((yyvsp[-2].blk), (yyvsp[0].blk));
 | |
|   }
 | |
| #line 3374 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 137:
 | |
| #line 813 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_dictpair((yyvsp[0].blk), BLOCK(gen_op_simple(POP), gen_op_simple(DUP2),
 | |
|                               gen_op_simple(DUP2), gen_op_simple(INDEX)));
 | |
|   }
 | |
| #line 3383 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 138:
 | |
| #line 817 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_dictpair(gen_const(jv_copy((yyvsp[0].literal))),
 | |
|                     gen_index(gen_noop(), gen_const((yyvsp[0].literal))));
 | |
|   }
 | |
| #line 3392 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 139:
 | |
| #line 821 "parser.y" /* yacc.c:1646  */
 | |
|     {
 | |
|   (yyval.blk) = gen_dictpair((yyvsp[-3].blk), (yyvsp[0].blk));
 | |
|   }
 | |
| #line 3400 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
|   case 140:
 | |
| #line 824 "parser.y" /* yacc.c:1646  */
 | |
|     { (yyval.blk) = (yyvsp[0].blk); }
 | |
| #line 3406 "parser.c" /* yacc.c:1646  */
 | |
|     break;
 | |
| 
 | |
| 
 | |
| #line 3410 "parser.c" /* yacc.c:1646  */
 | |
|       default: break;
 | |
|     }
 | |
|   /* User semantic actions sometimes alter yychar, and that requires
 | |
|      that yytoken be updated with the new translation.  We take the
 | |
|      approach of translating immediately before every use of yytoken.
 | |
|      One alternative is translating here after every semantic action,
 | |
|      but that translation would be missed if the semantic action invokes
 | |
|      YYABORT, YYACCEPT, or YYERROR immediately after altering yychar or
 | |
|      if it invokes YYBACKUP.  In the case of YYABORT or YYACCEPT, an
 | |
|      incorrect destructor might then be invoked immediately.  In the
 | |
|      case of YYERROR or YYBACKUP, subsequent parser actions might lead
 | |
|      to an incorrect destructor call or verbose syntax error message
 | |
|      before the lookahead is translated.  */
 | |
|   YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
 | |
| 
 | |
|   YYPOPSTACK (yylen);
 | |
|   yylen = 0;
 | |
|   YY_STACK_PRINT (yyss, yyssp);
 | |
| 
 | |
|   *++yyvsp = yyval;
 | |
|   *++yylsp = yyloc;
 | |
| 
 | |
|   /* Now 'shift' the result of the reduction.  Determine what state
 | |
|      that goes to, based on the state we popped back to and the rule
 | |
|      number reduced by.  */
 | |
| 
 | |
|   yyn = yyr1[yyn];
 | |
| 
 | |
|   yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
 | |
|   if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
 | |
|     yystate = yytable[yystate];
 | |
|   else
 | |
|     yystate = yydefgoto[yyn - YYNTOKENS];
 | |
| 
 | |
|   goto yynewstate;
 | |
| 
 | |
| 
 | |
| /*--------------------------------------.
 | |
| | yyerrlab -- here on detecting error.  |
 | |
| `--------------------------------------*/
 | |
| yyerrlab:
 | |
|   /* Make sure we have latest lookahead translation.  See comments at
 | |
|      user semantic actions for why this is necessary.  */
 | |
|   yytoken = yychar == YYEMPTY ? YYEMPTY : YYTRANSLATE (yychar);
 | |
| 
 | |
|   /* If not already recovering from an error, report this error.  */
 | |
|   if (!yyerrstatus)
 | |
|     {
 | |
|       ++yynerrs;
 | |
| #if ! YYERROR_VERBOSE
 | |
|       yyerror (&yylloc, answer, errors, locations, lexer_param_ptr, YY_("syntax error"));
 | |
| #else
 | |
| # define YYSYNTAX_ERROR yysyntax_error (&yymsg_alloc, &yymsg, \
 | |
|                                         yyssp, yytoken)
 | |
|       {
 | |
|         char const *yymsgp = YY_("syntax error");
 | |
|         int yysyntax_error_status;
 | |
|         yysyntax_error_status = YYSYNTAX_ERROR;
 | |
|         if (yysyntax_error_status == 0)
 | |
|           yymsgp = yymsg;
 | |
|         else if (yysyntax_error_status == 1)
 | |
|           {
 | |
|             if (yymsg != yymsgbuf)
 | |
|               YYSTACK_FREE (yymsg);
 | |
|             yymsg = (char *) YYSTACK_ALLOC (yymsg_alloc);
 | |
|             if (!yymsg)
 | |
|               {
 | |
|                 yymsg = yymsgbuf;
 | |
|                 yymsg_alloc = sizeof yymsgbuf;
 | |
|                 yysyntax_error_status = 2;
 | |
|               }
 | |
|             else
 | |
|               {
 | |
|                 yysyntax_error_status = YYSYNTAX_ERROR;
 | |
|                 yymsgp = yymsg;
 | |
|               }
 | |
|           }
 | |
|         yyerror (&yylloc, answer, errors, locations, lexer_param_ptr, yymsgp);
 | |
|         if (yysyntax_error_status == 2)
 | |
|           goto yyexhaustedlab;
 | |
|       }
 | |
| # undef YYSYNTAX_ERROR
 | |
| #endif
 | |
|     }
 | |
| 
 | |
|   yyerror_range[1] = yylloc;
 | |
| 
 | |
|   if (yyerrstatus == 3)
 | |
|     {
 | |
|       /* If just tried and failed to reuse lookahead token after an
 | |
|          error, discard it.  */
 | |
| 
 | |
|       if (yychar <= YYEOF)
 | |
|         {
 | |
|           /* Return failure if at end of input.  */
 | |
|           if (yychar == YYEOF)
 | |
|             YYABORT;
 | |
|         }
 | |
|       else
 | |
|         {
 | |
|           yydestruct ("Error: discarding",
 | |
|                       yytoken, &yylval, &yylloc, answer, errors, locations, lexer_param_ptr);
 | |
|           yychar = YYEMPTY;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|   /* Else will try to reuse lookahead token after shifting the error
 | |
|      token.  */
 | |
|   goto yyerrlab1;
 | |
| 
 | |
| 
 | |
| /*---------------------------------------------------.
 | |
| | yyerrorlab -- error raised explicitly by YYERROR.  |
 | |
| `---------------------------------------------------*/
 | |
| yyerrorlab:
 | |
| 
 | |
|   /* Pacify compilers like GCC when the user code never invokes
 | |
|      YYERROR and the label yyerrorlab therefore never appears in user
 | |
|      code.  */
 | |
|   if (/*CONSTCOND*/ 0)
 | |
|      goto yyerrorlab;
 | |
| 
 | |
|   yyerror_range[1] = yylsp[1-yylen];
 | |
|   /* Do not reclaim the symbols of the rule whose action triggered
 | |
|      this YYERROR.  */
 | |
|   YYPOPSTACK (yylen);
 | |
|   yylen = 0;
 | |
|   YY_STACK_PRINT (yyss, yyssp);
 | |
|   yystate = *yyssp;
 | |
|   goto yyerrlab1;
 | |
| 
 | |
| 
 | |
| /*-------------------------------------------------------------.
 | |
| | yyerrlab1 -- common code for both syntax error and YYERROR.  |
 | |
| `-------------------------------------------------------------*/
 | |
| yyerrlab1:
 | |
|   yyerrstatus = 3;      /* Each real token shifted decrements this.  */
 | |
| 
 | |
|   for (;;)
 | |
|     {
 | |
|       yyn = yypact[yystate];
 | |
|       if (!yypact_value_is_default (yyn))
 | |
|         {
 | |
|           yyn += YYTERROR;
 | |
|           if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
 | |
|             {
 | |
|               yyn = yytable[yyn];
 | |
|               if (0 < yyn)
 | |
|                 break;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|       /* Pop the current state because it cannot handle the error token.  */
 | |
|       if (yyssp == yyss)
 | |
|         YYABORT;
 | |
| 
 | |
|       yyerror_range[1] = *yylsp;
 | |
|       yydestruct ("Error: popping",
 | |
|                   yystos[yystate], yyvsp, yylsp, answer, errors, locations, lexer_param_ptr);
 | |
|       YYPOPSTACK (1);
 | |
|       yystate = *yyssp;
 | |
|       YY_STACK_PRINT (yyss, yyssp);
 | |
|     }
 | |
| 
 | |
|   YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
 | |
|   *++yyvsp = yylval;
 | |
|   YY_IGNORE_MAYBE_UNINITIALIZED_END
 | |
| 
 | |
|   yyerror_range[2] = yylloc;
 | |
|   /* Using YYLLOC is tempting, but would change the location of
 | |
|      the lookahead.  YYLOC is available though.  */
 | |
|   YYLLOC_DEFAULT (yyloc, yyerror_range, 2);
 | |
|   *++yylsp = yyloc;
 | |
| 
 | |
|   /* Shift the error token.  */
 | |
|   YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
 | |
| 
 | |
|   yystate = yyn;
 | |
|   goto yynewstate;
 | |
| 
 | |
| 
 | |
| /*-------------------------------------.
 | |
| | yyacceptlab -- YYACCEPT comes here.  |
 | |
| `-------------------------------------*/
 | |
| yyacceptlab:
 | |
|   yyresult = 0;
 | |
|   goto yyreturn;
 | |
| 
 | |
| /*-----------------------------------.
 | |
| | yyabortlab -- YYABORT comes here.  |
 | |
| `-----------------------------------*/
 | |
| yyabortlab:
 | |
|   yyresult = 1;
 | |
|   goto yyreturn;
 | |
| 
 | |
| #if !defined yyoverflow || YYERROR_VERBOSE
 | |
| /*-------------------------------------------------.
 | |
| | yyexhaustedlab -- memory exhaustion comes here.  |
 | |
| `-------------------------------------------------*/
 | |
| yyexhaustedlab:
 | |
|   yyerror (&yylloc, answer, errors, locations, lexer_param_ptr, YY_("memory exhausted"));
 | |
|   yyresult = 2;
 | |
|   /* Fall through.  */
 | |
| #endif
 | |
| 
 | |
| yyreturn:
 | |
|   if (yychar != YYEMPTY)
 | |
|     {
 | |
|       /* Make sure we have latest lookahead translation.  See comments at
 | |
|          user semantic actions for why this is necessary.  */
 | |
|       yytoken = YYTRANSLATE (yychar);
 | |
|       yydestruct ("Cleanup: discarding lookahead",
 | |
|                   yytoken, &yylval, &yylloc, answer, errors, locations, lexer_param_ptr);
 | |
|     }
 | |
|   /* Do not reclaim the symbols of the rule whose action triggered
 | |
|      this YYABORT or YYACCEPT.  */
 | |
|   YYPOPSTACK (yylen);
 | |
|   YY_STACK_PRINT (yyss, yyssp);
 | |
|   while (yyssp != yyss)
 | |
|     {
 | |
|       yydestruct ("Cleanup: popping",
 | |
|                   yystos[*yyssp], yyvsp, yylsp, answer, errors, locations, lexer_param_ptr);
 | |
|       YYPOPSTACK (1);
 | |
|     }
 | |
| #ifndef yyoverflow
 | |
|   if (yyss != yyssa)
 | |
|     YYSTACK_FREE (yyss);
 | |
| #endif
 | |
| #if YYERROR_VERBOSE
 | |
|   if (yymsg != yymsgbuf)
 | |
|     YYSTACK_FREE (yymsg);
 | |
| #endif
 | |
|   return yyresult;
 | |
| }
 | |
| #line 825 "parser.y" /* yacc.c:1906  */
 | |
| 
 | |
| 
 | |
| int jq_parse(struct locfile* locations, block* answer) {
 | |
|   struct lexer_param scanner;
 | |
|   YY_BUFFER_STATE buf;
 | |
|   jq_yylex_init_extra(0, &scanner.lexer);
 | |
|   buf = jq_yy_scan_bytes(locations->data, locations->length, scanner.lexer);
 | |
|   int errors = 0;
 | |
|   *answer = gen_noop();
 | |
|   yyparse(answer, &errors, locations, &scanner);
 | |
|   jq_yy_delete_buffer(buf, scanner.lexer);
 | |
|   jq_yylex_destroy(scanner.lexer);
 | |
|   if (errors > 0) {
 | |
|     block_free(*answer);
 | |
|     *answer = gen_noop();
 | |
|   }
 | |
|   return errors;
 | |
| }
 | |
| 
 | |
| int jq_parse_library(struct locfile* locations, block* answer) {
 | |
|   int errs = jq_parse(locations, answer);
 | |
|   if (errs) return errs;
 | |
|   if (block_has_main(*answer)) {
 | |
|     locfile_locate(locations, UNKNOWN_LOCATION, "jq: error: library should only have function definitions, not a main expression");
 | |
|     return 1;
 | |
|   }
 | |
|   assert(block_has_only_binders_and_imports(*answer, OP_IS_CALL_PSEUDO));
 | |
|   return 0;
 | |
| }
 |