summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-compiler/core
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2020-11-22 22:44:22 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2020-11-22 22:44:22 +0900
commitabdd006df32aa12bef7f1819edfed3209e379e36 (patch)
treeafa177b6cdc4d3ea07f345a76c34db6e5ab419e8 /mrbgems/mruby-compiler/core
parent2d9bf22730d69b0450b47421bc23146e23dc1ebf (diff)
downloadmruby-abdd006df32aa12bef7f1819edfed3209e379e36.tar.gz
mruby-abdd006df32aa12bef7f1819edfed3209e379e36.zip
Strictly speaking `NULL + 0` is a undefined behavior; ref #5157
Diffstat (limited to 'mrbgems/mruby-compiler/core')
-rw-r--r--mrbgems/mruby-compiler/core/parse.y9
-rw-r--r--mrbgems/mruby-compiler/core/y.tab.c2897
2 files changed, 1266 insertions, 1640 deletions
diff --git a/mrbgems/mruby-compiler/core/parse.y b/mrbgems/mruby-compiler/core/parse.y
index ab04e1d6b..06d616f58 100644
--- a/mrbgems/mruby-compiler/core/parse.y
+++ b/mrbgems/mruby-compiler/core/parse.y
@@ -6528,8 +6528,13 @@ mrb_parse_file_continue(mrb_state *mrb, FILE *f, const void *prebuf, size_t preb
p = mrb_parser_new(mrb);
if (!p) return NULL;
- p->s = (const char *)prebuf;
- p->send = (const char *)prebuf + prebufsize;
+ if (prebuf) {
+ p->s = (const char *)prebuf;
+ p->send = (const char *)prebuf + prebufsize;
+ }
+ else {
+ p->s = p->send = NULL;
+ }
p->f = f;
mrb_parser_parse(p, c);
diff --git a/mrbgems/mruby-compiler/core/y.tab.c b/mrbgems/mruby-compiler/core/y.tab.c
index af5a8c5b1..01d3570ad 100644
--- a/mrbgems/mruby-compiler/core/y.tab.c
+++ b/mrbgems/mruby-compiler/core/y.tab.c
@@ -1,4 +1,4 @@
-/* A Bison parser, made by GNU Bison 3.7.4. */
+/* A Bison parser, made by GNU Bison 3.5.1. */
/* Bison implementation for Yacc-like parsers in C
@@ -34,10 +34,6 @@
/* C LALR(1) parser skeleton written by Richard Stallman, by
simplifying the original so-called "semantic" parser. */
-/* DO NOT RELY ON FEATURES THAT ARE NOT DOCUMENTED in the manual,
- especially those whose name start with YY_ or yy_. They are
- private implementation details that can be changed or removed. */
-
/* 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.
@@ -45,11 +41,14 @@
define necessary library symbols; they are noted "INFRINGES ON
USER NAME SPACE" below. */
-/* Identify Bison output, and Bison version. */
-#define YYBISON 30704
+/* Undocumented macros, especially those whose name start with YY_,
+ are private implementation details. Do not rely on them. */
+
+/* Identify Bison output. */
+#define YYBISON 1
-/* Bison version string. */
-#define YYBISON_VERSION "3.7.4"
+/* Bison version. */
+#define YYBISON_VERSION "3.5.1"
/* Skeleton name. */
#define YYSKELETON_NAME "yacc.c"
@@ -1432,7 +1431,7 @@ heredoc_end(parser_state *p)
/* xxx ----------------------------- */
-#line 1436 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 1435 "mrbgems/mruby-compiler/core/y.tab.c"
# ifndef YY_CAST
# ifdef __cplusplus
@@ -1455,6 +1454,14 @@ heredoc_end(parser_state *p)
# endif
# endif
+/* Enabling verbose error messages. */
+#ifdef YYERROR_VERBOSE
+# undef YYERROR_VERBOSE
+# define YYERROR_VERBOSE 1
+#else
+# define YYERROR_VERBOSE 1
+#endif
+
/* Debug traces. */
#ifndef YYDEBUG
@@ -1464,137 +1471,132 @@ heredoc_end(parser_state *p)
extern int yydebug;
#endif
-/* Token kinds. */
+/* Token type. */
#ifndef YYTOKENTYPE
# define YYTOKENTYPE
enum yytokentype
{
- YYEMPTY = -2,
- YYEOF = 0, /* "end of file" */
- YYerror = 256, /* error */
- YYUNDEF = 257, /* "invalid token" */
- keyword_class = 258, /* keyword_class */
- keyword_module = 259, /* keyword_module */
- keyword_def = 260, /* keyword_def */
- keyword_begin = 261, /* keyword_begin */
- keyword_if = 262, /* keyword_if */
- keyword_unless = 263, /* keyword_unless */
- keyword_while = 264, /* keyword_while */
- keyword_until = 265, /* keyword_until */
- keyword_for = 266, /* keyword_for */
- keyword_undef = 267, /* keyword_undef */
- keyword_rescue = 268, /* keyword_rescue */
- keyword_ensure = 269, /* keyword_ensure */
- keyword_end = 270, /* keyword_end */
- keyword_then = 271, /* keyword_then */
- keyword_elsif = 272, /* keyword_elsif */
- keyword_else = 273, /* keyword_else */
- keyword_case = 274, /* keyword_case */
- keyword_when = 275, /* keyword_when */
- keyword_break = 276, /* keyword_break */
- keyword_next = 277, /* keyword_next */
- keyword_redo = 278, /* keyword_redo */
- keyword_retry = 279, /* keyword_retry */
- keyword_in = 280, /* keyword_in */
- keyword_do = 281, /* keyword_do */
- keyword_do_cond = 282, /* keyword_do_cond */
- keyword_do_block = 283, /* keyword_do_block */
- keyword_do_LAMBDA = 284, /* keyword_do_LAMBDA */
- keyword_return = 285, /* keyword_return */
- keyword_yield = 286, /* keyword_yield */
- keyword_super = 287, /* keyword_super */
- keyword_self = 288, /* keyword_self */
- keyword_nil = 289, /* keyword_nil */
- keyword_true = 290, /* keyword_true */
- keyword_false = 291, /* keyword_false */
- keyword_and = 292, /* keyword_and */
- keyword_or = 293, /* keyword_or */
- keyword_not = 294, /* keyword_not */
- modifier_if = 295, /* modifier_if */
- modifier_unless = 296, /* modifier_unless */
- modifier_while = 297, /* modifier_while */
- modifier_until = 298, /* modifier_until */
- modifier_rescue = 299, /* modifier_rescue */
- keyword_alias = 300, /* keyword_alias */
- keyword_BEGIN = 301, /* keyword_BEGIN */
- keyword_END = 302, /* keyword_END */
- keyword__LINE__ = 303, /* keyword__LINE__ */
- keyword__FILE__ = 304, /* keyword__FILE__ */
- keyword__ENCODING__ = 305, /* keyword__ENCODING__ */
- tIDENTIFIER = 306, /* tIDENTIFIER */
- tFID = 307, /* tFID */
- tGVAR = 308, /* tGVAR */
- tIVAR = 309, /* tIVAR */
- tCONSTANT = 310, /* tCONSTANT */
- tCVAR = 311, /* tCVAR */
- tLABEL_TAG = 312, /* tLABEL_TAG */
- tINTEGER = 313, /* tINTEGER */
- tFLOAT = 314, /* tFLOAT */
- tCHAR = 315, /* tCHAR */
- tXSTRING = 316, /* tXSTRING */
- tREGEXP = 317, /* tREGEXP */
- tSTRING = 318, /* tSTRING */
- tSTRING_PART = 319, /* tSTRING_PART */
- tSTRING_MID = 320, /* tSTRING_MID */
- tNTH_REF = 321, /* tNTH_REF */
- tBACK_REF = 322, /* tBACK_REF */
- tREGEXP_END = 323, /* tREGEXP_END */
- tNUMPARAM = 324, /* tNUMPARAM */
- tUPLUS = 325, /* tUPLUS */
- tUMINUS = 326, /* tUMINUS */
- tPOW = 327, /* tPOW */
- tCMP = 328, /* tCMP */
- tEQ = 329, /* tEQ */
- tEQQ = 330, /* tEQQ */
- tNEQ = 331, /* tNEQ */
- tGEQ = 332, /* tGEQ */
- tLEQ = 333, /* tLEQ */
- tANDOP = 334, /* tANDOP */
- tOROP = 335, /* tOROP */
- tMATCH = 336, /* tMATCH */
- tNMATCH = 337, /* tNMATCH */
- tDOT2 = 338, /* tDOT2 */
- tDOT3 = 339, /* tDOT3 */
- tBDOT2 = 340, /* tBDOT2 */
- tBDOT3 = 341, /* tBDOT3 */
- tAREF = 342, /* tAREF */
- tASET = 343, /* tASET */
- tLSHFT = 344, /* tLSHFT */
- tRSHFT = 345, /* tRSHFT */
- tCOLON2 = 346, /* tCOLON2 */
- tCOLON3 = 347, /* tCOLON3 */
- tOP_ASGN = 348, /* tOP_ASGN */
- tASSOC = 349, /* tASSOC */
- tLPAREN = 350, /* tLPAREN */
- tLPAREN_ARG = 351, /* tLPAREN_ARG */
- tRPAREN = 352, /* tRPAREN */
- tLBRACK = 353, /* tLBRACK */
- tLBRACE = 354, /* tLBRACE */
- tLBRACE_ARG = 355, /* tLBRACE_ARG */
- tSTAR = 356, /* tSTAR */
- tDSTAR = 357, /* tDSTAR */
- tAMPER = 358, /* tAMPER */
- tLAMBDA = 359, /* tLAMBDA */
- tANDDOT = 360, /* tANDDOT */
- tSYMBEG = 361, /* tSYMBEG */
- tREGEXP_BEG = 362, /* tREGEXP_BEG */
- tWORDS_BEG = 363, /* tWORDS_BEG */
- tSYMBOLS_BEG = 364, /* tSYMBOLS_BEG */
- tSTRING_BEG = 365, /* tSTRING_BEG */
- tXSTRING_BEG = 366, /* tXSTRING_BEG */
- tSTRING_DVAR = 367, /* tSTRING_DVAR */
- tLAMBEG = 368, /* tLAMBEG */
- tHEREDOC_BEG = 369, /* tHEREDOC_BEG */
- tHEREDOC_END = 370, /* tHEREDOC_END */
- tLITERAL_DELIM = 371, /* tLITERAL_DELIM */
- tHD_LITERAL_DELIM = 372, /* tHD_LITERAL_DELIM */
- tHD_STRING_PART = 373, /* tHD_STRING_PART */
- tHD_STRING_MID = 374, /* tHD_STRING_MID */
- tLOWEST = 375, /* tLOWEST */
- tUMINUS_NUM = 376, /* tUMINUS_NUM */
- tLAST_TOKEN = 377 /* tLAST_TOKEN */
+ keyword_class = 258,
+ keyword_module = 259,
+ keyword_def = 260,
+ keyword_begin = 261,
+ keyword_if = 262,
+ keyword_unless = 263,
+ keyword_while = 264,
+ keyword_until = 265,
+ keyword_for = 266,
+ keyword_undef = 267,
+ keyword_rescue = 268,
+ keyword_ensure = 269,
+ keyword_end = 270,
+ keyword_then = 271,
+ keyword_elsif = 272,
+ keyword_else = 273,
+ keyword_case = 274,
+ keyword_when = 275,
+ keyword_break = 276,
+ keyword_next = 277,
+ keyword_redo = 278,
+ keyword_retry = 279,
+ keyword_in = 280,
+ keyword_do = 281,
+ keyword_do_cond = 282,
+ keyword_do_block = 283,
+ keyword_do_LAMBDA = 284,
+ keyword_return = 285,
+ keyword_yield = 286,
+ keyword_super = 287,
+ keyword_self = 288,
+ keyword_nil = 289,
+ keyword_true = 290,
+ keyword_false = 291,
+ keyword_and = 292,
+ keyword_or = 293,
+ keyword_not = 294,
+ modifier_if = 295,
+ modifier_unless = 296,
+ modifier_while = 297,
+ modifier_until = 298,
+ modifier_rescue = 299,
+ keyword_alias = 300,
+ keyword_BEGIN = 301,
+ keyword_END = 302,
+ keyword__LINE__ = 303,
+ keyword__FILE__ = 304,
+ keyword__ENCODING__ = 305,
+ tIDENTIFIER = 306,
+ tFID = 307,
+ tGVAR = 308,
+ tIVAR = 309,
+ tCONSTANT = 310,
+ tCVAR = 311,
+ tLABEL_TAG = 312,
+ tINTEGER = 313,
+ tFLOAT = 314,
+ tCHAR = 315,
+ tXSTRING = 316,
+ tREGEXP = 317,
+ tSTRING = 318,
+ tSTRING_PART = 319,
+ tSTRING_MID = 320,
+ tNTH_REF = 321,
+ tBACK_REF = 322,
+ tREGEXP_END = 323,
+ tNUMPARAM = 324,
+ tUPLUS = 325,
+ tUMINUS = 326,
+ tPOW = 327,
+ tCMP = 328,
+ tEQ = 329,
+ tEQQ = 330,
+ tNEQ = 331,
+ tGEQ = 332,
+ tLEQ = 333,
+ tANDOP = 334,
+ tOROP = 335,
+ tMATCH = 336,
+ tNMATCH = 337,
+ tDOT2 = 338,
+ tDOT3 = 339,
+ tBDOT2 = 340,
+ tBDOT3 = 341,
+ tAREF = 342,
+ tASET = 343,
+ tLSHFT = 344,
+ tRSHFT = 345,
+ tCOLON2 = 346,
+ tCOLON3 = 347,
+ tOP_ASGN = 348,
+ tASSOC = 349,
+ tLPAREN = 350,
+ tLPAREN_ARG = 351,
+ tRPAREN = 352,
+ tLBRACK = 353,
+ tLBRACE = 354,
+ tLBRACE_ARG = 355,
+ tSTAR = 356,
+ tDSTAR = 357,
+ tAMPER = 358,
+ tLAMBDA = 359,
+ tANDDOT = 360,
+ tSYMBEG = 361,
+ tREGEXP_BEG = 362,
+ tWORDS_BEG = 363,
+ tSYMBOLS_BEG = 364,
+ tSTRING_BEG = 365,
+ tXSTRING_BEG = 366,
+ tSTRING_DVAR = 367,
+ tLAMBEG = 368,
+ tHEREDOC_BEG = 369,
+ tHEREDOC_END = 370,
+ tLITERAL_DELIM = 371,
+ tHD_LITERAL_DELIM = 372,
+ tHD_STRING_PART = 373,
+ tHD_STRING_MID = 374,
+ tLOWEST = 375,
+ tUMINUS_NUM = 376,
+ tLAST_TOKEN = 377
};
- typedef enum yytokentype yytoken_kind_t;
#endif
/* Value type. */
@@ -1609,7 +1611,7 @@ union YYSTYPE
stack_type stack;
const struct vtable *vars;
-#line 1613 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 1615 "mrbgems/mruby-compiler/core/y.tab.c"
};
typedef union YYSTYPE YYSTYPE;
@@ -1622,338 +1624,6 @@ typedef union YYSTYPE YYSTYPE;
int yyparse (parser_state *p);
-/* Symbol kind. */
-enum yysymbol_kind_t
-{
- YYSYMBOL_YYEMPTY = -2,
- YYSYMBOL_YYEOF = 0, /* "end of file" */
- YYSYMBOL_YYerror = 1, /* error */
- YYSYMBOL_YYUNDEF = 2, /* "invalid token" */
- YYSYMBOL_keyword_class = 3, /* keyword_class */
- YYSYMBOL_keyword_module = 4, /* keyword_module */
- YYSYMBOL_keyword_def = 5, /* keyword_def */
- YYSYMBOL_keyword_begin = 6, /* keyword_begin */
- YYSYMBOL_keyword_if = 7, /* keyword_if */
- YYSYMBOL_keyword_unless = 8, /* keyword_unless */
- YYSYMBOL_keyword_while = 9, /* keyword_while */
- YYSYMBOL_keyword_until = 10, /* keyword_until */
- YYSYMBOL_keyword_for = 11, /* keyword_for */
- YYSYMBOL_keyword_undef = 12, /* keyword_undef */
- YYSYMBOL_keyword_rescue = 13, /* keyword_rescue */
- YYSYMBOL_keyword_ensure = 14, /* keyword_ensure */
- YYSYMBOL_keyword_end = 15, /* keyword_end */
- YYSYMBOL_keyword_then = 16, /* keyword_then */
- YYSYMBOL_keyword_elsif = 17, /* keyword_elsif */
- YYSYMBOL_keyword_else = 18, /* keyword_else */
- YYSYMBOL_keyword_case = 19, /* keyword_case */
- YYSYMBOL_keyword_when = 20, /* keyword_when */
- YYSYMBOL_keyword_break = 21, /* keyword_break */
- YYSYMBOL_keyword_next = 22, /* keyword_next */
- YYSYMBOL_keyword_redo = 23, /* keyword_redo */
- YYSYMBOL_keyword_retry = 24, /* keyword_retry */
- YYSYMBOL_keyword_in = 25, /* keyword_in */
- YYSYMBOL_keyword_do = 26, /* keyword_do */
- YYSYMBOL_keyword_do_cond = 27, /* keyword_do_cond */
- YYSYMBOL_keyword_do_block = 28, /* keyword_do_block */
- YYSYMBOL_keyword_do_LAMBDA = 29, /* keyword_do_LAMBDA */
- YYSYMBOL_keyword_return = 30, /* keyword_return */
- YYSYMBOL_keyword_yield = 31, /* keyword_yield */
- YYSYMBOL_keyword_super = 32, /* keyword_super */
- YYSYMBOL_keyword_self = 33, /* keyword_self */
- YYSYMBOL_keyword_nil = 34, /* keyword_nil */
- YYSYMBOL_keyword_true = 35, /* keyword_true */
- YYSYMBOL_keyword_false = 36, /* keyword_false */
- YYSYMBOL_keyword_and = 37, /* keyword_and */
- YYSYMBOL_keyword_or = 38, /* keyword_or */
- YYSYMBOL_keyword_not = 39, /* keyword_not */
- YYSYMBOL_modifier_if = 40, /* modifier_if */
- YYSYMBOL_modifier_unless = 41, /* modifier_unless */
- YYSYMBOL_modifier_while = 42, /* modifier_while */
- YYSYMBOL_modifier_until = 43, /* modifier_until */
- YYSYMBOL_modifier_rescue = 44, /* modifier_rescue */
- YYSYMBOL_keyword_alias = 45, /* keyword_alias */
- YYSYMBOL_keyword_BEGIN = 46, /* keyword_BEGIN */
- YYSYMBOL_keyword_END = 47, /* keyword_END */
- YYSYMBOL_keyword__LINE__ = 48, /* keyword__LINE__ */
- YYSYMBOL_keyword__FILE__ = 49, /* keyword__FILE__ */
- YYSYMBOL_keyword__ENCODING__ = 50, /* keyword__ENCODING__ */
- YYSYMBOL_tIDENTIFIER = 51, /* tIDENTIFIER */
- YYSYMBOL_tFID = 52, /* tFID */
- YYSYMBOL_tGVAR = 53, /* tGVAR */
- YYSYMBOL_tIVAR = 54, /* tIVAR */
- YYSYMBOL_tCONSTANT = 55, /* tCONSTANT */
- YYSYMBOL_tCVAR = 56, /* tCVAR */
- YYSYMBOL_tLABEL_TAG = 57, /* tLABEL_TAG */
- YYSYMBOL_tINTEGER = 58, /* tINTEGER */
- YYSYMBOL_tFLOAT = 59, /* tFLOAT */
- YYSYMBOL_tCHAR = 60, /* tCHAR */
- YYSYMBOL_tXSTRING = 61, /* tXSTRING */
- YYSYMBOL_tREGEXP = 62, /* tREGEXP */
- YYSYMBOL_tSTRING = 63, /* tSTRING */
- YYSYMBOL_tSTRING_PART = 64, /* tSTRING_PART */
- YYSYMBOL_tSTRING_MID = 65, /* tSTRING_MID */
- YYSYMBOL_tNTH_REF = 66, /* tNTH_REF */
- YYSYMBOL_tBACK_REF = 67, /* tBACK_REF */
- YYSYMBOL_tREGEXP_END = 68, /* tREGEXP_END */
- YYSYMBOL_tNUMPARAM = 69, /* tNUMPARAM */
- YYSYMBOL_tUPLUS = 70, /* tUPLUS */
- YYSYMBOL_tUMINUS = 71, /* tUMINUS */
- YYSYMBOL_tPOW = 72, /* tPOW */
- YYSYMBOL_tCMP = 73, /* tCMP */
- YYSYMBOL_tEQ = 74, /* tEQ */
- YYSYMBOL_tEQQ = 75, /* tEQQ */
- YYSYMBOL_tNEQ = 76, /* tNEQ */
- YYSYMBOL_tGEQ = 77, /* tGEQ */
- YYSYMBOL_tLEQ = 78, /* tLEQ */
- YYSYMBOL_tANDOP = 79, /* tANDOP */
- YYSYMBOL_tOROP = 80, /* tOROP */
- YYSYMBOL_tMATCH = 81, /* tMATCH */
- YYSYMBOL_tNMATCH = 82, /* tNMATCH */
- YYSYMBOL_tDOT2 = 83, /* tDOT2 */
- YYSYMBOL_tDOT3 = 84, /* tDOT3 */
- YYSYMBOL_tBDOT2 = 85, /* tBDOT2 */
- YYSYMBOL_tBDOT3 = 86, /* tBDOT3 */
- YYSYMBOL_tAREF = 87, /* tAREF */
- YYSYMBOL_tASET = 88, /* tASET */
- YYSYMBOL_tLSHFT = 89, /* tLSHFT */
- YYSYMBOL_tRSHFT = 90, /* tRSHFT */
- YYSYMBOL_tCOLON2 = 91, /* tCOLON2 */
- YYSYMBOL_tCOLON3 = 92, /* tCOLON3 */
- YYSYMBOL_tOP_ASGN = 93, /* tOP_ASGN */
- YYSYMBOL_tASSOC = 94, /* tASSOC */
- YYSYMBOL_tLPAREN = 95, /* tLPAREN */
- YYSYMBOL_tLPAREN_ARG = 96, /* tLPAREN_ARG */
- YYSYMBOL_tRPAREN = 97, /* tRPAREN */
- YYSYMBOL_tLBRACK = 98, /* tLBRACK */
- YYSYMBOL_tLBRACE = 99, /* tLBRACE */
- YYSYMBOL_tLBRACE_ARG = 100, /* tLBRACE_ARG */
- YYSYMBOL_tSTAR = 101, /* tSTAR */
- YYSYMBOL_tDSTAR = 102, /* tDSTAR */
- YYSYMBOL_tAMPER = 103, /* tAMPER */
- YYSYMBOL_tLAMBDA = 104, /* tLAMBDA */
- YYSYMBOL_tANDDOT = 105, /* tANDDOT */
- YYSYMBOL_tSYMBEG = 106, /* tSYMBEG */
- YYSYMBOL_tREGEXP_BEG = 107, /* tREGEXP_BEG */
- YYSYMBOL_tWORDS_BEG = 108, /* tWORDS_BEG */
- YYSYMBOL_tSYMBOLS_BEG = 109, /* tSYMBOLS_BEG */
- YYSYMBOL_tSTRING_BEG = 110, /* tSTRING_BEG */
- YYSYMBOL_tXSTRING_BEG = 111, /* tXSTRING_BEG */
- YYSYMBOL_tSTRING_DVAR = 112, /* tSTRING_DVAR */
- YYSYMBOL_tLAMBEG = 113, /* tLAMBEG */
- YYSYMBOL_tHEREDOC_BEG = 114, /* tHEREDOC_BEG */
- YYSYMBOL_tHEREDOC_END = 115, /* tHEREDOC_END */
- YYSYMBOL_tLITERAL_DELIM = 116, /* tLITERAL_DELIM */
- YYSYMBOL_tHD_LITERAL_DELIM = 117, /* tHD_LITERAL_DELIM */
- YYSYMBOL_tHD_STRING_PART = 118, /* tHD_STRING_PART */
- YYSYMBOL_tHD_STRING_MID = 119, /* tHD_STRING_MID */
- YYSYMBOL_tLOWEST = 120, /* tLOWEST */
- YYSYMBOL_121_ = 121, /* '=' */
- YYSYMBOL_122_ = 122, /* '?' */
- YYSYMBOL_123_ = 123, /* ':' */
- YYSYMBOL_124_ = 124, /* '>' */
- YYSYMBOL_125_ = 125, /* '<' */
- YYSYMBOL_126_ = 126, /* '|' */
- YYSYMBOL_127_ = 127, /* '^' */
- YYSYMBOL_128_ = 128, /* '&' */
- YYSYMBOL_129_ = 129, /* '+' */
- YYSYMBOL_130_ = 130, /* '-' */
- YYSYMBOL_131_ = 131, /* '*' */
- YYSYMBOL_132_ = 132, /* '/' */
- YYSYMBOL_133_ = 133, /* '%' */
- YYSYMBOL_tUMINUS_NUM = 134, /* tUMINUS_NUM */
- YYSYMBOL_135_ = 135, /* '!' */
- YYSYMBOL_136_ = 136, /* '~' */
- YYSYMBOL_tLAST_TOKEN = 137, /* tLAST_TOKEN */
- YYSYMBOL_138_ = 138, /* '{' */
- YYSYMBOL_139_ = 139, /* '}' */
- YYSYMBOL_140_ = 140, /* '[' */
- YYSYMBOL_141_ = 141, /* ']' */
- YYSYMBOL_142_ = 142, /* ',' */
- YYSYMBOL_143_ = 143, /* '`' */
- YYSYMBOL_144_ = 144, /* '(' */
- YYSYMBOL_145_ = 145, /* ')' */
- YYSYMBOL_146_ = 146, /* ';' */
- YYSYMBOL_147_ = 147, /* '.' */
- YYSYMBOL_148_n_ = 148, /* '\n' */
- YYSYMBOL_YYACCEPT = 149, /* $accept */
- YYSYMBOL_program = 150, /* program */
- YYSYMBOL_151_1 = 151, /* $@1 */
- YYSYMBOL_top_compstmt = 152, /* top_compstmt */
- YYSYMBOL_top_stmts = 153, /* top_stmts */
- YYSYMBOL_top_stmt = 154, /* top_stmt */
- YYSYMBOL_155_2 = 155, /* @2 */
- YYSYMBOL_bodystmt = 156, /* bodystmt */
- YYSYMBOL_compstmt = 157, /* compstmt */
- YYSYMBOL_stmts = 158, /* stmts */
- YYSYMBOL_stmt = 159, /* stmt */
- YYSYMBOL_160_3 = 160, /* $@3 */
- YYSYMBOL_command_asgn = 161, /* command_asgn */
- YYSYMBOL_command_rhs = 162, /* command_rhs */
- YYSYMBOL_expr = 163, /* expr */
- YYSYMBOL_defn_head = 164, /* defn_head */
- YYSYMBOL_defs_head = 165, /* defs_head */
- YYSYMBOL_166_4 = 166, /* $@4 */
- YYSYMBOL_expr_value = 167, /* expr_value */
- YYSYMBOL_command_call = 168, /* command_call */
- YYSYMBOL_block_command = 169, /* block_command */
- YYSYMBOL_cmd_brace_block = 170, /* cmd_brace_block */
- YYSYMBOL_171_5 = 171, /* $@5 */
- YYSYMBOL_command = 172, /* command */
- YYSYMBOL_mlhs = 173, /* mlhs */
- YYSYMBOL_mlhs_inner = 174, /* mlhs_inner */
- YYSYMBOL_mlhs_basic = 175, /* mlhs_basic */
- YYSYMBOL_mlhs_item = 176, /* mlhs_item */
- YYSYMBOL_mlhs_list = 177, /* mlhs_list */
- YYSYMBOL_mlhs_post = 178, /* mlhs_post */
- YYSYMBOL_mlhs_node = 179, /* mlhs_node */
- YYSYMBOL_lhs = 180, /* lhs */
- YYSYMBOL_cname = 181, /* cname */
- YYSYMBOL_cpath = 182, /* cpath */
- YYSYMBOL_fname = 183, /* fname */
- YYSYMBOL_fsym = 184, /* fsym */
- YYSYMBOL_undef_list = 185, /* undef_list */
- YYSYMBOL_186_6 = 186, /* $@6 */
- YYSYMBOL_op = 187, /* op */
- YYSYMBOL_reswords = 188, /* reswords */
- YYSYMBOL_arg = 189, /* arg */
- YYSYMBOL_aref_args = 190, /* aref_args */
- YYSYMBOL_arg_rhs = 191, /* arg_rhs */
- YYSYMBOL_paren_args = 192, /* paren_args */
- YYSYMBOL_opt_paren_args = 193, /* opt_paren_args */
- YYSYMBOL_opt_call_args = 194, /* opt_call_args */
- YYSYMBOL_call_args = 195, /* call_args */
- YYSYMBOL_command_args = 196, /* command_args */
- YYSYMBOL_197_7 = 197, /* @7 */
- YYSYMBOL_block_arg = 198, /* block_arg */
- YYSYMBOL_opt_block_arg = 199, /* opt_block_arg */
- YYSYMBOL_comma = 200, /* comma */
- YYSYMBOL_args = 201, /* args */
- YYSYMBOL_mrhs = 202, /* mrhs */
- YYSYMBOL_primary = 203, /* primary */
- YYSYMBOL_204_8 = 204, /* @8 */
- YYSYMBOL_205_9 = 205, /* @9 */
- YYSYMBOL_206_10 = 206, /* $@10 */
- YYSYMBOL_207_11 = 207, /* $@11 */
- YYSYMBOL_208_12 = 208, /* @12 */
- YYSYMBOL_209_13 = 209, /* @13 */
- YYSYMBOL_210_14 = 210, /* $@14 */
- YYSYMBOL_211_15 = 211, /* $@15 */
- YYSYMBOL_212_16 = 212, /* $@16 */
- YYSYMBOL_213_17 = 213, /* $@17 */
- YYSYMBOL_214_18 = 214, /* $@18 */
- YYSYMBOL_215_19 = 215, /* $@19 */
- YYSYMBOL_216_20 = 216, /* @20 */
- YYSYMBOL_217_21 = 217, /* @21 */
- YYSYMBOL_218_22 = 218, /* @22 */
- YYSYMBOL_219_23 = 219, /* @23 */
- YYSYMBOL_primary_value = 220, /* primary_value */
- YYSYMBOL_then = 221, /* then */
- YYSYMBOL_do = 222, /* do */
- YYSYMBOL_if_tail = 223, /* if_tail */
- YYSYMBOL_opt_else = 224, /* opt_else */
- YYSYMBOL_for_var = 225, /* for_var */
- YYSYMBOL_f_margs = 226, /* f_margs */
- YYSYMBOL_227_24 = 227, /* $@24 */
- YYSYMBOL_block_args_tail = 228, /* block_args_tail */
- YYSYMBOL_opt_block_args_tail = 229, /* opt_block_args_tail */
- YYSYMBOL_block_param = 230, /* block_param */
- YYSYMBOL_opt_block_param = 231, /* opt_block_param */
- YYSYMBOL_block_param_def = 232, /* block_param_def */
- YYSYMBOL_233_25 = 233, /* $@25 */
- YYSYMBOL_opt_bv_decl = 234, /* opt_bv_decl */
- YYSYMBOL_bv_decls = 235, /* bv_decls */
- YYSYMBOL_bvar = 236, /* bvar */
- YYSYMBOL_f_larglist = 237, /* f_larglist */
- YYSYMBOL_lambda_body = 238, /* lambda_body */
- YYSYMBOL_do_block = 239, /* do_block */
- YYSYMBOL_240_26 = 240, /* $@26 */
- YYSYMBOL_block_call = 241, /* block_call */
- YYSYMBOL_method_call = 242, /* method_call */
- YYSYMBOL_brace_block = 243, /* brace_block */
- YYSYMBOL_244_27 = 244, /* @27 */
- YYSYMBOL_245_28 = 245, /* @28 */
- YYSYMBOL_case_body = 246, /* case_body */
- YYSYMBOL_cases = 247, /* cases */
- YYSYMBOL_opt_rescue = 248, /* opt_rescue */
- YYSYMBOL_exc_list = 249, /* exc_list */
- YYSYMBOL_exc_var = 250, /* exc_var */
- YYSYMBOL_opt_ensure = 251, /* opt_ensure */
- YYSYMBOL_literal = 252, /* literal */
- YYSYMBOL_string = 253, /* string */
- YYSYMBOL_string_fragment = 254, /* string_fragment */
- YYSYMBOL_string_rep = 255, /* string_rep */
- YYSYMBOL_string_interp = 256, /* string_interp */
- YYSYMBOL_257_29 = 257, /* @29 */
- YYSYMBOL_xstring = 258, /* xstring */
- YYSYMBOL_regexp = 259, /* regexp */
- YYSYMBOL_heredoc = 260, /* heredoc */
- YYSYMBOL_heredoc_bodies = 261, /* heredoc_bodies */
- YYSYMBOL_heredoc_body = 262, /* heredoc_body */
- YYSYMBOL_heredoc_string_rep = 263, /* heredoc_string_rep */
- YYSYMBOL_heredoc_string_interp = 264, /* heredoc_string_interp */
- YYSYMBOL_265_30 = 265, /* @30 */
- YYSYMBOL_words = 266, /* words */
- YYSYMBOL_symbol = 267, /* symbol */
- YYSYMBOL_basic_symbol = 268, /* basic_symbol */
- YYSYMBOL_sym = 269, /* sym */
- YYSYMBOL_symbols = 270, /* symbols */
- YYSYMBOL_numeric = 271, /* numeric */
- YYSYMBOL_variable = 272, /* variable */
- YYSYMBOL_var_lhs = 273, /* var_lhs */
- YYSYMBOL_var_ref = 274, /* var_ref */
- YYSYMBOL_backref = 275, /* backref */
- YYSYMBOL_superclass = 276, /* superclass */
- YYSYMBOL_277_31 = 277, /* $@31 */
- YYSYMBOL_f_arglist_paren = 278, /* f_arglist_paren */
- YYSYMBOL_f_arglist = 279, /* f_arglist */
- YYSYMBOL_f_label = 280, /* f_label */
- YYSYMBOL_f_kw = 281, /* f_kw */
- YYSYMBOL_f_block_kw = 282, /* f_block_kw */
- YYSYMBOL_f_block_kwarg = 283, /* f_block_kwarg */
- YYSYMBOL_f_kwarg = 284, /* f_kwarg */
- YYSYMBOL_kwrest_mark = 285, /* kwrest_mark */
- YYSYMBOL_f_kwrest = 286, /* f_kwrest */
- YYSYMBOL_args_tail = 287, /* args_tail */
- YYSYMBOL_opt_args_tail = 288, /* opt_args_tail */
- YYSYMBOL_f_args = 289, /* f_args */
- YYSYMBOL_f_bad_arg = 290, /* f_bad_arg */
- YYSYMBOL_f_norm_arg = 291, /* f_norm_arg */
- YYSYMBOL_f_arg_item = 292, /* f_arg_item */
- YYSYMBOL_293_32 = 293, /* @32 */
- YYSYMBOL_f_arg = 294, /* f_arg */
- YYSYMBOL_f_opt_asgn = 295, /* f_opt_asgn */
- YYSYMBOL_f_opt = 296, /* f_opt */
- YYSYMBOL_f_block_opt = 297, /* f_block_opt */
- YYSYMBOL_f_block_optarg = 298, /* f_block_optarg */
- YYSYMBOL_f_optarg = 299, /* f_optarg */
- YYSYMBOL_restarg_mark = 300, /* restarg_mark */
- YYSYMBOL_f_rest_arg = 301, /* f_rest_arg */
- YYSYMBOL_blkarg_mark = 302, /* blkarg_mark */
- YYSYMBOL_f_block_arg = 303, /* f_block_arg */
- YYSYMBOL_opt_f_block_arg = 304, /* opt_f_block_arg */
- YYSYMBOL_singleton = 305, /* singleton */
- YYSYMBOL_306_33 = 306, /* $@33 */
- YYSYMBOL_assoc_list = 307, /* assoc_list */
- YYSYMBOL_assocs = 308, /* assocs */
- YYSYMBOL_label_tag = 309, /* label_tag */
- YYSYMBOL_assoc = 310, /* assoc */
- YYSYMBOL_operation = 311, /* operation */
- YYSYMBOL_operation2 = 312, /* operation2 */
- YYSYMBOL_operation3 = 313, /* operation3 */
- YYSYMBOL_dot_or_colon = 314, /* dot_or_colon */
- YYSYMBOL_call_op = 315, /* call_op */
- YYSYMBOL_call_op2 = 316, /* call_op2 */
- YYSYMBOL_opt_terms = 317, /* opt_terms */
- YYSYMBOL_opt_nl = 318, /* opt_nl */
- YYSYMBOL_rparen = 319, /* rparen */
- YYSYMBOL_trailer = 320, /* trailer */
- YYSYMBOL_term = 321, /* term */
- YYSYMBOL_nl = 322, /* nl */
- YYSYMBOL_terms = 323, /* terms */
- YYSYMBOL_none = 324 /* none */
-};
-typedef enum yysymbol_kind_t yysymbol_kind_t;
-
@@ -2053,7 +1723,6 @@ typedef int yytype_uint16;
#define YYSIZEOF(X) YY_CAST (YYPTRDIFF_T, sizeof (X))
-
/* Stored state numbers (used for stacks). */
typedef yytype_int16 yy_state_t;
@@ -2072,7 +1741,6 @@ typedef int yy_state_fast_t;
# endif
#endif
-
#ifndef YY_ATTRIBUTE_PURE
# if defined __GNUC__ && 2 < __GNUC__ + (96 <= __GNUC_MINOR__)
# define YY_ATTRIBUTE_PURE __attribute__ ((__pure__))
@@ -2130,7 +1798,7 @@ typedef int yy_state_fast_t;
#define YY_ASSERT(E) ((void) (0 && (E)))
-#if 1
+#if ! defined yyoverflow || YYERROR_VERBOSE
/* The parser invokes alloca or malloc; define the necessary symbols. */
@@ -2195,7 +1863,8 @@ void free (void *); /* INFRINGES ON USER NAME SPACE */
# endif
# endif
# endif
-#endif /* 1 */
+#endif /* ! defined yyoverflow || YYERROR_VERBOSE */
+
#if (! defined yyoverflow \
&& (! defined __cplusplus \
@@ -2271,16 +1940,14 @@ union yyalloc
/* YYNSTATES -- Number of states. */
#define YYNSTATES 1053
-/* YYMAXUTOK -- Last valid token kind. */
+#define YYUNDEFTOK 2
#define YYMAXUTOK 377
/* YYTRANSLATE(TOKEN-NUM) -- Symbol number corresponding to TOKEN-NUM
as returned by yylex, with out-of-bounds checking. */
-#define YYTRANSLATE(YYX) \
- (0 <= (YYX) && (YYX) <= YYMAXUTOK \
- ? YY_CAST (yysymbol_kind_t, yytranslate[YYX]) \
- : YYSYMBOL_YYUNDEF)
+#define YYTRANSLATE(YYX) \
+ (0 <= (YYX) && (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
/* YYTRANSLATE[TOKEN-NUM] -- Symbol number corresponding to TOKEN-NUM
as returned by yylex. */
@@ -2394,34 +2061,26 @@ static const yytype_int16 yyrline[] =
};
#endif
-/** Accessing symbol of state STATE. */
-#define YY_ACCESSING_SYMBOL(State) YY_CAST (yysymbol_kind_t, yystos[State])
-
-#if 1
-/* The user-facing name of the symbol whose (internal) number is
- YYSYMBOL. No bounds checking. */
-static const char *yysymbol_name (yysymbol_kind_t yysymbol) YY_ATTRIBUTE_UNUSED;
-
+#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 of file\"", "error", "\"invalid token\"", "keyword_class",
- "keyword_module", "keyword_def", "keyword_begin", "keyword_if",
- "keyword_unless", "keyword_while", "keyword_until", "keyword_for",
- "keyword_undef", "keyword_rescue", "keyword_ensure", "keyword_end",
- "keyword_then", "keyword_elsif", "keyword_else", "keyword_case",
- "keyword_when", "keyword_break", "keyword_next", "keyword_redo",
- "keyword_retry", "keyword_in", "keyword_do", "keyword_do_cond",
- "keyword_do_block", "keyword_do_LAMBDA", "keyword_return",
- "keyword_yield", "keyword_super", "keyword_self", "keyword_nil",
- "keyword_true", "keyword_false", "keyword_and", "keyword_or",
- "keyword_not", "modifier_if", "modifier_unless", "modifier_while",
- "modifier_until", "modifier_rescue", "keyword_alias", "keyword_BEGIN",
- "keyword_END", "keyword__LINE__", "keyword__FILE__",
- "keyword__ENCODING__", "tIDENTIFIER", "tFID", "tGVAR", "tIVAR",
- "tCONSTANT", "tCVAR", "tLABEL_TAG", "tINTEGER", "tFLOAT", "tCHAR",
- "tXSTRING", "tREGEXP", "tSTRING", "tSTRING_PART", "tSTRING_MID",
+ "$end", "error", "$undefined", "keyword_class", "keyword_module",
+ "keyword_def", "keyword_begin", "keyword_if", "keyword_unless",
+ "keyword_while", "keyword_until", "keyword_for", "keyword_undef",
+ "keyword_rescue", "keyword_ensure", "keyword_end", "keyword_then",
+ "keyword_elsif", "keyword_else", "keyword_case", "keyword_when",
+ "keyword_break", "keyword_next", "keyword_redo", "keyword_retry",
+ "keyword_in", "keyword_do", "keyword_do_cond", "keyword_do_block",
+ "keyword_do_LAMBDA", "keyword_return", "keyword_yield", "keyword_super",
+ "keyword_self", "keyword_nil", "keyword_true", "keyword_false",
+ "keyword_and", "keyword_or", "keyword_not", "modifier_if",
+ "modifier_unless", "modifier_while", "modifier_until", "modifier_rescue",
+ "keyword_alias", "keyword_BEGIN", "keyword_END", "keyword__LINE__",
+ "keyword__FILE__", "keyword__ENCODING__", "tIDENTIFIER", "tFID", "tGVAR",
+ "tIVAR", "tCONSTANT", "tCVAR", "tLABEL_TAG", "tINTEGER", "tFLOAT",
+ "tCHAR", "tXSTRING", "tREGEXP", "tSTRING", "tSTRING_PART", "tSTRING_MID",
"tNTH_REF", "tBACK_REF", "tREGEXP_END", "tNUMPARAM", "tUPLUS", "tUMINUS",
"tPOW", "tCMP", "tEQ", "tEQQ", "tNEQ", "tGEQ", "tLEQ", "tANDOP", "tOROP",
"tMATCH", "tNMATCH", "tDOT2", "tDOT3", "tBDOT2", "tBDOT3", "tAREF",
@@ -2467,15 +2126,9 @@ static const char *const yytname[] =
"call_op2", "opt_terms", "opt_nl", "rparen", "trailer", "term", "nl",
"terms", "none", YY_NULLPTR
};
-
-static const char *
-yysymbol_name (yysymbol_kind_t yysymbol)
-{
- return yytname[yysymbol];
-}
#endif
-#ifdef YYPRINT
+# ifdef YYPRINT
/* YYTOKNUM[NUM] -- (External) token number corresponding to the
(internal) symbol number NUM (which must be that of a token). */
static const yytype_int16 yytoknum[] =
@@ -2496,7 +2149,7 @@ static const yytype_int16 yytoknum[] =
45, 42, 47, 37, 376, 33, 126, 377, 123, 125,
91, 93, 44, 96, 40, 41, 59, 46, 10
};
-#endif
+# endif
#define YYPACT_NINF (-856)
@@ -5473,10 +5126,10 @@ static const yytype_int8 yyr2[] =
};
-enum { YYENOMEM = -2 };
-
#define yyerrok (yyerrstatus = 0)
#define yyclearin (yychar = YYEMPTY)
+#define YYEMPTY (-2)
+#define YYEOF 0
#define YYACCEPT goto yyacceptlab
#define YYABORT goto yyabortlab
@@ -5502,9 +5155,10 @@ enum { YYENOMEM = -2 };
} \
while (0)
-/* Backward compatibility with an undocumented macro.
- Use YYerror or YYUNDEF. */
-#define YYERRCODE YYUNDEF
+/* Error token number */
+#define YYTERROR 1
+#define YYERRCODE 256
+
/* Enable debugging if requested. */
@@ -5522,18 +5176,18 @@ do { \
} while (0)
/* This macro is provided for backward compatibility. */
-# ifndef YY_LOCATION_PRINT
-# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
-# endif
+#ifndef YY_LOCATION_PRINT
+# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
+#endif
-# define YY_SYMBOL_PRINT(Title, Kind, Value, Location) \
+# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
do { \
if (yydebug) \
{ \
YYFPRINTF (stderr, "%s ", Title); \
yy_symbol_print (stderr, \
- Kind, Value, p); \
+ Type, Value, p); \
YYFPRINTF (stderr, "\n"); \
} \
} while (0)
@@ -5544,8 +5198,7 @@ do { \
`-----------------------------------*/
static void
-yy_symbol_value_print (FILE *yyo,
- yysymbol_kind_t yykind, YYSTYPE const * const yyvaluep, parser_state *p)
+yy_symbol_value_print (FILE *yyo, int yytype, YYSTYPE const * const yyvaluep, parser_state *p)
{
FILE *yyoutput = yyo;
YYUSE (yyoutput);
@@ -5553,11 +5206,11 @@ yy_symbol_value_print (FILE *yyo,
if (!yyvaluep)
return;
# ifdef YYPRINT
- if (yykind < YYNTOKENS)
- YYPRINT (yyo, yytoknum[yykind], *yyvaluep);
+ if (yytype < YYNTOKENS)
+ YYPRINT (yyo, yytoknum[yytype], *yyvaluep);
# endif
YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
- YYUSE (yykind);
+ YYUSE (yytype);
YY_IGNORE_MAYBE_UNINITIALIZED_END
}
@@ -5567,13 +5220,12 @@ yy_symbol_value_print (FILE *yyo,
`---------------------------*/
static void
-yy_symbol_print (FILE *yyo,
- yysymbol_kind_t yykind, YYSTYPE const * const yyvaluep, parser_state *p)
+yy_symbol_print (FILE *yyo, int yytype, YYSTYPE const * const yyvaluep, parser_state *p)
{
YYFPRINTF (yyo, "%s %s (",
- yykind < YYNTOKENS ? "token" : "nterm", yysymbol_name (yykind));
+ yytype < YYNTOKENS ? "token" : "nterm", yytname[yytype]);
- yy_symbol_value_print (yyo, yykind, yyvaluep, p);
+ yy_symbol_value_print (yyo, yytype, yyvaluep, p);
YYFPRINTF (yyo, ")");
}
@@ -5606,8 +5258,7 @@ do { \
`------------------------------------------------*/
static void
-yy_reduce_print (yy_state_t *yyssp, YYSTYPE *yyvsp,
- int yyrule, parser_state *p)
+yy_reduce_print (yy_state_t *yyssp, YYSTYPE *yyvsp, int yyrule, parser_state *p)
{
int yylno = yyrline[yyrule];
int yynrhs = yyr2[yyrule];
@@ -5619,8 +5270,9 @@ yy_reduce_print (yy_state_t *yyssp, YYSTYPE *yyvsp,
{
YYFPRINTF (stderr, " $%d = ", yyi + 1);
yy_symbol_print (stderr,
- YY_ACCESSING_SYMBOL (+yyssp[yyi + 1 - yynrhs]),
- &yyvsp[(yyi + 1) - (yynrhs)], p);
+ yystos[+yyssp[yyi + 1 - yynrhs]],
+ &yyvsp[(yyi + 1) - (yynrhs)]
+ , p);
YYFPRINTF (stderr, "\n");
}
}
@@ -5635,8 +5287,8 @@ do { \
multiple parsers can coexist. */
int yydebug;
#else /* !YYDEBUG */
-# define YYDPRINTF(Args) ((void) 0)
-# define YY_SYMBOL_PRINT(Title, Kind, Value, Location)
+# define YYDPRINTF(Args)
+# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
# define YY_STACK_PRINT(Bottom, Top)
# define YY_REDUCE_PRINT(Rule)
#endif /* !YYDEBUG */
@@ -5659,60 +5311,12 @@ int yydebug;
#endif
-/* Context of a parse error. */
-typedef struct
-{
- yy_state_t *yyssp;
- yysymbol_kind_t yytoken;
-} yypcontext_t;
+#if YYERROR_VERBOSE
-/* Put in YYARG at most YYARGN of the expected tokens given the
- current YYCTX, and return the number of tokens stored in YYARG. If
- YYARG is null, return the number of expected tokens (guaranteed to
- be less than YYNTOKENS). Return YYENOMEM on memory exhaustion.
- Return 0 if there are more than YYARGN expected tokens, yet fill
- YYARG up to YYARGN. */
-static int
-yypcontext_expected_tokens (const yypcontext_t *yyctx,
- yysymbol_kind_t yyarg[], int yyargn)
-{
- /* Actual size of YYARG. */
- int yycount = 0;
- int yyn = yypact[+*yyctx->yyssp];
- 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 != YYSYMBOL_YYerror
- && !yytable_value_is_error (yytable[yyx + yyn]))
- {
- if (!yyarg)
- ++yycount;
- else if (yycount == yyargn)
- return 0;
- else
- yyarg[yycount++] = YY_CAST (yysymbol_kind_t, yyx);
- }
- }
- if (yyarg && yycount == 0 && 0 < yyargn)
- yyarg[0] = YYSYMBOL_YYEMPTY;
- return yycount;
-}
-
-
-
-
-#ifndef yystrlen
-# if defined __GLIBC__ && defined _STRING_H
-# define yystrlen(S) (YY_CAST (YYPTRDIFF_T, strlen (S)))
-# else
+# ifndef yystrlen
+# if defined __GLIBC__ && defined _STRING_H
+# define yystrlen(S) (YY_CAST (YYPTRDIFF_T, strlen (S)))
+# else
/* Return the length of YYSTR. */
static YYPTRDIFF_T
yystrlen (const char *yystr)
@@ -5722,13 +5326,13 @@ yystrlen (const char *yystr)
continue;
return yylen;
}
+# endif
# endif
-#endif
-#ifndef yystpcpy
-# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
-# define yystpcpy stpcpy
-# else
+# 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 *
@@ -5742,10 +5346,10 @@ yystpcpy (char *yydest, const char *yysrc)
return yyd - 1;
}
+# endif
# endif
-#endif
-#ifndef yytnamerr
+# 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
@@ -5760,6 +5364,7 @@ yytnamerr (char *yyres, const char *yystr)
{
YYPTRDIFF_T yyn = 0;
char const *yyp = yystr;
+
for (;;)
switch (*++yyp)
{
@@ -5793,15 +5398,31 @@ yytnamerr (char *yyres, const char *yystr)
else
return yystrlen (yystr);
}
-#endif
+# 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
-yy_syntax_error_arguments (const yypcontext_t *yyctx,
- yysymbol_kind_t yyarg[], int yyargn)
+yysyntax_error (YYPTRDIFF_T *yymsg_alloc, char **yymsg,
+ yy_state_t *yyssp, int yytoken)
{
+ enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
+ /* Internationalized format string. */
+ const char *yyformat = YY_NULLPTR;
+ /* Arguments of yyformat: reported tokens (one for the "unexpected",
+ one per "expected"). */
+ char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
/* Actual size of YYARG. */
int yycount = 0;
+ /* Cumulated lengths of YYARG. */
+ YYPTRDIFF_T yysize = 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
@@ -5825,54 +5446,52 @@ yy_syntax_error_arguments (const yypcontext_t *yyctx,
one exception: it will still contain any token that will not be
accepted due to an error action in a later state.
*/
- if (yyctx->yytoken != YYSYMBOL_YYEMPTY)
+ if (yytoken != YYEMPTY)
{
- int yyn;
- if (yyarg)
- yyarg[yycount] = yyctx->yytoken;
- ++yycount;
- yyn = yypcontext_expected_tokens (yyctx,
- yyarg ? yyarg + 1 : yyarg, yyargn - 1);
- if (yyn == YYENOMEM)
- return YYENOMEM;
- else
- yycount += yyn;
+ int yyn = yypact[+*yyssp];
+ YYPTRDIFF_T yysize0 = yytnamerr (YY_NULLPTR, yytname[yytoken]);
+ yysize = yysize0;
+ 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];
+ {
+ YYPTRDIFF_T yysize1
+ = yysize + yytnamerr (YY_NULLPTR, yytname[yyx]);
+ if (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM)
+ yysize = yysize1;
+ else
+ return 2;
+ }
+ }
+ }
}
- return yycount;
-}
-
-/* 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 YYENOMEM if the
- required number of bytes is too large to store. */
-static int
-yysyntax_error (YYPTRDIFF_T *yymsg_alloc, char **yymsg,
- const yypcontext_t *yyctx)
-{
- enum { YYARGS_MAX = 5 };
- /* Internationalized format string. */
- const char *yyformat = YY_NULLPTR;
- /* Arguments of yyformat: reported tokens (one for the "unexpected",
- one per "expected"). */
- yysymbol_kind_t yyarg[YYARGS_MAX];
- /* Cumulated lengths of YYARG. */
- YYPTRDIFF_T yysize = 0;
-
- /* Actual size of YYARG. */
- int yycount = yy_syntax_error_arguments (yyctx, yyarg, YYARGS_MAX);
- if (yycount == YYENOMEM)
- return YYENOMEM;
switch (yycount)
{
-#define YYCASE_(N, S) \
+# define YYCASE_(N, S) \
case N: \
yyformat = S; \
- break
+ break
default: /* Avoid compiler warnings. */
YYCASE_(0, YY_("syntax error"));
YYCASE_(1, YY_("syntax error, unexpected %s"));
@@ -5880,23 +5499,17 @@ yysyntax_error (YYPTRDIFF_T *yymsg_alloc, char **yymsg,
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_
+# undef YYCASE_
}
- /* Compute error message size. Don't count the "%s"s, but reserve
- room for the terminator. */
- yysize = yystrlen (yyformat) - 2 * yycount + 1;
{
- int yyi;
- for (yyi = 0; yyi < yycount; ++yyi)
- {
- YYPTRDIFF_T yysize1
- = yysize + yytnamerr (YY_NULLPTR, yytname[yyarg[yyi]]);
- if (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM)
- yysize = yysize1;
- else
- return YYENOMEM;
- }
+ /* Don't count the "%s"s in the final size, but reserve room for
+ the terminator. */
+ YYPTRDIFF_T yysize1 = yysize + (yystrlen (yyformat) - 2 * yycount) + 1;
+ if (yysize <= yysize1 && yysize1 <= YYSTACK_ALLOC_MAXIMUM)
+ yysize = yysize1;
+ else
+ return 2;
}
if (*yymsg_alloc < yysize)
@@ -5905,7 +5518,7 @@ yysyntax_error (YYPTRDIFF_T *yymsg_alloc, char **yymsg,
if (! (yysize <= *yymsg_alloc
&& *yymsg_alloc <= YYSTACK_ALLOC_MAXIMUM))
*yymsg_alloc = YYSTACK_ALLOC_MAXIMUM;
- return -1;
+ return 1;
}
/* Avoid sprintf, as that infringes on the user's name space.
@@ -5917,7 +5530,7 @@ yysyntax_error (YYPTRDIFF_T *yymsg_alloc, char **yymsg,
while ((*yyp = *yyformat) != '\0')
if (*yyp == '%' && yyformat[1] == 's' && yyi < yycount)
{
- yyp += yytnamerr (yyp, yytname[yyarg[yyi++]]);
+ yyp += yytnamerr (yyp, yyarg[yyi++]);
yyformat += 2;
}
else
@@ -5928,32 +5541,29 @@ yysyntax_error (YYPTRDIFF_T *yymsg_alloc, char **yymsg,
}
return 0;
}
-
+#endif /* YYERROR_VERBOSE */
/*-----------------------------------------------.
| Release the memory associated to this symbol. |
`-----------------------------------------------*/
static void
-yydestruct (const char *yymsg,
- yysymbol_kind_t yykind, YYSTYPE *yyvaluep, parser_state *p)
+yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep, parser_state *p)
{
YYUSE (yyvaluep);
YYUSE (p);
if (!yymsg)
yymsg = "Deleting";
- YY_SYMBOL_PRINT (yymsg, yykind, yyvaluep, yylocationp);
+ YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN
- YYUSE (yykind);
+ YYUSE (yytype);
YY_IGNORE_MAYBE_UNINITIALIZED_END
}
-
-
/*----------.
| yyparse. |
`----------*/
@@ -5961,7 +5571,7 @@ yydestruct (const char *yymsg,
int
yyparse (parser_state *p)
{
-/* Lookahead token kind. */
+/* The lookahead symbol. */
int yychar;
@@ -5972,41 +5582,45 @@ YY_INITIAL_VALUE (static YYSTYPE yyval_default;)
YYSTYPE yylval YY_INITIAL_VALUE (= yyval_default);
/* Number of syntax errors so far. */
- int yynerrs = 0;
+ int yynerrs;
- yy_state_fast_t yystate = 0;
+ yy_state_fast_t yystate;
/* Number of tokens to shift before error messages enabled. */
- int yyerrstatus = 0;
+ int yyerrstatus;
- /* Refer to the stacks through separate pointers, to allow yyoverflow
- to reallocate them elsewhere. */
+ /* The stacks and their tools:
+ 'yyss': related to states.
+ 'yyvs': related to semantic values.
- /* Their size. */
- YYPTRDIFF_T yystacksize = YYINITDEPTH;
+ Refer to the stacks through separate pointers, to allow yyoverflow
+ to reallocate them elsewhere. */
- /* The state stack: array, bottom, top. */
+ /* The state stack. */
yy_state_t yyssa[YYINITDEPTH];
- yy_state_t *yyss = yyssa;
- yy_state_t *yyssp = yyss;
+ yy_state_t *yyss;
+ yy_state_t *yyssp;
- /* The semantic value stack: array, bottom, top. */
+ /* The semantic value stack. */
YYSTYPE yyvsa[YYINITDEPTH];
- YYSTYPE *yyvs = yyvsa;
- YYSTYPE *yyvsp = yyvs;
+ YYSTYPE *yyvs;
+ YYSTYPE *yyvsp;
+
+ YYPTRDIFF_T yystacksize;
int yyn;
- /* The return value of yyparse. */
int yyresult;
- /* Lookahead symbol kind. */
- yysymbol_kind_t yytoken = YYSYMBOL_YYEMPTY;
+ /* 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;
+#if YYERROR_VERBOSE
/* Buffer for error messages, and its allocated size. */
char yymsgbuf[128];
char *yymsg = yymsgbuf;
YYPTRDIFF_T yymsg_alloc = sizeof yymsgbuf;
+#endif
#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N))
@@ -6014,8 +5628,15 @@ YYSTYPE yylval YY_INITIAL_VALUE (= yyval_default);
Keep to zero when no symbol should be popped. */
int yylen = 0;
+ yyssp = yyss = yyssa;
+ yyvsp = yyvs = yyvsa;
+ yystacksize = YYINITDEPTH;
+
YYDPRINTF ((stderr, "Starting parse\n"));
+ yystate = 0;
+ yyerrstatus = 0;
+ yynerrs = 0;
yychar = YYEMPTY; /* Cause a token to be read. */
goto yysetstate;
@@ -6038,7 +5659,6 @@ yysetstate:
YY_IGNORE_USELESS_CAST_BEGIN
*yyssp = YY_CAST (yy_state_t, yystate);
YY_IGNORE_USELESS_CAST_END
- YY_STACK_PRINT (yyss, yyssp);
if (yyss + yystacksize - 1 <= yyssp)
#if !defined yyoverflow && !defined YYSTACK_RELOCATE
@@ -6084,7 +5704,7 @@ yysetstate:
goto yyexhaustedlab;
YYSTACK_RELOCATE (yyss_alloc, yyss);
YYSTACK_RELOCATE (yyvs_alloc, yyvs);
-# undef YYSTACK_RELOCATE
+# undef YYSTACK_RELOCATE
if (yyss1 != yyssa)
YYSTACK_FREE (yyss1);
}
@@ -6123,29 +5743,18 @@ yybackup:
/* Not known => get a lookahead token if don't already have one. */
- /* YYCHAR is either empty, or end-of-input, or a valid lookahead. */
+ /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
if (yychar == YYEMPTY)
{
- YYDPRINTF ((stderr, "Reading a token\n"));
+ YYDPRINTF ((stderr, "Reading a token: "));
yychar = yylex (&yylval, p);
}
if (yychar <= YYEOF)
{
- yychar = YYEOF;
- yytoken = YYSYMBOL_YYEOF;
+ yychar = yytoken = YYEOF;
YYDPRINTF ((stderr, "Now at end of input.\n"));
}
- else if (yychar == YYerror)
- {
- /* The scanner already issued an error message, process directly
- to error recovery. But do not keep the error token as
- lookahead, it is too special and may lead us to an endless
- loop in error recovery. */
- yychar = YYUNDEF;
- yytoken = YYSYMBOL_YYerror;
- goto yyerrlab1;
- }
else
{
yytoken = YYTRANSLATE (yychar);
@@ -6214,75 +5823,75 @@ yyreduce:
YY_REDUCE_PRINT (yyn);
switch (yyn)
{
- case 2: /* $@1: %empty */
+ case 2:
#line 1536 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_BEG;
if (!p->locals) p->locals = cons(0,0);
}
-#line 6224 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5833 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 3: /* program: $@1 top_compstmt */
+ case 3:
#line 1541 "mrbgems/mruby-compiler/core/parse.y"
{
p->tree = new_scope(p, (yyvsp[0].nd));
NODE_LINENO(p->tree, (yyvsp[0].nd));
}
-#line 6233 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5842 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 4: /* top_compstmt: top_stmts opt_terms */
+ case 4:
#line 1548 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 6241 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5850 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 5: /* top_stmts: none */
+ case 5:
#line 1554 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_begin(p, 0);
}
-#line 6249 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5858 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 6: /* top_stmts: top_stmt */
+ case 6:
#line 1558 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_begin(p, (yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 6258 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5867 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 7: /* top_stmts: top_stmts terms top_stmt */
+ case 7:
#line 1563 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), newline_node((yyvsp[0].nd)));
}
-#line 6266 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5875 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 8: /* top_stmts: error top_stmt */
+ case 8:
#line 1567 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_begin(p, 0);
}
-#line 6274 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5883 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 10: /* @2: %empty */
+ case 10:
#line 1574 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = local_switch(p);
nvars_block(p);
}
-#line 6283 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5892 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 11: /* top_stmt: keyword_BEGIN @2 '{' top_compstmt '}' */
+ case 11:
#line 1579 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "BEGIN not supported");
@@ -6290,10 +5899,10 @@ yyreduce:
nvars_unnest(p);
(yyval.nd) = 0;
}
-#line 6294 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5903 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 12: /* bodystmt: compstmt opt_rescue opt_else opt_ensure */
+ case 12:
#line 1591 "mrbgems/mruby-compiler/core/parse.y"
{
if ((yyvsp[-2].nd)) {
@@ -6316,154 +5925,154 @@ yyreduce:
}
}
}
-#line 6320 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5929 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 13: /* compstmt: stmts opt_terms */
+ case 13:
#line 1615 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 6328 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5937 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 14: /* stmts: none */
+ case 14:
#line 1621 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_begin(p, 0);
}
-#line 6336 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5945 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 15: /* stmts: stmt */
+ case 15:
#line 1625 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_begin(p, (yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 6345 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5954 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 16: /* stmts: stmts terms stmt */
+ case 16:
#line 1630 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), newline_node((yyvsp[0].nd)));
}
-#line 6353 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5962 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 17: /* stmts: error stmt */
+ case 17:
#line 1634 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_begin(p, (yyvsp[0].nd));
}
-#line 6361 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5970 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 18: /* $@3: %empty */
+ case 18:
#line 1639 "mrbgems/mruby-compiler/core/parse.y"
{p->lstate = EXPR_FNAME;}
-#line 6367 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5976 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 19: /* stmt: keyword_alias fsym $@3 fsym */
+ case 19:
#line 1640 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_alias(p, (yyvsp[-2].id), (yyvsp[0].id));
}
-#line 6375 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5984 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 20: /* stmt: keyword_undef undef_list */
+ case 20:
#line 1644 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 6383 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 5992 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 21: /* stmt: stmt modifier_if expr_value */
+ case 21:
#line 1648 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_if(p, cond((yyvsp[0].nd)), (yyvsp[-2].nd), 0);
}
-#line 6391 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6000 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 22: /* stmt: stmt modifier_unless expr_value */
+ case 22:
#line 1652 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_unless(p, cond((yyvsp[0].nd)), (yyvsp[-2].nd), 0);
}
-#line 6399 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6008 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 23: /* stmt: stmt modifier_while expr_value */
+ case 23:
#line 1656 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_while(p, cond((yyvsp[0].nd)), (yyvsp[-2].nd));
}
-#line 6407 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6016 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 24: /* stmt: stmt modifier_until expr_value */
+ case 24:
#line 1660 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_until(p, cond((yyvsp[0].nd)), (yyvsp[-2].nd));
}
-#line 6415 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6024 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 25: /* stmt: stmt modifier_rescue stmt */
+ case 25:
#line 1664 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_mod_rescue(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6423 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6032 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 26: /* stmt: keyword_END '{' compstmt '}' */
+ case 26:
#line 1668 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "END not supported");
(yyval.nd) = new_postexe(p, (yyvsp[-1].nd));
}
-#line 6432 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6041 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 28: /* stmt: mlhs '=' command_call */
+ case 28:
#line 1674 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_masgn(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6440 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6049 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 29: /* stmt: lhs '=' mrhs */
+ case 29:
#line 1678 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_asgn(p, (yyvsp[-2].nd), new_array(p, (yyvsp[0].nd)));
}
-#line 6448 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6057 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 30: /* stmt: mlhs '=' arg */
+ case 30:
#line 1682 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_masgn(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6456 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6065 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 31: /* stmt: mlhs '=' mrhs */
+ case 31:
#line 1686 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_masgn(p, (yyvsp[-2].nd), new_array(p, (yyvsp[0].nd)));
}
-#line 6464 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6073 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 32: /* stmt: arg tASSOC tIDENTIFIER */
+ case 32:
#line 1690 "mrbgems/mruby-compiler/core/parse.y"
{
node *lhs = new_lvar(p, (yyvsp[0].id));
@@ -6471,116 +6080,116 @@ yyreduce:
assignable(p, lhs);
(yyval.nd) = new_asgn(p, lhs, (yyvsp[-2].nd));
}
-#line 6475 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6084 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 34: /* command_asgn: lhs '=' command_rhs */
+ case 34:
#line 1700 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_asgn(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6483 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6092 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 35: /* command_asgn: var_lhs tOP_ASGN command_rhs */
+ case 35:
#line 1704 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, (yyvsp[-2].nd), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 6491 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6100 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 36: /* command_asgn: primary_value '[' opt_call_args ']' tOP_ASGN command_rhs */
+ case 36:
#line 1708 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-5].nd), MRB_OPSYM(aref), (yyvsp[-3].nd), '.'), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 6499 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6108 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 37: /* command_asgn: primary_value call_op tIDENTIFIER tOP_ASGN command_rhs */
+ case 37:
#line 1712 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), 0, (yyvsp[-3].num)), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 6507 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6116 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 38: /* command_asgn: primary_value call_op tCONSTANT tOP_ASGN command_rhs */
+ case 38:
#line 1716 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), 0, (yyvsp[-3].num)), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 6515 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6124 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 39: /* command_asgn: primary_value tCOLON2 tCONSTANT tOP_ASGN command_call */
+ case 39:
#line 1720 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "constant re-assignment");
(yyval.nd) = 0;
}
-#line 6524 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6133 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 40: /* command_asgn: primary_value tCOLON2 tIDENTIFIER tOP_ASGN command_rhs */
+ case 40:
#line 1725 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), 0, tCOLON2), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 6532 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6141 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 41: /* command_asgn: backref tOP_ASGN command_rhs */
+ case 41:
#line 1729 "mrbgems/mruby-compiler/core/parse.y"
{
backref_error(p, (yyvsp[-2].nd));
(yyval.nd) = new_begin(p, 0);
}
-#line 6541 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6150 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 43: /* command_rhs: command_call modifier_rescue stmt */
+ case 43:
#line 1737 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_mod_rescue(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6549 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6158 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 46: /* expr: expr keyword_and expr */
+ case 46:
#line 1746 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_and(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6557 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6166 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 47: /* expr: expr keyword_or expr */
+ case 47:
#line 1750 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_or(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6565 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6174 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 48: /* expr: keyword_not opt_nl expr */
+ case 48:
#line 1754 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, cond((yyvsp[0].nd)), "!");
}
-#line 6573 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6182 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 49: /* expr: '!' command_call */
+ case 49:
#line 1758 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, cond((yyvsp[0].nd)), "!");
}
-#line 6581 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6190 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 51: /* defn_head: keyword_def fname */
+ case 51:
#line 1766 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_def(p, (yyvsp[0].id), nint(p->cmdarg_stack), local_switch(p));
@@ -6588,18 +6197,18 @@ yyreduce:
p->in_def++;
nvars_block(p);
}
-#line 6592 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6201 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 52: /* $@4: %empty */
+ case 52:
#line 1775 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_FNAME;
}
-#line 6600 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6209 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 53: /* defs_head: keyword_def singleton dot_or_colon $@4 fname */
+ case 53:
#line 1779 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_sdef(p, (yyvsp[-3].nd), (yyvsp[0].id), nint(p->cmdarg_stack), local_switch(p));
@@ -6609,10 +6218,10 @@ yyreduce:
nvars_block(p);
p->lstate = EXPR_ENDFN; /* force for args */
}
-#line 6613 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6222 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 54: /* expr_value: expr */
+ case 54:
#line 1790 "mrbgems/mruby-compiler/core/parse.y"
{
if (!(yyvsp[0].nd)) (yyval.nd) = new_nil(p);
@@ -6620,1042 +6229,1042 @@ yyreduce:
(yyval.nd) = (yyvsp[0].nd);
}
}
-#line 6624 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6233 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 58: /* block_command: block_call call_op2 operation2 command_args */
+ case 58:
#line 1804 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), (yyvsp[-1].id), (yyvsp[0].nd), (yyvsp[-2].num));
}
-#line 6632 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6241 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 59: /* $@5: %empty */
+ case 59:
#line 1810 "mrbgems/mruby-compiler/core/parse.y"
{
local_nest(p);
nvars_nest(p);
}
-#line 6641 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6250 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 60: /* cmd_brace_block: tLBRACE_ARG $@5 opt_block_param compstmt '}' */
+ case 60:
#line 1817 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_block(p, (yyvsp[-2].nd), (yyvsp[-1].nd));
local_unnest(p);
nvars_unnest(p);
}
-#line 6651 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6260 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 61: /* command: operation command_args */
+ case 61:
#line 1825 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_fcall(p, (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 6659 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6268 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 62: /* command: operation command_args cmd_brace_block */
+ case 62:
#line 1829 "mrbgems/mruby-compiler/core/parse.y"
{
args_with_block(p, (yyvsp[-1].nd), (yyvsp[0].nd));
(yyval.nd) = new_fcall(p, (yyvsp[-2].id), (yyvsp[-1].nd));
}
-#line 6668 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6277 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 63: /* command: primary_value call_op operation2 command_args */
+ case 63:
#line 1834 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), (yyvsp[-1].id), (yyvsp[0].nd), (yyvsp[-2].num));
}
-#line 6676 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6285 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 64: /* command: primary_value call_op operation2 command_args cmd_brace_block */
+ case 64:
#line 1838 "mrbgems/mruby-compiler/core/parse.y"
{
args_with_block(p, (yyvsp[-1].nd), (yyvsp[0].nd));
(yyval.nd) = new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), (yyvsp[-1].nd), (yyvsp[-3].num));
}
-#line 6685 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6294 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 65: /* command: primary_value tCOLON2 operation2 command_args */
+ case 65:
#line 1843 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), (yyvsp[-1].id), (yyvsp[0].nd), tCOLON2);
}
-#line 6693 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6302 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 66: /* command: primary_value tCOLON2 operation2 command_args cmd_brace_block */
+ case 66:
#line 1847 "mrbgems/mruby-compiler/core/parse.y"
{
args_with_block(p, (yyvsp[-1].nd), (yyvsp[0].nd));
(yyval.nd) = new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), (yyvsp[-1].nd), tCOLON2);
}
-#line 6702 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6311 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 67: /* command: keyword_super command_args */
+ case 67:
#line 1852 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_super(p, (yyvsp[0].nd));
}
-#line 6710 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6319 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 68: /* command: keyword_yield command_args */
+ case 68:
#line 1856 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_yield(p, (yyvsp[0].nd));
}
-#line 6718 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6327 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 69: /* command: keyword_return call_args */
+ case 69:
#line 1860 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_return(p, ret_args(p, (yyvsp[0].nd)));
}
-#line 6726 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6335 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 70: /* command: keyword_break call_args */
+ case 70:
#line 1864 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_break(p, ret_args(p, (yyvsp[0].nd)));
}
-#line 6734 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6343 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 71: /* command: keyword_next call_args */
+ case 71:
#line 1868 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_next(p, ret_args(p, (yyvsp[0].nd)));
}
-#line 6742 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6351 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 72: /* mlhs: mlhs_basic */
+ case 72:
#line 1874 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 6750 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6359 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 73: /* mlhs: tLPAREN mlhs_inner rparen */
+ case 73:
#line 1878 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 6758 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6367 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 75: /* mlhs_inner: tLPAREN mlhs_inner rparen */
+ case 75:
#line 1885 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 6766 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6375 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 76: /* mlhs_basic: mlhs_list */
+ case 76:
#line 1891 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 6774 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6383 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 77: /* mlhs_basic: mlhs_list mlhs_item */
+ case 77:
#line 1895 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1(push((yyvsp[-1].nd),(yyvsp[0].nd)));
}
-#line 6782 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6391 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 78: /* mlhs_basic: mlhs_list tSTAR mlhs_node */
+ case 78:
#line 1899 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list2((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6790 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6399 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 79: /* mlhs_basic: mlhs_list tSTAR mlhs_node ',' mlhs_post */
+ case 79:
#line 1903 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3((yyvsp[-4].nd), (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6798 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6407 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 80: /* mlhs_basic: mlhs_list tSTAR */
+ case 80:
#line 1907 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list2((yyvsp[-1].nd), new_nil(p));
}
-#line 6806 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6415 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 81: /* mlhs_basic: mlhs_list tSTAR ',' mlhs_post */
+ case 81:
#line 1911 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3((yyvsp[-3].nd), new_nil(p), (yyvsp[0].nd));
}
-#line 6814 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6423 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 82: /* mlhs_basic: tSTAR mlhs_node */
+ case 82:
#line 1915 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list2(0, (yyvsp[0].nd));
}
-#line 6822 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6431 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 83: /* mlhs_basic: tSTAR mlhs_node ',' mlhs_post */
+ case 83:
#line 1919 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3(0, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 6830 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6439 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 84: /* mlhs_basic: tSTAR */
+ case 84:
#line 1923 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list2(0, new_nil(p));
}
-#line 6838 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6447 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 85: /* mlhs_basic: tSTAR ',' mlhs_post */
+ case 85:
#line 1927 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3(0, new_nil(p), (yyvsp[0].nd));
}
-#line 6846 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6455 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 87: /* mlhs_item: tLPAREN mlhs_inner rparen */
+ case 87:
#line 1934 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_masgn(p, (yyvsp[-1].nd), NULL);
}
-#line 6854 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6463 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 88: /* mlhs_list: mlhs_item ',' */
+ case 88:
#line 1940 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[-1].nd));
}
-#line 6862 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6471 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 89: /* mlhs_list: mlhs_list mlhs_item ',' */
+ case 89:
#line 1944 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[-1].nd));
}
-#line 6870 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6479 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 90: /* mlhs_post: mlhs_item */
+ case 90:
#line 1950 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 6878 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6487 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 91: /* mlhs_post: mlhs_list mlhs_item */
+ case 91:
#line 1954 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 6886 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6495 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 92: /* mlhs_node: variable */
+ case 92:
#line 1960 "mrbgems/mruby-compiler/core/parse.y"
{
assignable(p, (yyvsp[0].nd));
}
-#line 6894 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6503 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 93: /* mlhs_node: primary_value '[' opt_call_args ']' */
+ case 93:
#line 1964 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), MRB_OPSYM(aref), (yyvsp[-1].nd), '.');
}
-#line 6902 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6511 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 94: /* mlhs_node: primary_value call_op tIDENTIFIER */
+ case 94:
#line 1968 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, (yyvsp[-1].num));
}
-#line 6910 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6519 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 95: /* mlhs_node: primary_value tCOLON2 tIDENTIFIER */
+ case 95:
#line 1972 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, tCOLON2);
}
-#line 6918 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6527 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 96: /* mlhs_node: primary_value call_op tCONSTANT */
+ case 96:
#line 1976 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, (yyvsp[-1].num));
}
-#line 6926 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6535 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 97: /* mlhs_node: primary_value tCOLON2 tCONSTANT */
+ case 97:
#line 1980 "mrbgems/mruby-compiler/core/parse.y"
{
if (p->in_def || p->in_single)
yyerror(p, "dynamic constant assignment");
(yyval.nd) = new_colon2(p, (yyvsp[-2].nd), (yyvsp[0].id));
}
-#line 6936 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6545 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 98: /* mlhs_node: tCOLON3 tCONSTANT */
+ case 98:
#line 1986 "mrbgems/mruby-compiler/core/parse.y"
{
if (p->in_def || p->in_single)
yyerror(p, "dynamic constant assignment");
(yyval.nd) = new_colon3(p, (yyvsp[0].id));
}
-#line 6946 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6555 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 99: /* mlhs_node: backref */
+ case 99:
#line 1992 "mrbgems/mruby-compiler/core/parse.y"
{
backref_error(p, (yyvsp[0].nd));
(yyval.nd) = 0;
}
-#line 6955 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6564 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 100: /* lhs: variable */
+ case 100:
#line 1999 "mrbgems/mruby-compiler/core/parse.y"
{
assignable(p, (yyvsp[0].nd));
}
-#line 6963 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6572 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 101: /* lhs: primary_value '[' opt_call_args ']' */
+ case 101:
#line 2003 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), MRB_OPSYM(aref), (yyvsp[-1].nd), '.');
}
-#line 6971 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6580 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 102: /* lhs: primary_value call_op tIDENTIFIER */
+ case 102:
#line 2007 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, (yyvsp[-1].num));
}
-#line 6979 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6588 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 103: /* lhs: primary_value tCOLON2 tIDENTIFIER */
+ case 103:
#line 2011 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, tCOLON2);
}
-#line 6987 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6596 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 104: /* lhs: primary_value call_op tCONSTANT */
+ case 104:
#line 2015 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, (yyvsp[-1].num));
}
-#line 6995 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6604 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 105: /* lhs: primary_value tCOLON2 tCONSTANT */
+ case 105:
#line 2019 "mrbgems/mruby-compiler/core/parse.y"
{
if (p->in_def || p->in_single)
yyerror(p, "dynamic constant assignment");
(yyval.nd) = new_colon2(p, (yyvsp[-2].nd), (yyvsp[0].id));
}
-#line 7005 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6614 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 106: /* lhs: tCOLON3 tCONSTANT */
+ case 106:
#line 2025 "mrbgems/mruby-compiler/core/parse.y"
{
if (p->in_def || p->in_single)
yyerror(p, "dynamic constant assignment");
(yyval.nd) = new_colon3(p, (yyvsp[0].id));
}
-#line 7015 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6624 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 107: /* lhs: backref */
+ case 107:
#line 2031 "mrbgems/mruby-compiler/core/parse.y"
{
backref_error(p, (yyvsp[0].nd));
(yyval.nd) = 0;
}
-#line 7024 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6633 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 108: /* lhs: tNUMPARAM */
+ case 108:
#line 2036 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "can't assign to numbered parameter");
}
-#line 7032 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6641 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 109: /* cname: tIDENTIFIER */
+ case 109:
#line 2042 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "class/module name must be CONSTANT");
}
-#line 7040 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6649 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 111: /* cpath: tCOLON3 cname */
+ case 111:
#line 2049 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons((node*)1, nsym((yyvsp[0].id)));
}
-#line 7048 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6657 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 112: /* cpath: cname */
+ case 112:
#line 2053 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons((node*)0, nsym((yyvsp[0].id)));
}
-#line 7056 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6665 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 113: /* cpath: primary_value tCOLON2 cname */
+ case 113:
#line 2057 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[-2].nd));
(yyval.nd) = cons((yyvsp[-2].nd), nsym((yyvsp[0].id)));
}
-#line 7065 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6674 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 117: /* fname: op */
+ case 117:
#line 2067 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_ENDFN;
(yyval.id) = (yyvsp[0].id);
}
-#line 7074 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6683 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 118: /* fname: reswords */
+ case 118:
#line 2072 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_ENDFN;
(yyval.id) = (yyvsp[0].id);
}
-#line 7083 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6692 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 121: /* undef_list: fsym */
+ case 121:
#line 2083 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_undef(p, (yyvsp[0].id));
}
-#line 7091 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6700 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 122: /* $@6: %empty */
+ case 122:
#line 2086 "mrbgems/mruby-compiler/core/parse.y"
{p->lstate = EXPR_FNAME;}
-#line 7097 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6706 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 123: /* undef_list: undef_list ',' $@6 fsym */
+ case 123:
#line 2087 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-3].nd), nsym((yyvsp[0].id)));
}
-#line 7105 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6714 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 124: /* op: '|' */
+ case 124:
#line 2092 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(or); }
-#line 7111 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6720 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 125: /* op: '^' */
+ case 125:
#line 2093 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(xor); }
-#line 7117 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6726 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 126: /* op: '&' */
+ case 126:
#line 2094 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(and); }
-#line 7123 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6732 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 127: /* op: tCMP */
+ case 127:
#line 2095 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(cmp); }
-#line 7129 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6738 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 128: /* op: tEQ */
+ case 128:
#line 2096 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(eq); }
-#line 7135 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6744 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 129: /* op: tEQQ */
+ case 129:
#line 2097 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(eqq); }
-#line 7141 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6750 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 130: /* op: tMATCH */
+ case 130:
#line 2098 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(match); }
-#line 7147 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6756 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 131: /* op: tNMATCH */
+ case 131:
#line 2099 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(nmatch); }
-#line 7153 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6762 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 132: /* op: '>' */
+ case 132:
#line 2100 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(gt); }
-#line 7159 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6768 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 133: /* op: tGEQ */
+ case 133:
#line 2101 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(ge); }
-#line 7165 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6774 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 134: /* op: '<' */
+ case 134:
#line 2102 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(lt); }
-#line 7171 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6780 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 135: /* op: tLEQ */
+ case 135:
#line 2103 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(le); }
-#line 7177 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6786 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 136: /* op: tNEQ */
+ case 136:
#line 2104 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(neq); }
-#line 7183 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6792 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 137: /* op: tLSHFT */
+ case 137:
#line 2105 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(lshift); }
-#line 7189 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6798 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 138: /* op: tRSHFT */
+ case 138:
#line 2106 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(rshift); }
-#line 7195 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6804 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 139: /* op: '+' */
+ case 139:
#line 2107 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(add); }
-#line 7201 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6810 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 140: /* op: '-' */
+ case 140:
#line 2108 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(sub); }
-#line 7207 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6816 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 141: /* op: '*' */
+ case 141:
#line 2109 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(mul); }
-#line 7213 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6822 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 142: /* op: tSTAR */
+ case 142:
#line 2110 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(mul); }
-#line 7219 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6828 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 143: /* op: '/' */
+ case 143:
#line 2111 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(div); }
-#line 7225 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6834 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 144: /* op: '%' */
+ case 144:
#line 2112 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(mod); }
-#line 7231 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6840 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 145: /* op: tPOW */
+ case 145:
#line 2113 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(pow); }
-#line 7237 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6846 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 146: /* op: tDSTAR */
+ case 146:
#line 2114 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(pow); }
-#line 7243 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6852 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 147: /* op: '!' */
+ case 147:
#line 2115 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(not); }
-#line 7249 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6858 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 148: /* op: '~' */
+ case 148:
#line 2116 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(neg); }
-#line 7255 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6864 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 149: /* op: tUPLUS */
+ case 149:
#line 2117 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(plus); }
-#line 7261 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6870 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 150: /* op: tUMINUS */
+ case 150:
#line 2118 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(minus); }
-#line 7267 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6876 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 151: /* op: tAREF */
+ case 151:
#line 2119 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(aref); }
-#line 7273 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6882 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 152: /* op: tASET */
+ case 152:
#line 2120 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(aset); }
-#line 7279 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6888 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 153: /* op: '`' */
+ case 153:
#line 2121 "mrbgems/mruby-compiler/core/parse.y"
{ (yyval.id) = MRB_OPSYM(tick); }
-#line 7285 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6894 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 194: /* arg: lhs '=' arg_rhs */
+ case 194:
#line 2139 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_asgn(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7293 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6902 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 195: /* arg: var_lhs tOP_ASGN arg_rhs */
+ case 195:
#line 2143 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, (yyvsp[-2].nd), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 7301 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6910 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 196: /* arg: primary_value '[' opt_call_args ']' tOP_ASGN arg_rhs */
+ case 196:
#line 2147 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-5].nd), MRB_OPSYM(aref), (yyvsp[-3].nd), '.'), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 7309 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6918 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 197: /* arg: primary_value call_op tIDENTIFIER tOP_ASGN arg_rhs */
+ case 197:
#line 2151 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), 0, (yyvsp[-3].num)), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 7317 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6926 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 198: /* arg: primary_value call_op tCONSTANT tOP_ASGN arg_rhs */
+ case 198:
#line 2155 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), 0, (yyvsp[-3].num)), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 7325 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6934 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 199: /* arg: primary_value tCOLON2 tIDENTIFIER tOP_ASGN arg_rhs */
+ case 199:
#line 2159 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_op_asgn(p, new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), 0, tCOLON2), (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 7333 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6942 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 200: /* arg: primary_value tCOLON2 tCONSTANT tOP_ASGN arg_rhs */
+ case 200:
#line 2163 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "constant re-assignment");
(yyval.nd) = new_begin(p, 0);
}
-#line 7342 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6951 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 201: /* arg: tCOLON3 tCONSTANT tOP_ASGN arg_rhs */
+ case 201:
#line 2168 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "constant re-assignment");
(yyval.nd) = new_begin(p, 0);
}
-#line 7351 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6960 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 202: /* arg: backref tOP_ASGN arg_rhs */
+ case 202:
#line 2173 "mrbgems/mruby-compiler/core/parse.y"
{
backref_error(p, (yyvsp[-2].nd));
(yyval.nd) = new_begin(p, 0);
}
-#line 7360 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6969 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 203: /* arg: arg tDOT2 arg */
+ case 203:
#line 2178 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dot2(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7368 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6977 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 204: /* arg: arg tDOT2 */
+ case 204:
#line 2182 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dot2(p, (yyvsp[-1].nd), new_nil(p));
}
-#line 7376 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6985 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 205: /* arg: tBDOT2 arg */
+ case 205:
#line 2186 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dot2(p, new_nil(p), (yyvsp[0].nd));
}
-#line 7384 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 6993 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 206: /* arg: arg tDOT3 arg */
+ case 206:
#line 2190 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dot3(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7392 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7001 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 207: /* arg: arg tDOT3 */
+ case 207:
#line 2194 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dot3(p, (yyvsp[-1].nd), new_nil(p));
}
-#line 7400 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7009 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 208: /* arg: tBDOT3 arg */
+ case 208:
#line 2198 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dot3(p, new_nil(p), (yyvsp[0].nd));
}
-#line 7408 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7017 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 209: /* arg: arg '+' arg */
+ case 209:
#line 2202 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "+", (yyvsp[0].nd));
}
-#line 7416 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7025 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 210: /* arg: arg '-' arg */
+ case 210:
#line 2206 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "-", (yyvsp[0].nd));
}
-#line 7424 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7033 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 211: /* arg: arg '*' arg */
+ case 211:
#line 2210 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "*", (yyvsp[0].nd));
}
-#line 7432 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7041 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 212: /* arg: arg '/' arg */
+ case 212:
#line 2214 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "/", (yyvsp[0].nd));
}
-#line 7440 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7049 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 213: /* arg: arg '%' arg */
+ case 213:
#line 2218 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "%", (yyvsp[0].nd));
}
-#line 7448 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7057 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 214: /* arg: arg tPOW arg */
+ case 214:
#line 2222 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd));
}
-#line 7456 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7065 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 215: /* arg: tUMINUS_NUM tINTEGER tPOW arg */
+ case 215:
#line 2226 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd)), "-@");
}
-#line 7464 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7073 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 216: /* arg: tUMINUS_NUM tFLOAT tPOW arg */
+ case 216:
#line 2230 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, call_bin_op(p, (yyvsp[-2].nd), "**", (yyvsp[0].nd)), "-@");
}
-#line 7472 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7081 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 217: /* arg: tUPLUS arg */
+ case 217:
#line 2234 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, (yyvsp[0].nd), "+@");
}
-#line 7480 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7089 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 218: /* arg: tUMINUS arg */
+ case 218:
#line 2238 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, (yyvsp[0].nd), "-@");
}
-#line 7488 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7097 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 219: /* arg: arg '|' arg */
+ case 219:
#line 2242 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "|", (yyvsp[0].nd));
}
-#line 7496 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7105 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 220: /* arg: arg '^' arg */
+ case 220:
#line 2246 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "^", (yyvsp[0].nd));
}
-#line 7504 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7113 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 221: /* arg: arg '&' arg */
+ case 221:
#line 2250 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "&", (yyvsp[0].nd));
}
-#line 7512 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7121 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 222: /* arg: arg tCMP arg */
+ case 222:
#line 2254 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "<=>", (yyvsp[0].nd));
}
-#line 7520 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7129 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 223: /* arg: arg '>' arg */
+ case 223:
#line 2258 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), ">", (yyvsp[0].nd));
}
-#line 7528 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7137 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 224: /* arg: arg tGEQ arg */
+ case 224:
#line 2262 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), ">=", (yyvsp[0].nd));
}
-#line 7536 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7145 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 225: /* arg: arg '<' arg */
+ case 225:
#line 2266 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "<", (yyvsp[0].nd));
}
-#line 7544 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7153 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 226: /* arg: arg tLEQ arg */
+ case 226:
#line 2270 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "<=", (yyvsp[0].nd));
}
-#line 7552 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7161 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 227: /* arg: arg tEQ arg */
+ case 227:
#line 2274 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "==", (yyvsp[0].nd));
}
-#line 7560 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7169 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 228: /* arg: arg tEQQ arg */
+ case 228:
#line 2278 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "===", (yyvsp[0].nd));
}
-#line 7568 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7177 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 229: /* arg: arg tNEQ arg */
+ case 229:
#line 2282 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "!=", (yyvsp[0].nd));
}
-#line 7576 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7185 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 230: /* arg: arg tMATCH arg */
+ case 230:
#line 2286 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "=~", (yyvsp[0].nd));
}
-#line 7584 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7193 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 231: /* arg: arg tNMATCH arg */
+ case 231:
#line 2290 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "!~", (yyvsp[0].nd));
}
-#line 7592 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7201 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 232: /* arg: '!' arg */
+ case 232:
#line 2294 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, cond((yyvsp[0].nd)), "!");
}
-#line 7600 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7209 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 233: /* arg: '~' arg */
+ case 233:
#line 2298 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, cond((yyvsp[0].nd)), "~");
}
-#line 7608 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7217 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 234: /* arg: arg tLSHFT arg */
+ case 234:
#line 2302 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), "<<", (yyvsp[0].nd));
}
-#line 7616 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7225 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 235: /* arg: arg tRSHFT arg */
+ case 235:
#line 2306 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_bin_op(p, (yyvsp[-2].nd), ">>", (yyvsp[0].nd));
}
-#line 7624 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7233 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 236: /* arg: arg tANDOP arg */
+ case 236:
#line 2310 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_and(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7632 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7241 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 237: /* arg: arg tOROP arg */
+ case 237:
#line 2314 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_or(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7640 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7249 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 238: /* arg: arg '?' arg opt_nl ':' arg */
+ case 238:
#line 2318 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_if(p, cond((yyvsp[-5].nd)), (yyvsp[-3].nd), (yyvsp[0].nd));
}
-#line 7648 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7257 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 239: /* arg: arg '?' arg opt_nl tLABEL_TAG arg */
+ case 239:
#line 2322 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_if(p, cond((yyvsp[-5].nd)), (yyvsp[-3].nd), (yyvsp[0].nd));
}
-#line 7656 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7265 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 240: /* arg: defn_head f_arglist_paren '=' arg */
+ case 240:
#line 2326 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-3].nd);
@@ -7664,10 +7273,10 @@ yyreduce:
nvars_unnest(p);
p->in_def--;
}
-#line 7668 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7277 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 241: /* arg: defn_head f_arglist_paren '=' arg modifier_rescue arg */
+ case 241:
#line 2334 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-5].nd);
@@ -7677,10 +7286,10 @@ yyreduce:
nvars_unnest(p);
p->in_def--;
}
-#line 7681 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7290 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 242: /* arg: defs_head f_arglist_paren '=' arg */
+ case 242:
#line 2343 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-3].nd);
@@ -7690,10 +7299,10 @@ yyreduce:
p->in_def--;
p->in_single--;
}
-#line 7694 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7303 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 243: /* arg: defs_head f_arglist_paren '=' arg modifier_rescue arg */
+ case 243:
#line 2352 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-5].nd);
@@ -7704,70 +7313,70 @@ yyreduce:
p->in_def--;
p->in_single--;
}
-#line 7708 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7317 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 244: /* arg: primary */
+ case 244:
#line 2362 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 7716 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7325 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 246: /* aref_args: args trailer */
+ case 246:
#line 2369 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 7725 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7334 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 247: /* aref_args: args comma assocs trailer */
+ case 247:
#line 2374 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-3].nd), new_kw_hash(p, (yyvsp[-1].nd)));
}
-#line 7733 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7342 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 248: /* aref_args: assocs trailer */
+ case 248:
#line 2378 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(new_kw_hash(p, (yyvsp[-1].nd)), 0);
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 7742 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7351 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 249: /* arg_rhs: arg */
+ case 249:
#line 2385 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 7750 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7359 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 250: /* arg_rhs: arg modifier_rescue arg */
+ case 250:
#line 2389 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[-2].nd));
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = new_mod_rescue(p, (yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7760 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7369 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 251: /* paren_args: '(' opt_call_args ')' */
+ case 251:
#line 2397 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 7768 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7377 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 252: /* paren_args: '(' tDOT3 rparen */
+ case 252:
#line 2401 "mrbgems/mruby-compiler/core/parse.y"
{
#if 1
@@ -7792,372 +7401,372 @@ yyreduce:
(yyval.nd) = 0;
}
}
-#line 7796 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7405 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 257: /* opt_call_args: args comma */
+ case 257:
#line 2433 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons((yyvsp[-1].nd),0);
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 7805 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7414 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 258: /* opt_call_args: args comma assocs comma */
+ case 258:
#line 2438 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(push((yyvsp[-3].nd), new_kw_hash(p, (yyvsp[-1].nd))), 0);
NODE_LINENO((yyval.nd), (yyvsp[-3].nd));
}
-#line 7814 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7423 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 259: /* opt_call_args: assocs comma */
+ case 259:
#line 2443 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(list1(new_kw_hash(p, (yyvsp[-1].nd))), 0);
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 7823 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7432 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 260: /* call_args: command */
+ case 260:
#line 2450 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons(list1((yyvsp[0].nd)), 0);
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 7833 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7442 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 261: /* call_args: args opt_block_arg */
+ case 261:
#line 2456 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons((yyvsp[-1].nd), (yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 7842 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7451 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 262: /* call_args: assocs opt_block_arg */
+ case 262:
#line 2461 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(list1(new_kw_hash(p, (yyvsp[-1].nd))), (yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 7851 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7460 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 263: /* call_args: args comma assocs opt_block_arg */
+ case 263:
#line 2466 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(push((yyvsp[-3].nd), new_kw_hash(p, (yyvsp[-1].nd))), (yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[-3].nd));
}
-#line 7860 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7469 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 264: /* call_args: block_arg */
+ case 264:
#line 2471 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(0, (yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 7869 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7478 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 265: /* @7: %empty */
+ case 265:
#line 2477 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.stack) = p->cmdarg_stack;
CMDARG_PUSH(1);
}
-#line 7878 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7487 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 266: /* command_args: @7 call_args */
+ case 266:
#line 2482 "mrbgems/mruby-compiler/core/parse.y"
{
p->cmdarg_stack = (yyvsp[-1].stack);
(yyval.nd) = (yyvsp[0].nd);
}
-#line 7887 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7496 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 267: /* block_arg: tAMPER arg */
+ case 267:
#line 2489 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_block_arg(p, (yyvsp[0].nd));
}
-#line 7895 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7504 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 268: /* opt_block_arg: comma block_arg */
+ case 268:
#line 2495 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 7903 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7512 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 269: /* opt_block_arg: none */
+ case 269:
#line 2499 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = 0;
}
-#line 7911 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7520 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 272: /* args: arg */
+ case 272:
#line 2509 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons((yyvsp[0].nd), 0);
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 7921 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7530 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 273: /* args: tSTAR arg */
+ case 273:
#line 2515 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons(new_splat(p, (yyvsp[0].nd)), 0);
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 7931 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7540 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 274: /* args: args comma arg */
+ case 274:
#line 2521 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7940 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7549 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 275: /* args: args comma tSTAR arg */
+ case 275:
#line 2526 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = push((yyvsp[-3].nd), new_splat(p, (yyvsp[0].nd)));
}
-#line 7949 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7558 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 276: /* mrhs: args comma arg */
+ case 276:
#line 2533 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 7958 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7567 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 277: /* mrhs: args comma tSTAR arg */
+ case 277:
#line 2538 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = push((yyvsp[-3].nd), new_splat(p, (yyvsp[0].nd)));
}
-#line 7967 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7576 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 278: /* mrhs: tSTAR arg */
+ case 278:
#line 2543 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = list1(new_splat(p, (yyvsp[0].nd)));
}
-#line 7976 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7585 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 286: /* primary: tNUMPARAM */
+ case 286:
#line 2557 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_nvar(p, (yyvsp[0].num));
}
-#line 7984 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7593 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 287: /* primary: tFID */
+ case 287:
#line 2561 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_fcall(p, (yyvsp[0].id), 0);
}
-#line 7992 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7601 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 288: /* @8: %empty */
+ case 288:
#line 2565 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.stack) = p->cmdarg_stack;
p->cmdarg_stack = 0;
}
-#line 8001 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7610 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 289: /* primary: keyword_begin @8 bodystmt keyword_end */
+ case 289:
#line 2571 "mrbgems/mruby-compiler/core/parse.y"
{
p->cmdarg_stack = (yyvsp[-2].stack);
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 8010 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7619 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 290: /* @9: %empty */
+ case 290:
#line 2576 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.stack) = p->cmdarg_stack;
p->cmdarg_stack = 0;
}
-#line 8019 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7628 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 291: /* $@10: %empty */
+ case 291:
#line 2580 "mrbgems/mruby-compiler/core/parse.y"
{p->lstate = EXPR_ENDARG;}
-#line 8025 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7634 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 292: /* primary: tLPAREN_ARG @9 stmt $@10 rparen */
+ case 292:
#line 2581 "mrbgems/mruby-compiler/core/parse.y"
{
p->cmdarg_stack = (yyvsp[-3].stack);
(yyval.nd) = (yyvsp[-2].nd);
}
-#line 8034 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7643 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 293: /* $@11: %empty */
+ case 293:
#line 2585 "mrbgems/mruby-compiler/core/parse.y"
{p->lstate = EXPR_ENDARG;}
-#line 8040 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7649 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 294: /* primary: tLPAREN_ARG $@11 rparen */
+ case 294:
#line 2586 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_nil(p);
}
-#line 8048 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7657 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 295: /* primary: tLPAREN compstmt ')' */
+ case 295:
#line 2590 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 8056 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7665 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 296: /* primary: primary_value tCOLON2 tCONSTANT */
+ case 296:
#line 2594 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_colon2(p, (yyvsp[-2].nd), (yyvsp[0].id));
}
-#line 8064 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7673 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 297: /* primary: tCOLON3 tCONSTANT */
+ case 297:
#line 2598 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_colon3(p, (yyvsp[0].id));
}
-#line 8072 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7681 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 298: /* primary: tLBRACK aref_args ']' */
+ case 298:
#line 2602 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_array(p, (yyvsp[-1].nd));
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 8081 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7690 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 299: /* primary: tLBRACE assoc_list '}' */
+ case 299:
#line 2607 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_hash(p, (yyvsp[-1].nd));
NODE_LINENO((yyval.nd), (yyvsp[-1].nd));
}
-#line 8090 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7699 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 300: /* primary: keyword_return */
+ case 300:
#line 2612 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_return(p, 0);
}
-#line 8098 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7707 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 301: /* primary: keyword_yield opt_paren_args */
+ case 301:
#line 2616 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_yield(p, (yyvsp[0].nd));
}
-#line 8106 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7715 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 302: /* primary: keyword_not '(' expr rparen */
+ case 302:
#line 2620 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, cond((yyvsp[-1].nd)), "!");
}
-#line 8114 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7723 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 303: /* primary: keyword_not '(' rparen */
+ case 303:
#line 2624 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = call_uni_op(p, new_nil(p), "!");
}
-#line 8122 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7731 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 304: /* primary: operation brace_block */
+ case 304:
#line 2628 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_fcall(p, (yyvsp[-1].id), cons(0, (yyvsp[0].nd)));
}
-#line 8130 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7739 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 306: /* primary: method_call brace_block */
+ case 306:
#line 2633 "mrbgems/mruby-compiler/core/parse.y"
{
call_with_block(p, (yyvsp[-1].nd), (yyvsp[0].nd));
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 8139 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7748 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 307: /* @12: %empty */
+ case 307:
#line 2638 "mrbgems/mruby-compiler/core/parse.y"
{
local_nest(p);
(yyval.num) = p->lpar_beg;
p->lpar_beg = ++p->paren_nest;
}
-#line 8149 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7758 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 308: /* @13: %empty */
+ case 308:
#line 2644 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.stack) = p->cmdarg_stack;
p->cmdarg_stack = 0;
}
-#line 8158 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7767 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 309: /* primary: tLAMBDA @12 f_larglist @13 lambda_body */
+ case 309:
#line 2649 "mrbgems/mruby-compiler/core/parse.y"
{
p->lpar_beg = (yyvsp[-3].num);
@@ -8166,107 +7775,107 @@ yyreduce:
p->cmdarg_stack = (yyvsp[-1].stack);
CMDARG_LEXPOP();
}
-#line 8170 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7779 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 310: /* primary: keyword_if expr_value then compstmt if_tail keyword_end */
+ case 310:
#line 2660 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_if(p, cond((yyvsp[-4].nd)), (yyvsp[-2].nd), (yyvsp[-1].nd));
SET_LINENO((yyval.nd), (yyvsp[-5].num));
}
-#line 8179 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7788 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 311: /* primary: keyword_unless expr_value then compstmt opt_else keyword_end */
+ case 311:
#line 2668 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_unless(p, cond((yyvsp[-4].nd)), (yyvsp[-2].nd), (yyvsp[-1].nd));
SET_LINENO((yyval.nd), (yyvsp[-5].num));
}
-#line 8188 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7797 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 312: /* $@14: %empty */
+ case 312:
#line 2672 "mrbgems/mruby-compiler/core/parse.y"
{COND_PUSH(1);}
-#line 8194 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7803 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 313: /* $@15: %empty */
+ case 313:
#line 2672 "mrbgems/mruby-compiler/core/parse.y"
{COND_POP();}
-#line 8200 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7809 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 314: /* primary: keyword_while $@14 expr_value do $@15 compstmt keyword_end */
+ case 314:
#line 2675 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_while(p, cond((yyvsp[-4].nd)), (yyvsp[-1].nd));
SET_LINENO((yyval.nd), (yyvsp[-6].num));
}
-#line 8209 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7818 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 315: /* $@16: %empty */
+ case 315:
#line 2679 "mrbgems/mruby-compiler/core/parse.y"
{COND_PUSH(1);}
-#line 8215 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7824 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 316: /* $@17: %empty */
+ case 316:
#line 2679 "mrbgems/mruby-compiler/core/parse.y"
{COND_POP();}
-#line 8221 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7830 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 317: /* primary: keyword_until $@16 expr_value do $@17 compstmt keyword_end */
+ case 317:
#line 2682 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_until(p, cond((yyvsp[-4].nd)), (yyvsp[-1].nd));
SET_LINENO((yyval.nd), (yyvsp[-6].num));
}
-#line 8230 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7839 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 318: /* primary: keyword_case expr_value opt_terms case_body keyword_end */
+ case 318:
#line 2689 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_case(p, (yyvsp[-3].nd), (yyvsp[-1].nd));
}
-#line 8238 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7847 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 319: /* primary: keyword_case opt_terms case_body keyword_end */
+ case 319:
#line 2693 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_case(p, 0, (yyvsp[-1].nd));
}
-#line 8246 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7855 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 320: /* $@18: %empty */
+ case 320:
#line 2697 "mrbgems/mruby-compiler/core/parse.y"
{COND_PUSH(1);}
-#line 8252 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7861 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 321: /* $@19: %empty */
+ case 321:
#line 2699 "mrbgems/mruby-compiler/core/parse.y"
{COND_POP();}
-#line 8258 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7867 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 322: /* primary: keyword_for for_var keyword_in $@18 expr_value do $@19 compstmt keyword_end */
+ case 322:
#line 2702 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_for(p, (yyvsp[-7].nd), (yyvsp[-4].nd), (yyvsp[-1].nd));
SET_LINENO((yyval.nd), (yyvsp[-8].num));
}
-#line 8267 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7876 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 323: /* @20: %empty */
+ case 323:
#line 2708 "mrbgems/mruby-compiler/core/parse.y"
{
if (p->in_def || p->in_single)
@@ -8274,10 +7883,10 @@ yyreduce:
(yyval.nd) = local_switch(p);
nvars_block(p);
}
-#line 8278 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7887 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 324: /* primary: keyword_class cpath superclass @20 bodystmt keyword_end */
+ case 324:
#line 2716 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_class(p, (yyvsp[-4].nd), (yyvsp[-3].nd), (yyvsp[-1].nd));
@@ -8285,29 +7894,29 @@ yyreduce:
local_resume(p, (yyvsp[-2].nd));
nvars_unnest(p);
}
-#line 8289 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7898 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 325: /* @21: %empty */
+ case 325:
#line 2724 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.num) = p->in_def;
p->in_def = 0;
}
-#line 8298 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7907 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 326: /* @22: %empty */
+ case 326:
#line 2729 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(local_switch(p), nint(p->in_single));
nvars_block(p);
p->in_single = 0;
}
-#line 8308 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7917 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 327: /* primary: keyword_class tLSHFT expr @21 term @22 bodystmt keyword_end */
+ case 327:
#line 2736 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_sclass(p, (yyvsp[-5].nd), (yyvsp[-1].nd));
@@ -8317,10 +7926,10 @@ yyreduce:
p->in_def = (yyvsp[-4].num);
p->in_single = intn((yyvsp[-2].nd)->cdr);
}
-#line 8321 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7930 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 328: /* @23: %empty */
+ case 328:
#line 2746 "mrbgems/mruby-compiler/core/parse.y"
{
if (p->in_def || p->in_single)
@@ -8328,10 +7937,10 @@ yyreduce:
(yyval.nd) = local_switch(p);
nvars_block(p);
}
-#line 8332 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7941 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 329: /* primary: keyword_module cpath @23 bodystmt keyword_end */
+ case 329:
#line 2754 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_module(p, (yyvsp[-3].nd), (yyvsp[-1].nd));
@@ -8339,10 +7948,10 @@ yyreduce:
local_resume(p, (yyvsp[-2].nd));
nvars_unnest(p);
}
-#line 8343 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7952 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 330: /* primary: defn_head f_arglist bodystmt keyword_end */
+ case 330:
#line 2764 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-3].nd);
@@ -8350,10 +7959,10 @@ yyreduce:
nvars_unnest(p);
p->in_def--;
}
-#line 8354 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7963 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 331: /* primary: defs_head f_arglist bodystmt keyword_end */
+ case 331:
#line 2774 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-3].nd);
@@ -8362,450 +7971,450 @@ yyreduce:
p->in_def--;
p->in_single--;
}
-#line 8366 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7975 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 332: /* primary: keyword_break */
+ case 332:
#line 2782 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_break(p, 0);
}
-#line 8374 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7983 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 333: /* primary: keyword_next */
+ case 333:
#line 2786 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_next(p, 0);
}
-#line 8382 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7991 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 334: /* primary: keyword_redo */
+ case 334:
#line 2790 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_redo(p);
}
-#line 8390 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 7999 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 335: /* primary: keyword_retry */
+ case 335:
#line 2794 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_retry(p);
}
-#line 8398 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8007 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 336: /* primary_value: primary */
+ case 336:
#line 2800 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
if (!(yyval.nd)) (yyval.nd) = new_nil(p);
}
-#line 8407 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8016 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 343: /* if_tail: keyword_elsif expr_value then compstmt if_tail */
+ case 343:
#line 2819 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_if(p, cond((yyvsp[-3].nd)), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8415 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8024 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 345: /* opt_else: keyword_else compstmt */
+ case 345:
#line 2826 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 8423 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8032 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 346: /* for_var: lhs */
+ case 346:
#line 2832 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1(list1((yyvsp[0].nd)));
}
-#line 8431 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8040 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 348: /* f_margs: f_arg */
+ case 348:
#line 2839 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3((yyvsp[0].nd),0,0);
}
-#line 8439 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8048 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 349: /* f_margs: f_arg ',' tSTAR f_norm_arg */
+ case 349:
#line 2843 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3((yyvsp[-3].nd), new_arg(p, (yyvsp[0].id)), 0);
}
-#line 8447 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8056 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 350: /* f_margs: f_arg ',' tSTAR f_norm_arg ',' f_arg */
+ case 350:
#line 2847 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3((yyvsp[-5].nd), new_arg(p, (yyvsp[-2].id)), (yyvsp[0].nd));
}
-#line 8455 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8064 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 351: /* f_margs: f_arg ',' tSTAR */
+ case 351:
#line 2851 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, 0);
(yyval.nd) = list3((yyvsp[-2].nd), (node*)-1, 0);
}
-#line 8464 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8073 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 352: /* f_margs: f_arg ',' tSTAR ',' f_arg */
+ case 352:
#line 2856 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3((yyvsp[-4].nd), (node*)-1, (yyvsp[0].nd));
}
-#line 8472 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8081 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 353: /* f_margs: tSTAR f_norm_arg */
+ case 353:
#line 2860 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3(0, new_arg(p, (yyvsp[0].id)), 0);
}
-#line 8480 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8089 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 354: /* f_margs: tSTAR f_norm_arg ',' f_arg */
+ case 354:
#line 2864 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3(0, new_arg(p, (yyvsp[-2].id)), (yyvsp[0].nd));
}
-#line 8488 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8097 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 355: /* f_margs: tSTAR */
+ case 355:
#line 2868 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, 0);
(yyval.nd) = list3(0, (node*)-1, 0);
}
-#line 8497 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8106 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 356: /* $@24: %empty */
+ case 356:
#line 2873 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, 0);
}
-#line 8505 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8114 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 357: /* f_margs: tSTAR ',' $@24 f_arg */
+ case 357:
#line 2877 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list3(0, (node*)-1, (yyvsp[0].nd));
}
-#line 8513 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8122 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 358: /* block_args_tail: f_block_kwarg ',' f_kwrest opt_f_block_arg */
+ case 358:
#line 2883 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, (yyvsp[-3].nd), (yyvsp[-1].nd), (yyvsp[0].id));
}
-#line 8521 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8130 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 359: /* block_args_tail: f_block_kwarg opt_f_block_arg */
+ case 359:
#line 2887 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, (yyvsp[-1].nd), 0, (yyvsp[0].id));
}
-#line 8529 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8138 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 360: /* block_args_tail: f_kwrest opt_f_block_arg */
+ case 360:
#line 2891 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, 0, (yyvsp[-1].nd), (yyvsp[0].id));
}
-#line 8537 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8146 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 361: /* block_args_tail: f_block_arg */
+ case 361:
#line 2895 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, 0, 0, (yyvsp[0].id));
}
-#line 8545 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8154 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 362: /* opt_block_args_tail: ',' block_args_tail */
+ case 362:
#line 2901 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 8553 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8162 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 363: /* opt_block_args_tail: %empty */
+ case 363:
#line 2905 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, 0, 0, 0);
}
-#line 8561 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8170 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 364: /* block_param: f_arg ',' f_block_optarg ',' f_rest_arg opt_block_args_tail */
+ case 364:
#line 2911 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-5].nd), (yyvsp[-3].nd), (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 8569 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8178 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 365: /* block_param: f_arg ',' f_block_optarg ',' f_rest_arg ',' f_arg opt_block_args_tail */
+ case 365:
#line 2915 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-7].nd), (yyvsp[-5].nd), (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8577 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8186 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 366: /* block_param: f_arg ',' f_block_optarg opt_block_args_tail */
+ case 366:
#line 2919 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-3].nd), (yyvsp[-1].nd), 0, 0, (yyvsp[0].nd));
}
-#line 8585 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8194 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 367: /* block_param: f_arg ',' f_block_optarg ',' f_arg opt_block_args_tail */
+ case 367:
#line 2923 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-5].nd), (yyvsp[-3].nd), 0, (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8593 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8202 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 368: /* block_param: f_arg ',' f_rest_arg opt_block_args_tail */
+ case 368:
#line 2927 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-3].nd), 0, (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 8601 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8210 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 369: /* block_param: f_arg ',' opt_block_args_tail */
+ case 369:
#line 2931 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-2].nd), 0, 0, 0, (yyvsp[0].nd));
}
-#line 8609 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8218 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 370: /* block_param: f_arg ',' f_rest_arg ',' f_arg opt_block_args_tail */
+ case 370:
#line 2935 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-5].nd), 0, (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8617 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8226 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 371: /* block_param: f_arg opt_block_args_tail */
+ case 371:
#line 2939 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-1].nd), 0, 0, 0, (yyvsp[0].nd));
}
-#line 8625 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8234 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 372: /* block_param: f_block_optarg ',' f_rest_arg opt_block_args_tail */
+ case 372:
#line 2943 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-3].nd), (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 8633 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8242 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 373: /* block_param: f_block_optarg ',' f_rest_arg ',' f_arg opt_block_args_tail */
+ case 373:
#line 2947 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-5].nd), (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8641 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8250 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 374: /* block_param: f_block_optarg opt_block_args_tail */
+ case 374:
#line 2951 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-1].nd), 0, 0, (yyvsp[0].nd));
}
-#line 8649 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8258 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 375: /* block_param: f_block_optarg ',' f_arg opt_block_args_tail */
+ case 375:
#line 2955 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-3].nd), 0, (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8657 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8266 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 376: /* block_param: f_rest_arg opt_block_args_tail */
+ case 376:
#line 2959 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, 0, (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 8665 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8274 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 377: /* block_param: f_rest_arg ',' f_arg opt_block_args_tail */
+ case 377:
#line 2963 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, 0, (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 8673 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8282 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 378: /* block_param: block_args_tail */
+ case 378:
#line 2967 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, 0, 0, 0, (yyvsp[0].nd));
}
-#line 8681 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8290 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 379: /* opt_block_param: none */
+ case 379:
#line 2973 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_blk(p, 0);
(yyval.nd) = 0;
}
-#line 8690 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8299 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 380: /* opt_block_param: block_param_def */
+ case 380:
#line 2978 "mrbgems/mruby-compiler/core/parse.y"
{
p->cmd_start = TRUE;
(yyval.nd) = (yyvsp[0].nd);
}
-#line 8699 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8308 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 381: /* $@25: %empty */
+ case 381:
#line 2984 "mrbgems/mruby-compiler/core/parse.y"
{local_add_blk(p, 0);}
-#line 8705 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8314 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 382: /* block_param_def: '|' $@25 opt_bv_decl '|' */
+ case 382:
#line 2985 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = 0;
}
-#line 8713 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8322 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 383: /* block_param_def: tOROP */
+ case 383:
#line 2989 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_blk(p, 0);
(yyval.nd) = 0;
}
-#line 8722 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8331 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 384: /* block_param_def: '|' block_param opt_bv_decl '|' */
+ case 384:
#line 2994 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-2].nd);
}
-#line 8730 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8339 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 385: /* opt_bv_decl: opt_nl */
+ case 385:
#line 3001 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = 0;
}
-#line 8738 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8347 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 386: /* opt_bv_decl: opt_nl ';' bv_decls opt_nl */
+ case 386:
#line 3005 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = 0;
}
-#line 8746 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8355 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 389: /* bvar: tIDENTIFIER */
+ case 389:
#line 3015 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, (yyvsp[0].id));
new_bv(p, (yyvsp[0].id));
}
-#line 8755 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8364 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 391: /* f_larglist: '(' f_args opt_bv_decl ')' */
+ case 391:
#line 3023 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-2].nd);
}
-#line 8763 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8372 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 392: /* f_larglist: f_args */
+ case 392:
#line 3027 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 8771 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8380 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 393: /* lambda_body: tLAMBEG compstmt '}' */
+ case 393:
#line 3033 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 8779 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8388 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 394: /* lambda_body: keyword_do_LAMBDA bodystmt keyword_end */
+ case 394:
#line 3037 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 8787 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8396 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 395: /* $@26: %empty */
+ case 395:
#line 3043 "mrbgems/mruby-compiler/core/parse.y"
{
local_nest(p);
nvars_nest(p);
}
-#line 8796 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8405 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 396: /* do_block: keyword_do_block $@26 opt_block_param bodystmt keyword_end */
+ case 396:
#line 3050 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_block(p,(yyvsp[-2].nd),(yyvsp[-1].nd));
local_unnest(p);
nvars_unnest(p);
}
-#line 8806 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8415 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 397: /* block_call: command do_block */
+ case 397:
#line 3058 "mrbgems/mruby-compiler/core/parse.y"
{
if ((yyvsp[-1].nd)->car == (node*)NODE_YIELD) {
@@ -8816,118 +8425,118 @@ yyreduce:
}
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 8820 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8429 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 398: /* block_call: block_call call_op2 operation2 opt_paren_args */
+ case 398:
#line 3068 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), (yyvsp[-1].id), (yyvsp[0].nd), (yyvsp[-2].num));
}
-#line 8828 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8437 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 399: /* block_call: block_call call_op2 operation2 opt_paren_args brace_block */
+ case 399:
#line 3072 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), (yyvsp[-1].nd), (yyvsp[-3].num));
call_with_block(p, (yyval.nd), (yyvsp[0].nd));
}
-#line 8837 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8446 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 400: /* block_call: block_call call_op2 operation2 command_args do_block */
+ case 400:
#line 3077 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-4].nd), (yyvsp[-2].id), (yyvsp[-1].nd), (yyvsp[-3].num));
call_with_block(p, (yyval.nd), (yyvsp[0].nd));
}
-#line 8846 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8455 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 401: /* method_call: operation paren_args */
+ case 401:
#line 3084 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_fcall(p, (yyvsp[-1].id), (yyvsp[0].nd));
}
-#line 8854 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8463 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 402: /* method_call: primary_value call_op operation2 opt_paren_args */
+ case 402:
#line 3088 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), (yyvsp[-1].id), (yyvsp[0].nd), (yyvsp[-2].num));
}
-#line 8862 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8471 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 403: /* method_call: primary_value tCOLON2 operation2 paren_args */
+ case 403:
#line 3092 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), (yyvsp[-1].id), (yyvsp[0].nd), tCOLON2);
}
-#line 8870 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8479 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 404: /* method_call: primary_value tCOLON2 operation3 */
+ case 404:
#line 3096 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), (yyvsp[0].id), 0, tCOLON2);
}
-#line 8878 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8487 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 405: /* method_call: primary_value call_op paren_args */
+ case 405:
#line 3100 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), MRB_SYM(call), (yyvsp[0].nd), (yyvsp[-1].num));
}
-#line 8886 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8495 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 406: /* method_call: primary_value tCOLON2 paren_args */
+ case 406:
#line 3104 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-2].nd), MRB_SYM(call), (yyvsp[0].nd), tCOLON2);
}
-#line 8894 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8503 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 407: /* method_call: keyword_super paren_args */
+ case 407:
#line 3108 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_super(p, (yyvsp[0].nd));
}
-#line 8902 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8511 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 408: /* method_call: keyword_super */
+ case 408:
#line 3112 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_zsuper(p);
}
-#line 8910 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8519 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 409: /* method_call: primary_value '[' opt_call_args ']' */
+ case 409:
#line 3116 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_call(p, (yyvsp[-3].nd), MRB_OPSYM(aref), (yyvsp[-1].nd), '.');
}
-#line 8918 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8527 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 410: /* @27: %empty */
+ case 410:
#line 3122 "mrbgems/mruby-compiler/core/parse.y"
{
local_nest(p);
nvars_nest(p);
(yyval.num) = p->lineno;
}
-#line 8928 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8537 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 411: /* brace_block: '{' @27 opt_block_param compstmt '}' */
+ case 411:
#line 3129 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_block(p,(yyvsp[-2].nd),(yyvsp[-1].nd));
@@ -8935,20 +8544,20 @@ yyreduce:
local_unnest(p);
nvars_unnest(p);
}
-#line 8939 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8548 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 412: /* @28: %empty */
+ case 412:
#line 3136 "mrbgems/mruby-compiler/core/parse.y"
{
local_nest(p);
nvars_nest(p);
(yyval.num) = p->lineno;
}
-#line 8949 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8558 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 413: /* brace_block: keyword_do @28 opt_block_param bodystmt keyword_end */
+ case 413:
#line 3143 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_block(p,(yyvsp[-2].nd),(yyvsp[-1].nd));
@@ -8956,18 +8565,18 @@ yyreduce:
local_unnest(p);
nvars_unnest(p);
}
-#line 8960 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8569 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 414: /* case_body: keyword_when args then compstmt cases */
+ case 414:
#line 3154 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = cons(cons((yyvsp[-3].nd), (yyvsp[-1].nd)), (yyvsp[0].nd));
}
-#line 8968 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8577 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 415: /* cases: opt_else */
+ case 415:
#line 3160 "mrbgems/mruby-compiler/core/parse.y"
{
if ((yyvsp[0].nd)) {
@@ -8977,382 +8586,382 @@ yyreduce:
(yyval.nd) = 0;
}
}
-#line 8981 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8590 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 417: /* opt_rescue: keyword_rescue exc_list exc_var then compstmt opt_rescue */
+ case 417:
#line 3174 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1(list3((yyvsp[-4].nd), (yyvsp[-3].nd), (yyvsp[-1].nd)));
if ((yyvsp[0].nd)) (yyval.nd) = append((yyval.nd), (yyvsp[0].nd));
}
-#line 8990 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8599 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 419: /* exc_list: arg */
+ case 419:
#line 3182 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 8998 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8607 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 422: /* exc_var: tASSOC lhs */
+ case 422:
#line 3190 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 9006 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8615 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 424: /* opt_ensure: keyword_ensure compstmt */
+ case 424:
#line 3197 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 9014 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8623 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 431: /* string: string string_fragment */
+ case 431:
#line 3211 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = concat_string(p, (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9022 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8631 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 434: /* string_fragment: tSTRING_BEG tSTRING */
+ case 434:
#line 3219 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 9030 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8639 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 435: /* string_fragment: tSTRING_BEG string_rep tSTRING */
+ case 435:
#line 3223 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dstr(p, push((yyvsp[-1].nd), (yyvsp[0].nd)));
}
-#line 9038 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8647 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 437: /* string_rep: string_rep string_interp */
+ case 437:
#line 3230 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = append((yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9046 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8655 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 438: /* string_interp: tSTRING_MID */
+ case 438:
#line 3236 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 9054 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8663 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 439: /* @29: %empty */
+ case 439:
#line 3240 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = p->lex_strterm;
p->lex_strterm = NULL;
}
-#line 9063 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8672 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 440: /* string_interp: tSTRING_PART @29 compstmt '}' */
+ case 440:
#line 3246 "mrbgems/mruby-compiler/core/parse.y"
{
p->lex_strterm = (yyvsp[-2].nd);
(yyval.nd) = list2((yyvsp[-3].nd), (yyvsp[-1].nd));
}
-#line 9072 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8681 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 441: /* string_interp: tLITERAL_DELIM */
+ case 441:
#line 3251 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1(new_literal_delim(p));
}
-#line 9080 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8689 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 442: /* string_interp: tHD_LITERAL_DELIM heredoc_bodies */
+ case 442:
#line 3255 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1(new_literal_delim(p));
}
-#line 9088 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8697 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 443: /* xstring: tXSTRING_BEG tXSTRING */
+ case 443:
#line 3261 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 9096 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8705 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 444: /* xstring: tXSTRING_BEG string_rep tXSTRING */
+ case 444:
#line 3265 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dxstr(p, push((yyvsp[-1].nd), (yyvsp[0].nd)));
}
-#line 9104 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8713 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 445: /* regexp: tREGEXP_BEG tREGEXP */
+ case 445:
#line 3271 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 9112 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8721 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 446: /* regexp: tREGEXP_BEG string_rep tREGEXP */
+ case 446:
#line 3275 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_dregx(p, (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9120 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8729 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 450: /* heredoc_body: tHEREDOC_END */
+ case 450:
#line 3288 "mrbgems/mruby-compiler/core/parse.y"
{
parser_heredoc_info * inf = parsing_heredoc_inf(p);
inf->doc = push(inf->doc, new_str(p, "", 0));
heredoc_end(p);
}
-#line 9130 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8739 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 451: /* heredoc_body: heredoc_string_rep tHEREDOC_END */
+ case 451:
#line 3294 "mrbgems/mruby-compiler/core/parse.y"
{
heredoc_end(p);
}
-#line 9138 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8747 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 454: /* heredoc_string_interp: tHD_STRING_MID */
+ case 454:
#line 3304 "mrbgems/mruby-compiler/core/parse.y"
{
parser_heredoc_info * inf = parsing_heredoc_inf(p);
inf->doc = push(inf->doc, (yyvsp[0].nd));
heredoc_treat_nextline(p);
}
-#line 9148 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8757 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 455: /* @30: %empty */
+ case 455:
#line 3310 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = p->lex_strterm;
p->lex_strterm = NULL;
}
-#line 9157 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8766 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 456: /* heredoc_string_interp: tHD_STRING_PART @30 compstmt '}' */
+ case 456:
#line 3316 "mrbgems/mruby-compiler/core/parse.y"
{
parser_heredoc_info * inf = parsing_heredoc_inf(p);
p->lex_strterm = (yyvsp[-2].nd);
inf->doc = push(push(inf->doc, (yyvsp[-3].nd)), (yyvsp[-1].nd));
}
-#line 9167 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8776 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 457: /* words: tWORDS_BEG tSTRING */
+ case 457:
#line 3324 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_words(p, list1((yyvsp[0].nd)));
}
-#line 9175 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8784 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 458: /* words: tWORDS_BEG string_rep tSTRING */
+ case 458:
#line 3328 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_words(p, push((yyvsp[-1].nd), (yyvsp[0].nd)));
}
-#line 9183 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8792 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 459: /* symbol: basic_symbol */
+ case 459:
#line 3335 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_ENDARG;
(yyval.nd) = new_sym(p, (yyvsp[0].id));
}
-#line 9192 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8801 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 460: /* symbol: tSYMBEG tSTRING_BEG string_rep tSTRING */
+ case 460:
#line 3340 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_ENDARG;
(yyval.nd) = new_dsym(p, new_dstr(p, push((yyvsp[-1].nd), (yyvsp[0].nd))));
}
-#line 9201 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8810 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 461: /* basic_symbol: tSYMBEG sym */
+ case 461:
#line 3347 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = (yyvsp[0].id);
}
-#line 9209 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8818 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 466: /* sym: tSTRING */
+ case 466:
#line 3357 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = new_strsym(p, (yyvsp[0].nd));
}
-#line 9217 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8826 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 467: /* sym: tSTRING_BEG tSTRING */
+ case 467:
#line 3361 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = new_strsym(p, (yyvsp[0].nd));
}
-#line 9225 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8834 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 468: /* symbols: tSYMBOLS_BEG tSTRING */
+ case 468:
#line 3367 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_symbols(p, list1((yyvsp[0].nd)));
}
-#line 9233 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8842 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 469: /* symbols: tSYMBOLS_BEG string_rep tSTRING */
+ case 469:
#line 3371 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_symbols(p, push((yyvsp[-1].nd), (yyvsp[0].nd)));
}
-#line 9241 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8850 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 472: /* numeric: tUMINUS_NUM tINTEGER */
+ case 472:
#line 3379 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = negate_lit(p, (yyvsp[0].nd));
}
-#line 9249 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8858 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 473: /* numeric: tUMINUS_NUM tFLOAT */
+ case 473:
#line 3383 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = negate_lit(p, (yyvsp[0].nd));
}
-#line 9257 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8866 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 474: /* variable: tIDENTIFIER */
+ case 474:
#line 3389 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_lvar(p, (yyvsp[0].id));
}
-#line 9265 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8874 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 475: /* variable: tIVAR */
+ case 475:
#line 3393 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_ivar(p, (yyvsp[0].id));
}
-#line 9273 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8882 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 476: /* variable: tGVAR */
+ case 476:
#line 3397 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_gvar(p, (yyvsp[0].id));
}
-#line 9281 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8890 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 477: /* variable: tCVAR */
+ case 477:
#line 3401 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_cvar(p, (yyvsp[0].id));
}
-#line 9289 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8898 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 478: /* variable: tCONSTANT */
+ case 478:
#line 3405 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_const(p, (yyvsp[0].id));
}
-#line 9297 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8906 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 479: /* var_lhs: variable */
+ case 479:
#line 3411 "mrbgems/mruby-compiler/core/parse.y"
{
assignable(p, (yyvsp[0].nd));
}
-#line 9305 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8914 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 480: /* var_lhs: tNUMPARAM */
+ case 480:
#line 3415 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "can't assign to numbered parameter");
}
-#line 9313 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8922 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 481: /* var_ref: variable */
+ case 481:
#line 3421 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = var_reference(p, (yyvsp[0].nd));
}
-#line 9321 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8930 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 482: /* var_ref: keyword_nil */
+ case 482:
#line 3425 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_nil(p);
}
-#line 9329 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8938 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 483: /* var_ref: keyword_self */
+ case 483:
#line 3429 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_self(p);
}
-#line 9337 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8946 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 484: /* var_ref: keyword_true */
+ case 484:
#line 3433 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_true(p);
}
-#line 9345 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8954 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 485: /* var_ref: keyword_false */
+ case 485:
#line 3437 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_false(p);
}
-#line 9353 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8962 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 486: /* var_ref: keyword__FILE__ */
+ case 486:
#line 3441 "mrbgems/mruby-compiler/core/parse.y"
{
const char *fn = mrb_sym_name_len(p->mrb, p->filename_sym, NULL);
@@ -9361,10 +8970,10 @@ yyreduce:
}
(yyval.nd) = new_str(p, fn, strlen(fn));
}
-#line 9365 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8974 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 487: /* var_ref: keyword__LINE__ */
+ case 487:
#line 3449 "mrbgems/mruby-compiler/core/parse.y"
{
char buf[16];
@@ -9372,10 +8981,10 @@ yyreduce:
dump_int(p->lineno, buf);
(yyval.nd) = new_int(p, buf, 10, 0);
}
-#line 9376 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8985 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 488: /* var_ref: keyword__ENCODING__ */
+ case 488:
#line 3456 "mrbgems/mruby-compiler/core/parse.y"
{
#ifdef MRB_UTF8_STRING
@@ -9385,45 +8994,45 @@ yyreduce:
#endif
(yyval.nd) = new_str(p, enc, strlen(enc));
}
-#line 9389 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 8998 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 491: /* superclass: %empty */
+ case 491:
#line 3471 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = 0;
}
-#line 9397 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9006 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 492: /* $@31: %empty */
+ case 492:
#line 3475 "mrbgems/mruby-compiler/core/parse.y"
{
p->lstate = EXPR_BEG;
p->cmd_start = TRUE;
}
-#line 9406 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9015 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 493: /* superclass: '<' $@31 expr_value term */
+ case 493:
#line 3480 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 9414 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9023 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 494: /* f_arglist_paren: '(' f_args rparen */
+ case 494:
#line 3491 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
p->lstate = EXPR_BEG;
p->cmd_start = TRUE;
}
-#line 9424 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9033 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 495: /* f_arglist_paren: '(' tDOT3 rparen */
+ case 495:
#line 3497 "mrbgems/mruby-compiler/core/parse.y"
{
#if 1
@@ -9442,503 +9051,503 @@ yyreduce:
new_args_tail(p, 0, new_kw_rest_args(p, nsym(k)), b));
#endif
}
-#line 9446 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9055 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 497: /* f_arglist: f_args term */
+ case 497:
#line 3518 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 9454 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9063 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 498: /* f_label: tIDENTIFIER tLABEL_TAG */
+ case 498:
#line 3524 "mrbgems/mruby-compiler/core/parse.y"
{
local_nest(p);
}
-#line 9462 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9071 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 499: /* f_kw: f_label arg */
+ case 499:
#line 3530 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = new_kw_arg(p, (yyvsp[-1].id), cons((yyvsp[0].nd), locals_node(p)));
local_unnest(p);
}
-#line 9472 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9081 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 500: /* f_kw: f_label */
+ case 500:
#line 3536 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_kw_arg(p, (yyvsp[0].id), 0);
local_unnest(p);
}
-#line 9481 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9090 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 501: /* f_block_kw: f_label primary_value */
+ case 501:
#line 3543 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_kw_arg(p, (yyvsp[-1].id), cons((yyvsp[0].nd), locals_node(p)));
local_unnest(p);
}
-#line 9490 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9099 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 502: /* f_block_kw: f_label */
+ case 502:
#line 3548 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_kw_arg(p, (yyvsp[0].id), 0);
local_unnest(p);
}
-#line 9499 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9108 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 503: /* f_block_kwarg: f_block_kw */
+ case 503:
#line 3555 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 9507 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9116 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 504: /* f_block_kwarg: f_block_kwarg ',' f_block_kw */
+ case 504:
#line 3559 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 9515 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9124 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 505: /* f_kwarg: f_kw */
+ case 505:
#line 3565 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 9523 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9132 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 506: /* f_kwarg: f_kwarg ',' f_kw */
+ case 506:
#line 3569 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 9531 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9140 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 509: /* f_kwrest: kwrest_mark tIDENTIFIER */
+ case 509:
#line 3579 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_kw_rest_args(p, nsym((yyvsp[0].id)));
}
-#line 9539 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9148 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 510: /* f_kwrest: kwrest_mark */
+ case 510:
#line 3583 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_kw_rest_args(p, 0);
}
-#line 9547 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9156 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 511: /* args_tail: f_kwarg ',' f_kwrest opt_f_block_arg */
+ case 511:
#line 3589 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, (yyvsp[-3].nd), (yyvsp[-1].nd), (yyvsp[0].id));
}
-#line 9555 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9164 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 512: /* args_tail: f_kwarg opt_f_block_arg */
+ case 512:
#line 3593 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, (yyvsp[-1].nd), 0, (yyvsp[0].id));
}
-#line 9563 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9172 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 513: /* args_tail: f_kwrest opt_f_block_arg */
+ case 513:
#line 3597 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, 0, (yyvsp[-1].nd), (yyvsp[0].id));
}
-#line 9571 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9180 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 514: /* args_tail: f_block_arg */
+ case 514:
#line 3601 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, 0, 0, (yyvsp[0].id));
}
-#line 9579 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9188 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 515: /* opt_args_tail: ',' args_tail */
+ case 515:
#line 3607 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
}
-#line 9587 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9196 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 516: /* opt_args_tail: %empty */
+ case 516:
#line 3611 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args_tail(p, 0, 0, 0);
}
-#line 9595 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9204 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 517: /* f_args: f_arg ',' f_optarg ',' f_rest_arg opt_args_tail */
+ case 517:
#line 3617 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-5].nd), (yyvsp[-3].nd), (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 9603 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9212 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 518: /* f_args: f_arg ',' f_optarg ',' f_rest_arg ',' f_arg opt_args_tail */
+ case 518:
#line 3621 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-7].nd), (yyvsp[-5].nd), (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9611 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9220 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 519: /* f_args: f_arg ',' f_optarg opt_args_tail */
+ case 519:
#line 3625 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-3].nd), (yyvsp[-1].nd), 0, 0, (yyvsp[0].nd));
}
-#line 9619 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9228 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 520: /* f_args: f_arg ',' f_optarg ',' f_arg opt_args_tail */
+ case 520:
#line 3629 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-5].nd), (yyvsp[-3].nd), 0, (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9627 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9236 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 521: /* f_args: f_arg ',' f_rest_arg opt_args_tail */
+ case 521:
#line 3633 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-3].nd), 0, (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 9635 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9244 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 522: /* f_args: f_arg ',' f_rest_arg ',' f_arg opt_args_tail */
+ case 522:
#line 3637 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-5].nd), 0, (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9643 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9252 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 523: /* f_args: f_arg opt_args_tail */
+ case 523:
#line 3641 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, (yyvsp[-1].nd), 0, 0, 0, (yyvsp[0].nd));
}
-#line 9651 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9260 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 524: /* f_args: f_optarg ',' f_rest_arg opt_args_tail */
+ case 524:
#line 3645 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-3].nd), (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 9659 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9268 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 525: /* f_args: f_optarg ',' f_rest_arg ',' f_arg opt_args_tail */
+ case 525:
#line 3649 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-5].nd), (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9667 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9276 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 526: /* f_args: f_optarg opt_args_tail */
+ case 526:
#line 3653 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-1].nd), 0, 0, (yyvsp[0].nd));
}
-#line 9675 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9284 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 527: /* f_args: f_optarg ',' f_arg opt_args_tail */
+ case 527:
#line 3657 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, (yyvsp[-3].nd), 0, (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9683 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9292 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 528: /* f_args: f_rest_arg opt_args_tail */
+ case 528:
#line 3661 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, 0, (yyvsp[-1].id), 0, (yyvsp[0].nd));
}
-#line 9691 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9300 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 529: /* f_args: f_rest_arg ',' f_arg opt_args_tail */
+ case 529:
#line 3665 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, 0, (yyvsp[-3].id), (yyvsp[-1].nd), (yyvsp[0].nd));
}
-#line 9699 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9308 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 530: /* f_args: args_tail */
+ case 530:
#line 3669 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_args(p, 0, 0, 0, 0, (yyvsp[0].nd));
}
-#line 9707 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9316 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 531: /* f_args: %empty */
+ case 531:
#line 3673 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, MRB_OPSYM(and));
(yyval.nd) = new_args(p, 0, 0, 0, 0, 0);
}
-#line 9716 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9325 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 532: /* f_bad_arg: tCONSTANT */
+ case 532:
#line 3680 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "formal argument cannot be a constant");
(yyval.nd) = 0;
}
-#line 9725 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9334 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 533: /* f_bad_arg: tIVAR */
+ case 533:
#line 3685 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "formal argument cannot be an instance variable");
(yyval.nd) = 0;
}
-#line 9734 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9343 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 534: /* f_bad_arg: tGVAR */
+ case 534:
#line 3690 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "formal argument cannot be a global variable");
(yyval.nd) = 0;
}
-#line 9743 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9352 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 535: /* f_bad_arg: tCVAR */
+ case 535:
#line 3695 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "formal argument cannot be a class variable");
(yyval.nd) = 0;
}
-#line 9752 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9361 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 536: /* f_bad_arg: tNUMPARAM */
+ case 536:
#line 3700 "mrbgems/mruby-compiler/core/parse.y"
{
yyerror(p, "formal argument cannot be a numbered parameter");
(yyval.nd) = 0;
}
-#line 9761 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9370 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 537: /* f_norm_arg: f_bad_arg */
+ case 537:
#line 3707 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = 0;
}
-#line 9769 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9378 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 538: /* f_norm_arg: tIDENTIFIER */
+ case 538:
#line 3711 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, (yyvsp[0].id));
(yyval.id) = (yyvsp[0].id);
}
-#line 9778 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9387 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 539: /* f_arg_item: f_norm_arg */
+ case 539:
#line 3718 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_arg(p, (yyvsp[0].id));
}
-#line 9786 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9395 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 540: /* @32: %empty */
+ case 540:
#line 3722 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = local_switch(p);
}
-#line 9794 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9403 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 541: /* f_arg_item: tLPAREN @32 f_margs rparen */
+ case 541:
#line 3726 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = new_masgn_param(p, (yyvsp[-1].nd), p->locals->car);
local_resume(p, (yyvsp[-2].nd));
local_add_f(p, 0);
}
-#line 9804 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9413 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 542: /* f_arg: f_arg_item */
+ case 542:
#line 3734 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 9812 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9421 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 543: /* f_arg: f_arg ',' f_arg_item */
+ case 543:
#line 3738 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 9820 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9429 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 544: /* f_opt_asgn: tIDENTIFIER '=' */
+ case 544:
#line 3744 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, (yyvsp[-1].id));
local_nest(p);
(yyval.id) = (yyvsp[-1].id);
}
-#line 9830 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9439 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 545: /* f_opt: f_opt_asgn arg */
+ case 545:
#line 3752 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons(nsym((yyvsp[-1].id)), cons((yyvsp[0].nd), locals_node(p)));
local_unnest(p);
}
-#line 9840 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9449 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 546: /* f_block_opt: f_opt_asgn primary_value */
+ case 546:
#line 3760 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons(nsym((yyvsp[-1].id)), cons((yyvsp[0].nd), locals_node(p)));
local_unnest(p);
}
-#line 9850 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9459 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 547: /* f_block_optarg: f_block_opt */
+ case 547:
#line 3768 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 9858 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9467 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 548: /* f_block_optarg: f_block_optarg ',' f_block_opt */
+ case 548:
#line 3772 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 9866 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9475 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 549: /* f_optarg: f_opt */
+ case 549:
#line 3778 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
}
-#line 9874 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9483 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 550: /* f_optarg: f_optarg ',' f_opt */
+ case 550:
#line 3782 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 9882 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9491 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 553: /* f_rest_arg: restarg_mark tIDENTIFIER */
+ case 553:
#line 3792 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, (yyvsp[0].id));
(yyval.id) = (yyvsp[0].id);
}
-#line 9891 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9500 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 554: /* f_rest_arg: restarg_mark */
+ case 554:
#line 3797 "mrbgems/mruby-compiler/core/parse.y"
{
local_add_f(p, MRB_OPSYM(mul));
(yyval.id) = -1;
}
-#line 9900 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9509 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 557: /* f_block_arg: blkarg_mark tIDENTIFIER */
+ case 557:
#line 3808 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = (yyvsp[0].id);
}
-#line 9908 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9517 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 558: /* opt_f_block_arg: ',' f_block_arg */
+ case 558:
#line 3814 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = (yyvsp[0].id);
}
-#line 9916 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9525 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 559: /* opt_f_block_arg: none */
+ case 559:
#line 3818 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.id) = 0;
}
-#line 9924 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9533 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 560: /* singleton: var_ref */
+ case 560:
#line 3824 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[0].nd);
if (!(yyval.nd)) (yyval.nd) = new_nil(p);
}
-#line 9933 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9542 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 561: /* $@33: %empty */
+ case 561:
#line 3828 "mrbgems/mruby-compiler/core/parse.y"
{p->lstate = EXPR_BEG;}
-#line 9939 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9548 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 562: /* singleton: '(' $@33 expr rparen */
+ case 562:
#line 3829 "mrbgems/mruby-compiler/core/parse.y"
{
if ((yyvsp[-1].nd) == 0) {
@@ -9962,54 +9571,54 @@ yyreduce:
}
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 9966 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9575 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 564: /* assoc_list: assocs trailer */
+ case 564:
#line 3855 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = (yyvsp[-1].nd);
}
-#line 9974 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9583 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 565: /* assocs: assoc */
+ case 565:
#line 3861 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = list1((yyvsp[0].nd));
NODE_LINENO((yyval.nd), (yyvsp[0].nd));
}
-#line 9983 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9592 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 566: /* assocs: assocs comma assoc */
+ case 566:
#line 3866 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = push((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 9991 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9600 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 569: /* assoc: arg tASSOC arg */
+ case 569:
#line 3876 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[-2].nd));
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons((yyvsp[-2].nd), (yyvsp[0].nd));
}
-#line 10001 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9610 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 570: /* assoc: tIDENTIFIER label_tag arg */
+ case 570:
#line 3882 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons(new_sym(p, (yyvsp[-2].id)), (yyvsp[0].nd));
}
-#line 10010 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9619 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 571: /* assoc: string_fragment label_tag arg */
+ case 571:
#line 3887 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
@@ -10020,67 +9629,67 @@ yyreduce:
(yyval.nd) = cons(new_sym(p, new_strsym(p, (yyvsp[-2].nd))), (yyvsp[0].nd));
}
}
-#line 10024 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9633 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 572: /* assoc: tDSTAR arg */
+ case 572:
#line 3897 "mrbgems/mruby-compiler/core/parse.y"
{
void_expr_error(p, (yyvsp[0].nd));
(yyval.nd) = cons(new_kw_rest_args(p, 0), (yyvsp[0].nd));
}
-#line 10033 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9642 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 585: /* call_op: '.' */
+ case 585:
#line 3924 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.num) = '.';
}
-#line 10041 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9650 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 586: /* call_op: tANDDOT */
+ case 586:
#line 3928 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.num) = 0;
}
-#line 10049 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9658 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 588: /* call_op2: tCOLON2 */
+ case 588:
#line 3935 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.num) = tCOLON2;
}
-#line 10057 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9666 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 597: /* term: ';' */
+ case 597:
#line 3956 "mrbgems/mruby-compiler/core/parse.y"
{yyerrok;}
-#line 10063 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9672 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 600: /* nl: '\n' */
+ case 600:
#line 3962 "mrbgems/mruby-compiler/core/parse.y"
{
p->lineno += (yyvsp[0].num);
p->column = 0;
}
-#line 10072 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9681 "mrbgems/mruby-compiler/core/y.tab.c"
break;
- case 603: /* none: %empty */
+ case 603:
#line 3973 "mrbgems/mruby-compiler/core/parse.y"
{
(yyval.nd) = 0;
}
-#line 10080 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9689 "mrbgems/mruby-compiler/core/y.tab.c"
break;
-#line 10084 "mrbgems/mruby-compiler/core/y.tab.c"
+#line 9693 "mrbgems/mruby-compiler/core/y.tab.c"
default: break;
}
@@ -10095,10 +9704,11 @@ yyreduce:
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 ("-> $$ =", YY_CAST (yysymbol_kind_t, yyr1[yyn]), &yyval, &yyloc);
+ YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
YYPOPSTACK (yylen);
yylen = 0;
+ YY_STACK_PRINT (yyss, yyssp);
*++yyvsp = yyval;
@@ -10122,44 +9732,50 @@ yyreduce:
yyerrlab:
/* Make sure we have latest lookahead translation. See comments at
user semantic actions for why this is necessary. */
- yytoken = yychar == YYEMPTY ? YYSYMBOL_YYEMPTY : YYTRANSLATE (yychar);
+ yytoken = yychar == YYEMPTY ? YYEMPTY : YYTRANSLATE (yychar);
+
/* If not already recovering from an error, report this error. */
if (!yyerrstatus)
{
++yynerrs;
+#if ! YYERROR_VERBOSE
+ yyerror (p, YY_("syntax error"));
+#else
+# define YYSYNTAX_ERROR yysyntax_error (&yymsg_alloc, &yymsg, \
+ yyssp, yytoken)
{
- yypcontext_t yyctx
- = {yyssp, yytoken};
char const *yymsgp = YY_("syntax error");
int yysyntax_error_status;
- yysyntax_error_status = yysyntax_error (&yymsg_alloc, &yymsg, &yyctx);
+ yysyntax_error_status = YYSYNTAX_ERROR;
if (yysyntax_error_status == 0)
yymsgp = yymsg;
- else if (yysyntax_error_status == -1)
+ else if (yysyntax_error_status == 1)
{
if (yymsg != yymsgbuf)
YYSTACK_FREE (yymsg);
- yymsg = YY_CAST (char *,
- YYSTACK_ALLOC (YY_CAST (YYSIZE_T, yymsg_alloc)));
- if (yymsg)
+ yymsg = YY_CAST (char *, YYSTACK_ALLOC (YY_CAST (YYSIZE_T, yymsg_alloc)));
+ if (!yymsg)
{
- yysyntax_error_status
- = yysyntax_error (&yymsg_alloc, &yymsg, &yyctx);
- yymsgp = yymsg;
+ yymsg = yymsgbuf;
+ yymsg_alloc = sizeof yymsgbuf;
+ yysyntax_error_status = 2;
}
else
{
- yymsg = yymsgbuf;
- yymsg_alloc = sizeof yymsgbuf;
- yysyntax_error_status = YYENOMEM;
+ yysyntax_error_status = YYSYNTAX_ERROR;
+ yymsgp = yymsg;
}
}
yyerror (p, yymsgp);
- if (yysyntax_error_status == YYENOMEM)
+ if (yysyntax_error_status == 2)
goto yyexhaustedlab;
}
+# undef YYSYNTAX_ERROR
+#endif
}
+
+
if (yyerrstatus == 3)
{
/* If just tried and failed to reuse lookahead token after an
@@ -10208,14 +9824,13 @@ yyerrorlab:
yyerrlab1:
yyerrstatus = 3; /* Each real token shifted decrements this. */
- /* Pop stack until we find a state that shifts the error token. */
for (;;)
{
yyn = yypact[yystate];
if (!yypact_value_is_default (yyn))
{
- yyn += YYSYMBOL_YYerror;
- if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYSYMBOL_YYerror)
+ yyn += YYTERROR;
+ if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
{
yyn = yytable[yyn];
if (0 < yyn)
@@ -10229,7 +9844,7 @@ yyerrlab1:
yydestruct ("Error: popping",
- YY_ACCESSING_SYMBOL (yystate), yyvsp, p);
+ yystos[yystate], yyvsp, p);
YYPOPSTACK (1);
yystate = *yyssp;
YY_STACK_PRINT (yyss, yyssp);
@@ -10241,7 +9856,7 @@ yyerrlab1:
/* Shift the error token. */
- YY_SYMBOL_PRINT ("Shifting", YY_ACCESSING_SYMBOL (yyn), yyvsp, yylsp);
+ YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
yystate = yyn;
goto yynewstate;
@@ -10263,20 +9878,20 @@ yyabortlab:
goto yyreturn;
-#if 1
+#if !defined yyoverflow || YYERROR_VERBOSE
/*-------------------------------------------------.
| yyexhaustedlab -- memory exhaustion comes here. |
`-------------------------------------------------*/
yyexhaustedlab:
yyerror (p, YY_("memory exhausted"));
yyresult = 2;
- goto yyreturn;
+ /* Fall through. */
#endif
-/*-------------------------------------------------------.
-| yyreturn -- parsing is finished, clean up and return. |
-`-------------------------------------------------------*/
+/*-----------------------------------------------------.
+| yyreturn -- parsing is finished, return the result. |
+`-----------------------------------------------------*/
yyreturn:
if (yychar != YYEMPTY)
{
@@ -10293,18 +9908,19 @@ yyreturn:
while (yyssp != yyss)
{
yydestruct ("Cleanup: popping",
- YY_ACCESSING_SYMBOL (+*yyssp), yyvsp, p);
+ yystos[+*yyssp], yyvsp, p);
YYPOPSTACK (1);
}
#ifndef yyoverflow
if (yyss != yyssa)
YYSTACK_FREE (yyss);
#endif
+#if YYERROR_VERBOSE
if (yymsg != yymsgbuf)
YYSTACK_FREE (yymsg);
+#endif
return yyresult;
}
-
#line 3977 "mrbgems/mruby-compiler/core/parse.y"
#define pylval (*((YYSTYPE*)(p->ylval)))
@@ -12860,8 +12476,13 @@ mrb_parse_file_continue(mrb_state *mrb, FILE *f, const void *prebuf, size_t preb
p = mrb_parser_new(mrb);
if (!p) return NULL;
- p->s = (const char *)prebuf;
- p->send = (const char *)prebuf + prebufsize;
+ if (prebuf) {
+ p->s = (const char *)prebuf;
+ p->send = (const char *)prebuf + prebufsize;
+ }
+ else {
+ p->s = p->send = NULL;
+ }
p->f = f;
mrb_parser_parse(p, c);