Annotation of parser3/src/main/compile.tab.C, revision 1.147
1.114 misha 1: /* A Bison parser, made by GNU Bison 1.875d. */
1.112 paf 2:
3: /* Skeleton parser for Yacc-like parsing with Bison,
1.114 misha 4: Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.112 paf 5:
6: This program is free software; you can redistribute it and/or modify
7: it under the terms of the GNU General Public License as published by
8: the Free Software Foundation; either version 2, or (at your option)
9: any later version.
10:
11: This program is distributed in the hope that it will be useful,
12: but WITHOUT ANY WARRANTY; without even the implied warranty of
13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14: GNU General Public License for more details.
15:
16: You should have received a copy of the GNU General Public License
17: along with this program; if not, write to the Free Software
18: Foundation, Inc., 59 Temple Place - Suite 330,
19: Boston, MA 02111-1307, USA. */
20:
21: /* As a special exception, when this file is copied by Bison into a
22: Bison output file, you may use that output file without restriction.
23: This special exception was added by the Free Software Foundation
24: in version 1.24 of Bison. */
25:
26: /* Written by Richard Stallman by simplifying the original so called
27: ``semantic'' parser. */
28:
29: /* All symbols defined below should begin with yy or YY, to avoid
30: infringing on user name space. This should be done even for local
31: variables, as they might otherwise be expanded by user macros.
32: There are some unavoidable exceptions within include files to
33: define necessary library symbols; they are noted "INFRINGES ON
34: USER NAME SPACE" below. */
35:
36: /* Identify Bison output. */
37: #define YYBISON 1
38:
39: /* Skeleton name. */
1.113 paf 40: #define YYSKELETON_NAME "yacc.c"
1.112 paf 41:
42: /* Pure parsers. */
43: #define YYPURE 1
44:
45: /* Using locations. */
46: #define YYLSP_NEEDED 0
1.105 paf 47:
1.1 parser 48:
49:
1.112 paf 50: /* Tokens. */
51: #ifndef YYTOKENTYPE
52: # define YYTOKENTYPE
53: /* Put the tokens into the symbol table, so that GDB and other debuggers
54: know about them. */
55: enum yytokentype {
56: EON = 258,
57: STRING = 259,
58: BOGUS = 260,
59: BAD_STRING_COMPARISON_OPERATOR = 261,
60: BAD_HEX_LITERAL = 262,
61: BAD_METHOD_DECL_START = 263,
62: BAD_METHOD_PARAMETER_NAME_CHARACTER = 264,
63: BAD_NONWHITESPACE_CHARACTER_IN_EXPLICIT_RESULT_MODE = 265,
64: LAND = 266,
65: LOR = 267,
66: LXOR = 268,
67: NXOR = 269,
68: NLE = 270,
69: NGE = 271,
70: NEQ = 272,
71: NNE = 273,
72: NSL = 274,
73: NSR = 275,
74: SLT = 276,
75: SGT = 277,
76: SLE = 278,
77: SGE = 279,
78: SEQ = 280,
79: SNE = 281,
80: DEF = 282,
81: IN = 283,
82: FEXISTS = 284,
83: DEXISTS = 285,
84: IS = 286,
85: LITERAL_TRUE = 287,
86: LITERAL_FALSE = 288,
87: NUNARY = 289
88: };
89: #endif
90: #define EON 258
91: #define STRING 259
92: #define BOGUS 260
93: #define BAD_STRING_COMPARISON_OPERATOR 261
94: #define BAD_HEX_LITERAL 262
95: #define BAD_METHOD_DECL_START 263
96: #define BAD_METHOD_PARAMETER_NAME_CHARACTER 264
97: #define BAD_NONWHITESPACE_CHARACTER_IN_EXPLICIT_RESULT_MODE 265
98: #define LAND 266
99: #define LOR 267
100: #define LXOR 268
101: #define NXOR 269
102: #define NLE 270
103: #define NGE 271
104: #define NEQ 272
105: #define NNE 273
106: #define NSL 274
107: #define NSR 275
108: #define SLT 276
109: #define SGT 277
110: #define SLE 278
111: #define SGE 279
112: #define SEQ 280
113: #define SNE 281
114: #define DEF 282
115: #define IN 283
116: #define FEXISTS 284
117: #define DEXISTS 285
118: #define IS 286
119: #define LITERAL_TRUE 287
120: #define LITERAL_FALSE 288
121: #define NUNARY 289
1.1 parser 122:
1.112 paf 123:
124:
125:
126: /* Copy the first part of user declarations. */
1.14 parser 127: #line 1 "compile.y"
1.1 parser 128:
1.14 parser 129: /** @file
130: Parser: compiler(lexical parser and grammar).
131:
1.132 misha 132: Copyright (c) 2001-2009 ArtLebedev Group (http://www.artlebedev.com)
1.27 paf 133: Author: Alexander Petrosyan <paf@design.ru> (http://design.ru/paf)
1.109 paf 134:
1.147 ! pretende 135: $Id: compile.tab.C,v 1.146 2009-09-07 12:31:25 misha Exp $
1.14 parser 136: */
1.1 parser 137:
138: /**
139: @todo parser4:
140: - cache compiled code from request to request. to do that...
141: -#: make method definitions, @CLASS, @BASE, @USE instructions,
142: which would be executed afterwards, and actions
143: now performed at compile time would be delayed to run time.
144: -#: make cache expiration on time and on disk-change of class source
145: -#: in apache use subpools for compiled class storage
146: -#: in iis make up specialized Pool object for that
147: */
148:
1.84 paf 149: #define YYSTYPE ArrayOperation*
1.1 parser 150: #define YYPARSE_PARAM pc
151: #define YYLEX_PARAM pc
152: #define YYDEBUG 1
153: #define YYERROR_VERBOSE 1
1.84 paf 154: #define yyerror(msg) real_yyerror((Parse_control *)pc, msg)
1.1 parser 155: #define YYPRINT(file, type, value) yyprint(file, type, value)
156:
1.84 paf 157: // includes
158:
1.1 parser 159: #include "compile_tools.h"
160: #include "pa_value.h"
161: #include "pa_request.h"
162: #include "pa_vobject.h"
163: #include "pa_vdouble.h"
164: #include "pa_globals.h"
165: #include "pa_vvoid.h"
1.72 paf 166: #include "pa_vmethod_frame.h"
1.1 parser 167:
1.84 paf 168: // defines
169:
1.1 parser 170: #define USE_CONTROL_METHOD_NAME "USE"
1.119 misha 171: #define OPTIONS_CONTROL_METHOD_NAME "OPTIONS"
172: #define OPTION_ALL_VARS_LOCAL_NAME "locals"
1.123 misha 173: #define OPTION_PARTIAL_CLASS "partial"
1.131 misha 174: #define REM_OPERATOR_NAME "rem"
1.1 parser 175:
1.84 paf 176: // forwards
177:
178: static int real_yyerror(Parse_control* pc, char* s);
179: static void yyprint(FILE* file, int type, YYSTYPE value);
180: static int yylex(YYSTYPE* lvalp, void* pc);
1.1 parser 181:
1.107 paf 182: static const VBool vfalse(false);
183: static const VBool vtrue(true);
184: static const VVoid vvoid;
185:
1.1 parser 186: // local convinient inplace typecast & var
1.83 paf 187: #undef PC
1.84 paf 188: #define PC (*(Parse_control *)pc)
189: #undef POOL
1.1 parser 190: #define POOL (*PC.pool)
191: #ifndef DOXYGEN
1.112 paf 192:
193:
194: /* Enabling traces. */
195: #ifndef YYDEBUG
196: # define YYDEBUG 0
1.109 paf 197: #endif
1.108 paf 198:
1.112 paf 199: /* Enabling verbose error messages. */
200: #ifdef YYERROR_VERBOSE
201: # undef YYERROR_VERBOSE
202: # define YYERROR_VERBOSE 1
203: #else
204: # define YYERROR_VERBOSE 0
1.106 paf 205: #endif
1.112 paf 206:
207: #if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
208: typedef int YYSTYPE;
209: # define yystype YYSTYPE /* obsolescent; will be withdrawn */
210: # define YYSTYPE_IS_DECLARED 1
211: # define YYSTYPE_IS_TRIVIAL 1
212: #endif
213:
214:
215:
216: /* Copy the second part of user declarations. */
217:
218:
219: /* Line 214 of yacc.c. */
1.131 misha 220: #line 221 "compile.tab.C"
1.112 paf 221:
222: #if ! defined (yyoverflow) || YYERROR_VERBOSE
223:
1.114 misha 224: # ifndef YYFREE
225: # define YYFREE free
226: # endif
227: # ifndef YYMALLOC
228: # define YYMALLOC malloc
229: # endif
230:
1.112 paf 231: /* The parser invokes alloca or malloc; define the necessary symbols. */
232:
1.113 paf 233: # ifdef YYSTACK_USE_ALLOCA
234: # if YYSTACK_USE_ALLOCA
235: # define YYSTACK_ALLOC alloca
236: # endif
1.112 paf 237: # else
1.113 paf 238: # if defined (alloca) || defined (_ALLOCA_H)
239: # define YYSTACK_ALLOC alloca
240: # else
241: # ifdef __GNUC__
242: # define YYSTACK_ALLOC __builtin_alloca
1.112 paf 243: # endif
244: # endif
245: # endif
246:
247: # ifdef YYSTACK_ALLOC
248: /* Pacify GCC's `empty if-body' warning. */
249: # define YYSTACK_FREE(Ptr) do { /* empty */; } while (0)
250: # else
251: # if defined (__STDC__) || defined (__cplusplus)
252: # include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
253: # define YYSIZE_T size_t
254: # endif
1.114 misha 255: # define YYSTACK_ALLOC YYMALLOC
256: # define YYSTACK_FREE YYFREE
1.112 paf 257: # endif
258: #endif /* ! defined (yyoverflow) || YYERROR_VERBOSE */
259:
260:
261: #if (! defined (yyoverflow) \
262: && (! defined (__cplusplus) \
1.113 paf 263: || (defined (YYSTYPE_IS_TRIVIAL) && YYSTYPE_IS_TRIVIAL)))
1.112 paf 264:
265: /* A type that is properly aligned for any stack member. */
266: union yyalloc
267: {
1.114 misha 268: short int yyss;
1.112 paf 269: YYSTYPE yyvs;
270: };
271:
272: /* The size of the maximum gap between one aligned stack and the next. */
273: # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
274:
275: /* The size of an array large to enough to hold all stacks, each with
276: N elements. */
277: # define YYSTACK_BYTES(N) \
1.114 misha 278: ((N) * (sizeof (short int) + sizeof (YYSTYPE)) \
1.112 paf 279: + YYSTACK_GAP_MAXIMUM)
280:
281: /* Copy COUNT objects from FROM to TO. The source and destination do
282: not overlap. */
283: # ifndef YYCOPY
1.113 paf 284: # if defined (__GNUC__) && 1 < __GNUC__
1.112 paf 285: # define YYCOPY(To, From, Count) \
286: __builtin_memcpy (To, From, (Count) * sizeof (*(From)))
287: # else
288: # define YYCOPY(To, From, Count) \
289: do \
290: { \
291: register YYSIZE_T yyi; \
292: for (yyi = 0; yyi < (Count); yyi++) \
293: (To)[yyi] = (From)[yyi]; \
294: } \
295: while (0)
296: # endif
297: # endif
298:
299: /* Relocate STACK from its old location to the new one. The
300: local variables YYSIZE and YYSTACKSIZE give the old and new number of
301: elements in the stack, and YYPTR gives the new location of the
302: stack. Advance YYPTR to a properly aligned location for the next
303: stack. */
304: # define YYSTACK_RELOCATE(Stack) \
305: do \
306: { \
307: YYSIZE_T yynewbytes; \
308: YYCOPY (&yyptr->Stack, Stack, yysize); \
309: Stack = &yyptr->Stack; \
310: yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
311: yyptr += yynewbytes / sizeof (*yyptr); \
312: } \
313: while (0)
314:
1.1 parser 315: #endif
1.108 paf 316:
1.112 paf 317: #if defined (__STDC__) || defined (__cplusplus)
318: typedef signed char yysigned_char;
319: #else
1.114 misha 320: typedef short int yysigned_char;
1.112 paf 321: #endif
1.108 paf 322:
1.112 paf 323: /* YYFINAL -- State number of the termination state. */
324: #define YYFINAL 51
325: /* YYLAST -- Last index in YYTABLE. */
1.115 misha 326: #define YYLAST 470
1.112 paf 327:
328: /* YYNTOKENS -- Number of terminals. */
329: #define YYNTOKENS 62
330: /* YYNNTS -- Number of nonterminals. */
1.115 misha 331: #define YYNNTS 89
1.112 paf 332: /* YYNRULES -- Number of rules. */
1.115 misha 333: #define YYNRULES 172
1.112 paf 334: /* YYNRULES -- Number of states. */
1.115 misha 335: #define YYNSTATES 263
1.112 paf 336:
337: /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
338: #define YYUNDEFTOK 2
339: #define YYMAXUTOK 289
340:
341: #define YYTRANSLATE(YYX) \
342: ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
343:
344: /* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
345: static const unsigned char yytranslate[] =
346: {
347: 0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
348: 48, 2, 2, 2, 2, 2, 2, 2, 2, 2,
349: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
350: 2, 2, 2, 46, 60, 2, 52, 43, 37, 61,
351: 56, 57, 40, 38, 2, 39, 55, 41, 2, 2,
352: 2, 2, 2, 2, 2, 2, 2, 2, 59, 51,
353: 34, 2, 35, 2, 47, 2, 2, 2, 2, 2,
354: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
355: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
356: 2, 49, 42, 50, 58, 2, 2, 2, 2, 2,
357: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
358: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
359: 2, 2, 2, 53, 36, 54, 45, 2, 2, 2,
360: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
361: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
362: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
363: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
364: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
365: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
366: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
367: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
368: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
369: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
370: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
371: 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
372: 2, 2, 2, 2, 2, 2, 1, 2, 3, 4,
373: 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
374: 15, 16, 17, 18, 19, 20, 21, 22, 23, 24,
375: 25, 26, 27, 28, 29, 30, 31, 32, 33, 44
376: };
1.105 paf 377:
1.112 paf 378: #if YYDEBUG
379: /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
380: YYRHS. */
1.114 misha 381: static const unsigned short int yyprhs[] =
1.112 paf 382: {
383: 0, 0, 3, 5, 7, 9, 12, 14, 16, 18,
1.115 misha 384: 23, 25, 27, 29, 32, 35, 37, 39, 40, 49,
385: 51, 53, 57, 59, 61, 63, 67, 69, 71, 73,
386: 75, 77, 80, 82, 84, 86, 88, 90, 92, 95,
387: 98, 100, 104, 106, 108, 110, 113, 115, 118, 122,
388: 124, 126, 128, 130, 133, 136, 138, 140, 142, 143,
389: 144, 150, 154, 158, 160, 162, 164, 166, 168, 170,
390: 173, 175, 176, 177, 184, 186, 188, 191, 193, 195,
391: 197, 198, 199, 205, 209, 213, 215, 219, 221, 225,
392: 227, 231, 233, 235, 237, 239, 241, 243, 245, 248,
393: 250, 253, 256, 258, 260, 263, 265, 267, 269, 271,
394: 274, 277, 278, 279, 285, 287, 289, 292, 295, 297,
395: 299, 302, 305, 307, 309, 311, 313, 315, 317, 321,
396: 325, 329, 332, 335, 338, 341, 344, 347, 350, 353,
397: 357, 361, 365, 369, 373, 377, 381, 385, 389, 393,
398: 397, 401, 405, 409, 413, 417, 421, 425, 429, 433,
399: 437, 441, 445, 449, 453, 457, 461, 463, 465, 467,
400: 468, 470, 472
1.109 paf 401: };
1.105 paf 402:
1.112 paf 403: /* YYRHS -- A `-1'-separated list of the rules' RHS. */
1.114 misha 404: static const short int yyrhs[] =
1.112 paf 405: {
406: 63, 0, -1, 65, -1, 64, -1, 66, -1, 64,
1.115 misha 407: 66, -1, 79, -1, 67, -1, 72, -1, 47, 4,
408: 48, 68, -1, 150, -1, 69, -1, 70, -1, 69,
409: 70, -1, 71, 48, -1, 150, -1, 4, -1, -1,
410: 47, 4, 75, 74, 78, 48, 73, 79, -1, 150,
411: -1, 75, -1, 49, 76, 50, -1, 150, -1, 77,
412: -1, 4, -1, 77, 51, 4, -1, 150, -1, 4,
413: -1, 150, -1, 80, -1, 81, -1, 80, 81, -1,
414: 146, -1, 82, -1, 83, -1, 91, -1, 106, -1,
415: 84, -1, 52, 85, -1, 87, 3, -1, 86, -1,
416: 53, 87, 54, -1, 88, -1, 89, -1, 90, -1,
417: 139, 90, -1, 129, -1, 126, 129, -1, 52, 92,
418: 96, -1, 93, -1, 94, -1, 95, -1, 125, -1,
419: 55, 125, -1, 139, 125, -1, 97, -1, 100, -1,
420: 101, -1, -1, -1, 49, 98, 102, 99, 50, -1,
421: 56, 142, 57, -1, 53, 79, 54, -1, 147, -1,
422: 4, -1, 103, -1, 104, -1, 105, -1, 82, -1,
423: 81, 80, -1, 107, -1, -1, -1, 58, 108, 110,
424: 109, 111, 3, -1, 87, -1, 112, -1, 111, 112,
425: -1, 113, -1, 116, -1, 117, -1, -1, -1, 49,
426: 114, 118, 115, 50, -1, 56, 119, 57, -1, 53,
427: 120, 54, -1, 121, -1, 118, 51, 121, -1, 122,
428: -1, 119, 51, 122, -1, 123, -1, 120, 51, 123,
429: -1, 124, -1, 142, -1, 79, -1, 147, -1, 4,
430: -1, 103, -1, 130, -1, 126, 130, -1, 127, -1,
431: 126, 127, -1, 128, 55, -1, 130, -1, 130, -1,
432: 4, 5, -1, 4, -1, 131, -1, 132, -1, 133,
433: -1, 52, 136, -1, 4, 137, -1, -1, -1, 49,
434: 134, 80, 135, 50, -1, 4, -1, 138, -1, 137,
435: 138, -1, 52, 136, -1, 140, -1, 141, -1, 4,
436: 59, -1, 140, 59, -1, 143, -1, 144, -1, 148,
437: -1, 149, -1, 84, -1, 107, -1, 60, 145, 60,
438: -1, 61, 145, 61, -1, 56, 143, 57, -1, 39,
439: 143, -1, 38, 143, -1, 45, 143, -1, 46, 143,
440: -1, 27, 143, -1, 28, 143, -1, 29, 143, -1,
441: 30, 143, -1, 143, 39, 143, -1, 143, 38, 143,
442: -1, 143, 40, 143, -1, 143, 41, 143, -1, 143,
443: 43, 143, -1, 143, 42, 143, -1, 143, 19, 143,
444: -1, 143, 20, 143, -1, 143, 37, 143, -1, 143,
445: 36, 143, -1, 143, 14, 143, -1, 143, 11, 143,
446: -1, 143, 12, 143, -1, 143, 13, 143, -1, 143,
447: 34, 143, -1, 143, 35, 143, -1, 143, 15, 143,
448: -1, 143, 16, 143, -1, 143, 17, 143, -1, 143,
449: 18, 143, -1, 143, 21, 143, -1, 143, 22, 143,
450: -1, 143, 23, 143, -1, 143, 24, 143, -1, 143,
451: 25, 143, -1, 143, 26, 143, -1, 143, 31, 143,
452: -1, 4, -1, 79, -1, 4, -1, -1, 32, -1,
453: 33, -1, -1
1.108 paf 454: };
1.1 parser 455:
1.112 paf 456: /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
1.114 misha 457: static const unsigned short int yyrline[] =
1.112 paf 458: {
1.131 misha 459: 0, 132, 132, 139, 141, 141, 142, 144, 144, 146,
460: 247, 247, 248, 248, 249, 250, 250, 252, 252, 302,
461: 302, 303, 304, 304, 305, 305, 307, 307, 311, 311,
1.140 misha 462: 313, 313, 314, 314, 315, 315, 315, 319, 360, 361,
1.141 misha 463: 361, 362, 364, 365, 366, 419, 420, 420, 424, 437,
464: 438, 439, 440, 466, 471, 474, 475, 476, 478, 481,
465: 478, 489, 497, 504, 505, 506, 508, 514, 515, 515,
1.143 misha 466: 519, 531, 534, 531, 578, 580, 580, 582, 583, 584,
467: 586, 589, 586, 592, 593, 595, 596, 599, 600, 603,
468: 604, 606, 609, 623, 628, 629, 630, 635, 635, 637,
469: 637, 638, 639, 647, 652, 655, 656, 657, 658, 660,
470: 664, 673, 676, 673, 684, 689, 689, 690, 696, 697,
471: 699, 716, 728, 730, 731, 732, 733, 734, 735, 736,
472: 737, 739, 740, 741, 742, 743, 744, 745, 746, 748,
473: 749, 750, 751, 752, 753, 754, 755, 756, 757, 758,
474: 759, 760, 761, 762, 763, 764, 765, 766, 767, 768,
475: 769, 770, 771, 772, 773, 774, 777, 782, 803, 808,
476: 809, 810, 812
1.106 paf 477: };
1.109 paf 478: #endif
1.1 parser 479:
1.112 paf 480: #if YYDEBUG || YYERROR_VERBOSE
481: /* YYTNME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
482: First, the terminals, then, starting at YYNTOKENS, nonterminals. */
483: static const char *const yytname[] =
484: {
1.113 paf 485: "$end", "error", "$undefined", "EON", "STRING", "BOGUS",
486: "BAD_STRING_COMPARISON_OPERATOR", "BAD_HEX_LITERAL",
487: "BAD_METHOD_DECL_START", "BAD_METHOD_PARAMETER_NAME_CHARACTER",
488: "BAD_NONWHITESPACE_CHARACTER_IN_EXPLICIT_RESULT_MODE", "\"&&\"",
489: "\"||\"", "\"!||\"", "\"!|\"", "\"<=\"", "\">=\"", "\"==\"", "\"!=\"",
490: "\"<<\"", "\">>\"", "\"lt\"", "\"gt\"", "\"le\"", "\"ge\"", "\"eq\"",
491: "\"ne\"", "\"def\"", "\"in\"", "\"-f\"", "\"-d\"", "\"is\"", "\"true\"",
492: "\"false\"", "'<'", "'>'", "'|'", "'&'", "'+'", "'-'", "'*'", "'/'",
493: "'\\\\'", "'%'", "NUNARY", "'~'", "'!'", "'@'", "'\\n'", "'['", "']'",
494: "';'", "'$'", "'{'", "'}'", "'.'", "'('", "')'", "'^'", "':'", "'\"'",
495: "'''", "$accept", "all", "methods", "one_big_piece", "method",
496: "control_method", "maybe_control_strings", "control_strings",
1.115 misha 497: "control_string", "maybe_string", "code_method", "@1",
1.113 paf 498: "maybe_bracketed_strings", "bracketed_maybe_strings", "maybe_strings",
499: "strings", "maybe_comment", "maybe_codes", "codes", "code", "action",
500: "get", "get_value", "get_name_value", "name_in_curly_rdive",
501: "name_without_curly_rdive", "name_without_curly_rdive_read",
502: "name_without_curly_rdive_class", "name_without_curly_rdive_code", "put",
503: "name_expr_wdive", "name_expr_wdive_root", "name_expr_wdive_write",
1.115 misha 504: "name_expr_wdive_class", "construct", "construct_square", "@2", "@3",
1.113 paf 505: "construct_round", "construct_curly", "any_constructor_code_value",
506: "constructor_code_value", "constructor_code",
1.115 misha 507: "codes__excluding_sole_str_literal", "call", "call_value", "@4", "@5",
508: "call_name", "store_params", "store_param", "store_square_param", "@6",
509: "@7", "store_round_param", "store_curly_param", "store_code_param_parts",
1.113 paf 510: "store_expr_param_parts", "store_curly_param_parts",
511: "store_code_param_part", "store_expr_param_part",
512: "store_curly_param_part", "code_param_value", "name_expr_dive_code",
513: "name_path", "name_step", "name_advance1", "name_advance2",
514: "name_expr_value", "name_expr_subvar_value",
1.115 misha 515: "name_expr_with_subvar_value", "name_square_code_value", "@8", "@9",
1.113 paf 516: "subvar_ref_name_rdive", "subvar_get_writes", "subvar__get_write",
517: "class_prefix", "class_static_prefix", "class_constructor_prefix",
518: "expr_value", "expr", "double_or_STRING", "string_inside_quotes_value",
1.112 paf 519: "write_string", "void_value", "true_value", "false_value", "empty", 0
1.1 parser 520: };
1.106 paf 521: #endif
1.1 parser 522:
1.112 paf 523: # ifdef YYPRINT
524: /* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
525: token YYLEX-NUM. */
1.114 misha 526: static const unsigned short int yytoknum[] =
1.112 paf 527: {
528: 0, 256, 257, 258, 259, 260, 261, 262, 263, 264,
529: 265, 266, 267, 268, 269, 270, 271, 272, 273, 274,
530: 275, 276, 277, 278, 279, 280, 281, 282, 283, 284,
531: 285, 286, 287, 288, 60, 62, 124, 38, 43, 45,
532: 42, 47, 92, 37, 289, 126, 33, 64, 10, 91,
533: 93, 59, 36, 123, 125, 46, 40, 41, 94, 58,
534: 34, 39
535: };
536: # endif
1.109 paf 537:
1.112 paf 538: /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
539: static const unsigned char yyr1[] =
540: {
541: 0, 62, 63, 63, 64, 64, 65, 66, 66, 67,
1.115 misha 542: 68, 68, 69, 69, 70, 71, 71, 73, 72, 74,
543: 74, 75, 76, 76, 77, 77, 78, 78, 79, 79,
544: 80, 80, 81, 81, 82, 82, 82, 83, 84, 85,
545: 85, 86, 87, 87, 88, 89, 90, 90, 91, 92,
546: 92, 92, 93, 94, 95, 96, 96, 96, 98, 99,
547: 97, 100, 101, 102, 102, 102, 103, 104, 105, 105,
548: 106, 108, 109, 107, 110, 111, 111, 112, 112, 112,
549: 114, 115, 113, 116, 117, 118, 118, 119, 119, 120,
550: 120, 121, 122, 123, 124, 124, 124, 125, 125, 126,
551: 126, 127, 128, 129, 129, 130, 130, 130, 130, 131,
552: 132, 134, 135, 133, 136, 137, 137, 138, 139, 139,
553: 140, 141, 142, 143, 143, 143, 143, 143, 143, 143,
554: 143, 143, 143, 143, 143, 143, 143, 143, 143, 143,
555: 143, 143, 143, 143, 143, 143, 143, 143, 143, 143,
556: 143, 143, 143, 143, 143, 143, 143, 143, 143, 143,
557: 143, 143, 143, 143, 143, 143, 144, 145, 146, 147,
558: 148, 149, 150
1.1 parser 559: };
560:
1.112 paf 561: /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
562: static const unsigned char yyr2[] =
563: {
564: 0, 2, 1, 1, 1, 2, 1, 1, 1, 4,
1.115 misha 565: 1, 1, 1, 2, 2, 1, 1, 0, 8, 1,
566: 1, 3, 1, 1, 1, 3, 1, 1, 1, 1,
567: 1, 2, 1, 1, 1, 1, 1, 1, 2, 2,
568: 1, 3, 1, 1, 1, 2, 1, 2, 3, 1,
569: 1, 1, 1, 2, 2, 1, 1, 1, 0, 0,
570: 5, 3, 3, 1, 1, 1, 1, 1, 1, 2,
571: 1, 0, 0, 6, 1, 1, 2, 1, 1, 1,
572: 0, 0, 5, 3, 3, 1, 3, 1, 3, 1,
573: 3, 1, 1, 1, 1, 1, 1, 1, 2, 1,
574: 2, 2, 1, 1, 2, 1, 1, 1, 1, 2,
575: 2, 0, 0, 5, 1, 1, 2, 2, 1, 1,
576: 2, 2, 1, 1, 1, 1, 1, 1, 3, 3,
577: 3, 2, 2, 2, 2, 2, 2, 2, 2, 3,
1.112 paf 578: 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
579: 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
1.115 misha 580: 3, 3, 3, 3, 3, 3, 1, 1, 1, 0,
581: 1, 1, 0
1.108 paf 582: };
1.106 paf 583:
1.112 paf 584: /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
585: STATE-NUM when YYTABLE doesn't specify something else to do. Zero
586: means the default is an error. */
587: static const unsigned char yydefact[] =
588: {
1.115 misha 589: 172, 168, 0, 0, 71, 0, 3, 2, 4, 7,
590: 8, 6, 29, 30, 33, 34, 37, 35, 36, 70,
591: 32, 28, 0, 105, 111, 0, 0, 0, 38, 40,
592: 0, 42, 43, 44, 0, 49, 50, 51, 52, 0,
593: 99, 0, 46, 97, 106, 107, 108, 0, 118, 119,
594: 0, 1, 5, 31, 172, 172, 172, 104, 0, 120,
595: 110, 115, 0, 114, 109, 0, 0, 103, 0, 105,
596: 53, 0, 97, 39, 58, 172, 0, 48, 55, 56,
597: 57, 105, 100, 47, 98, 101, 45, 54, 121, 74,
598: 72, 16, 9, 11, 12, 0, 10, 24, 0, 23,
599: 22, 172, 20, 19, 117, 116, 112, 41, 98, 169,
600: 0, 166, 0, 0, 0, 0, 170, 171, 0, 0,
601: 0, 0, 0, 0, 172, 172, 126, 127, 0, 122,
602: 123, 124, 125, 0, 13, 15, 14, 21, 0, 27,
603: 0, 26, 0, 168, 0, 33, 59, 65, 66, 67,
604: 63, 62, 135, 136, 137, 138, 132, 131, 133, 134,
605: 0, 167, 0, 0, 61, 0, 0, 0, 0, 0,
1.112 paf 606: 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
607: 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1.115 misha 608: 0, 0, 80, 172, 0, 0, 75, 77, 78, 79,
609: 25, 17, 113, 69, 0, 130, 128, 129, 150, 151,
610: 152, 149, 155, 156, 157, 158, 145, 146, 159, 160,
611: 161, 162, 163, 164, 165, 153, 154, 148, 147, 140,
612: 139, 141, 142, 144, 143, 169, 93, 0, 89, 0,
613: 87, 92, 73, 76, 172, 60, 168, 96, 81, 85,
614: 91, 94, 172, 84, 0, 83, 18, 169, 0, 90,
615: 88, 86, 82
1.1 parser 616: };
617:
1.112 paf 618: /* YYDEFGOTO[NTERM-NUM]. */
1.114 misha 619: static const short int yydefgoto[] =
1.112 paf 620: {
621: -1, 5, 6, 7, 8, 9, 92, 93, 94, 95,
1.115 misha 622: 10, 244, 101, 56, 98, 99, 140, 161, 12, 13,
623: 14, 15, 126, 28, 29, 30, 31, 32, 33, 17,
624: 34, 35, 36, 37, 77, 78, 109, 204, 79, 80,
625: 146, 247, 148, 149, 18, 127, 50, 133, 90, 195,
626: 196, 197, 235, 258, 198, 199, 248, 239, 237, 249,
627: 240, 238, 250, 38, 66, 40, 41, 42, 67, 44,
628: 45, 46, 62, 142, 64, 60, 61, 68, 48, 49,
629: 241, 129, 130, 162, 20, 251, 131, 132, 21
1.105 paf 630: };
1.1 parser 631:
1.112 paf 632: /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
633: STATE-NUM. */
1.115 misha 634: #define YYPACT_NINF -107
1.114 misha 635: static const short int yypact[] =
1.112 paf 636: {
1.115 misha 637: 14, -107, 13, 45, -107, 28, -15, -107, -107, -107,
638: -107, -107, 21, -107, -107, -107, -107, -107, -107, -107,
639: -107, -107, 73, 19, -107, 50, 6, 44, -107, -107,
640: 87, -107, -107, -107, -34, -107, -107, -107, -107, 65,
641: -107, 48, -107, 5, -107, -107, -107, 65, 24, -107,
642: 6, -107, -107, -107, 88, 109, 74, -107, 50, -107,
643: 76, -107, 21, -107, -107, 86, 65, 101, 65, 76,
644: -107, 44, 101, -107, -107, 21, 7, -107, -107, -107,
645: -107, 18, -107, -107, 5, -107, -107, -107, -107, -107,
646: -107, -107, -107, 9, -107, 94, 99, -107, 93, 112,
647: -107, 146, -107, -107, -107, -107, 21, -107, 101, 29,
648: 110, -107, 7, 7, 7, 7, -107, -107, 7, 7,
649: 7, 7, 52, 7, 21, 21, -107, -107, 113, 323,
650: -107, -107, -107, 92, -107, -107, -107, -107, 165, -107,
651: 144, -107, 147, 149, 21, 80, -107, -107, -107, -107,
652: -107, -107, 96, 96, 96, 96, -107, -107, -107, -107,
653: 276, -107, 138, 139, -107, 7, 7, 7, 7, 7,
654: 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
655: 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
656: 7, 7, -107, 21, 7, 35, -107, -107, -107, -107,
657: -107, -107, -107, 21, 154, -107, -107, -107, 419, 389,
658: 356, 284, 135, 135, 148, 148, 191, 191, 135, 135,
659: 135, 135, 148, 148, 96, 135, 135, 182, 427, 140,
660: 140, -107, -107, -107, -107, 37, -107, 31, -107, -30,
661: -107, -107, -107, -107, 21, -107, 108, -107, 155, -107,
662: -107, -107, 21, -107, 7, -107, -107, 37, 161, -107,
663: -107, -107, -107
1.1 parser 664: };
665:
1.112 paf 666: /* YYPGOTO[NTERM-NUM]. */
1.114 misha 667: static const short int yypgoto[] =
1.112 paf 668: {
1.115 misha 669: -107, -107, -107, -107, 206, -107, -107, -107, 124, -107,
670: -107, -107, -107, 170, -107, -107, -107, 1, -58, -7,
671: -106, -107, 0, -107, -107, -6, -107, -107, -21, -107,
672: -107, -107, -107, -107, -107, -107, -107, -107, -107, -107,
673: -107, 118, -107, -107, -107, 2, -107, -107, -107, -107,
674: 43, -107, -107, -107, -107, -107, -107, -107, -107, -17,
675: -13, -16, -107, -18, 4, 41, -107, -23, 3, -107,
676: -107, -107, -107, -107, 181, -107, 183, 239, -107, -107,
677: 171, 95, -107, 123, -107, 142, -107, -107, 64
1.1 parser 678: };
679:
1.112 paf 680: /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
681: positive, shift that token. If negative, reduce the rule which
682: number is the opposite. If zero, do what YYDEFACT says.
683: If YYTABLE_NINF, syntax error. */
1.115 misha 684: #define YYTABLE_NINF -173
1.114 misha 685: static const short int yytable[] =
1.112 paf 686: {
1.115 misha 687: 16, 11, 19, 145, 106, 53, 43, 39, -103, 70,
688: 23, 111, 16, 91, 19, 74, 83, 22, 1, 75,
689: 65, 254, 76, 57, 57, 1, 86, 255, 51, 87,
690: 72, 71, 2, 143, 112, 113, 114, 115, 242, 116,
691: 117, 246, 84, 83, 89, 118, 119, 86, 69, 23,
692: 43, 39, 120, 121, 63, 24, 23, -172, 25, 122,
693: -102, 2, 16, 123, 19, 4, 3, 124, 125, 81,
694: 58, 58, 4, 3, 108, 16, 110, 19, 59, 4,
695: 82, 3, 252, 88, 192, 253, 203, 4, 193, 3,
696: 73, 194, 91, 24, 24, 4, 25, 25, 26, 53,
697: 27, 24, 144, 85, 25, 26, 16, 82, 19, 16,
698: 168, 19, 82, 97, 24, 173, 174, 25, 96, 100,
699: 103, 54, 55, 55, 16, 16, 19, 19, 58, 145,
700: -68, -68, 184, 185, 186, 187, 188, 189, 190, 191,
701: 107, 192, 136, 137, 16, 193, 19, -15, 194, 168,
702: 139, 145, 171, 172, 173, 174, -102, 135, -95, -95,
703: 179, 180, 168, 138, 151, 141, 181, 173, 174, 200,
704: 164, 184, 185, 186, 187, 188, 189, 190, 191, 181,
705: 188, 189, 190, 191, 184, 185, 186, 187, 188, 189,
706: 190, 191, 201, 16, 236, 19, 53, 202, 206, -64,
707: 207, 173, 174, 16, 245, 19, 257, 152, 153, 154,
708: 155, 262, 52, 156, 157, 158, 159, 134, 160, 185,
709: 186, 187, 188, 189, 190, 191, 102, 147, 144, 186,
710: 187, 188, 189, 190, 191, 16, 259, 19, 243, 104,
711: 261, 260, 47, 105, 16, 256, 19, 128, 163, 0,
712: 144, 150, 16, 236, 19, 0, 0, 16, 0, 19,
713: 208, 209, 210, 211, 212, 213, 214, 215, 216, 217,
714: 218, 219, 220, 221, 222, 223, 224, 225, 226, 227,
715: 228, 229, 230, 231, 232, 233, 234, 165, 166, 167,
716: 168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
717: 178, 179, 180, 173, 174, 0, 0, 181, 0, 0,
718: 182, 183, 184, 185, 186, 187, 188, 189, 190, 191,
719: 184, 185, 186, 187, 188, 189, 190, 191, 0, 0,
720: 0, 0, 0, 205, 165, 166, 167, 168, 169, 170,
721: 171, 172, 173, 174, 175, 176, 177, 178, 179, 180,
722: 0, 0, 0, 0, 181, 0, 0, 182, 183, 184,
723: 185, 186, 187, 188, 189, 190, 191, 165, 166, 0,
724: 168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
725: 178, 179, 180, 0, 0, 0, 0, 181, 0, 0,
726: 182, 183, 184, 185, 186, 187, 188, 189, 190, 191,
727: 165, 0, 0, 168, 169, 170, 171, 172, 173, 174,
728: 175, 176, 177, 178, 179, 180, 0, 0, 0, 0,
729: 181, 0, 0, 182, 183, 184, 185, 186, 187, 188,
730: 189, 190, 191, 168, 169, 170, 171, 172, 173, 174,
731: 175, 176, 177, 178, 179, 180, 173, 174, 0, 0,
732: 181, 0, 0, 182, 183, 184, 185, 186, 187, 188,
733: 189, 190, 191, 0, 0, 186, 187, 188, 189, 190,
1.112 paf 734: 191
1.1 parser 735: };
736:
1.114 misha 737: static const short int yycheck[] =
1.112 paf 738: {
1.115 misha 739: 0, 0, 0, 109, 62, 12, 3, 3, 3, 27,
740: 4, 4, 12, 4, 12, 49, 39, 4, 4, 53,
741: 26, 51, 56, 5, 5, 4, 47, 57, 0, 47,
742: 27, 27, 47, 4, 27, 28, 29, 30, 3, 32,
743: 33, 4, 39, 66, 50, 38, 39, 68, 4, 4,
744: 47, 47, 45, 46, 4, 49, 4, 48, 52, 52,
745: 55, 47, 62, 56, 62, 58, 52, 60, 61, 4,
746: 52, 52, 58, 52, 71, 75, 75, 75, 59, 58,
747: 39, 52, 51, 59, 49, 54, 144, 58, 53, 52,
748: 3, 56, 4, 49, 49, 58, 52, 52, 53, 106,
749: 55, 49, 109, 55, 52, 53, 106, 66, 106, 109,
750: 14, 109, 71, 4, 49, 19, 20, 52, 54, 55,
751: 56, 48, 49, 49, 124, 125, 124, 125, 52, 235,
752: 50, 51, 36, 37, 38, 39, 40, 41, 42, 43,
753: 54, 49, 48, 50, 144, 53, 144, 48, 56, 14,
754: 4, 257, 17, 18, 19, 20, 55, 93, 50, 51,
755: 25, 26, 14, 51, 54, 101, 31, 19, 20, 4,
756: 57, 36, 37, 38, 39, 40, 41, 42, 43, 31,
757: 40, 41, 42, 43, 36, 37, 38, 39, 40, 41,
758: 42, 43, 48, 193, 193, 193, 203, 50, 60, 50,
759: 61, 19, 20, 203, 50, 203, 51, 112, 113, 114,
760: 115, 50, 6, 118, 119, 120, 121, 93, 123, 37,
761: 38, 39, 40, 41, 42, 43, 56, 109, 235, 38,
762: 39, 40, 41, 42, 43, 235, 252, 235, 195, 58,
763: 257, 254, 3, 60, 244, 244, 244, 76, 125, -1,
764: 257, 109, 252, 252, 252, -1, -1, 257, -1, 257,
765: 165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
766: 175, 176, 177, 178, 179, 180, 181, 182, 183, 184,
767: 185, 186, 187, 188, 189, 190, 191, 11, 12, 13,
768: 14, 15, 16, 17, 18, 19, 20, 21, 22, 23,
769: 24, 25, 26, 19, 20, -1, -1, 31, -1, -1,
770: 34, 35, 36, 37, 38, 39, 40, 41, 42, 43,
771: 36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
772: -1, -1, -1, 57, 11, 12, 13, 14, 15, 16,
773: 17, 18, 19, 20, 21, 22, 23, 24, 25, 26,
774: -1, -1, -1, -1, 31, -1, -1, 34, 35, 36,
775: 37, 38, 39, 40, 41, 42, 43, 11, 12, -1,
776: 14, 15, 16, 17, 18, 19, 20, 21, 22, 23,
777: 24, 25, 26, -1, -1, -1, -1, 31, -1, -1,
778: 34, 35, 36, 37, 38, 39, 40, 41, 42, 43,
779: 11, -1, -1, 14, 15, 16, 17, 18, 19, 20,
780: 21, 22, 23, 24, 25, 26, -1, -1, -1, -1,
781: 31, -1, -1, 34, 35, 36, 37, 38, 39, 40,
782: 41, 42, 43, 14, 15, 16, 17, 18, 19, 20,
783: 21, 22, 23, 24, 25, 26, 19, 20, -1, -1,
784: 31, -1, -1, 34, 35, 36, 37, 38, 39, 40,
785: 41, 42, 43, -1, -1, 38, 39, 40, 41, 42,
1.112 paf 786: 43
1.1 parser 787: };
788:
1.112 paf 789: /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
790: symbol of state STATE-NUM. */
791: static const unsigned char yystos[] =
792: {
793: 0, 4, 47, 52, 58, 63, 64, 65, 66, 67,
1.115 misha 794: 72, 79, 80, 81, 82, 83, 84, 91, 106, 107,
795: 146, 150, 4, 4, 49, 52, 53, 55, 85, 86,
796: 87, 88, 89, 90, 92, 93, 94, 95, 125, 126,
797: 127, 128, 129, 130, 131, 132, 133, 139, 140, 141,
798: 108, 0, 66, 81, 48, 49, 75, 5, 52, 59,
799: 137, 138, 134, 4, 136, 87, 126, 130, 139, 4,
800: 125, 126, 130, 3, 49, 53, 56, 96, 97, 100,
801: 101, 4, 127, 129, 130, 55, 90, 125, 59, 87,
802: 110, 4, 68, 69, 70, 71, 150, 4, 76, 77,
803: 150, 74, 75, 150, 136, 138, 80, 54, 130, 98,
804: 79, 4, 27, 28, 29, 30, 32, 33, 38, 39,
805: 45, 46, 52, 56, 60, 61, 84, 107, 142, 143,
806: 144, 148, 149, 109, 70, 150, 48, 50, 51, 4,
807: 78, 150, 135, 4, 81, 82, 102, 103, 104, 105,
808: 147, 54, 143, 143, 143, 143, 143, 143, 143, 143,
809: 143, 79, 145, 145, 57, 11, 12, 13, 14, 15,
1.112 paf 810: 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,
811: 26, 31, 34, 35, 36, 37, 38, 39, 40, 41,
1.115 misha 812: 42, 43, 49, 53, 56, 111, 112, 113, 116, 117,
813: 4, 48, 50, 80, 99, 57, 60, 61, 143, 143,
814: 143, 143, 143, 143, 143, 143, 143, 143, 143, 143,
815: 143, 143, 143, 143, 143, 143, 143, 143, 143, 143,
816: 143, 143, 143, 143, 143, 114, 79, 120, 123, 119,
817: 122, 142, 3, 112, 73, 50, 4, 103, 118, 121,
818: 124, 147, 51, 54, 51, 57, 79, 51, 115, 123,
819: 122, 121, 50
1.1 parser 820: };
1.109 paf 821:
1.112 paf 822: #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
823: # define YYSIZE_T __SIZE_TYPE__
824: #endif
825: #if ! defined (YYSIZE_T) && defined (size_t)
826: # define YYSIZE_T size_t
827: #endif
828: #if ! defined (YYSIZE_T)
829: # if defined (__STDC__) || defined (__cplusplus)
830: # include <stddef.h> /* INFRINGES ON USER NAME SPACE */
831: # define YYSIZE_T size_t
832: # endif
833: #endif
834: #if ! defined (YYSIZE_T)
835: # define YYSIZE_T unsigned int
1.1 parser 836: #endif
1.109 paf 837:
1.1 parser 838: #define yyerrok (yyerrstatus = 0)
839: #define yyclearin (yychar = YYEMPTY)
1.112 paf 840: #define YYEMPTY (-2)
1.1 parser 841: #define YYEOF 0
1.112 paf 842:
1.1 parser 843: #define YYACCEPT goto yyacceptlab
1.112 paf 844: #define YYABORT goto yyabortlab
1.113 paf 845: #define YYERROR goto yyerrorlab
1.112 paf 846:
847:
848: /* Like YYERROR except do call yyerror. This remains here temporarily
849: to ease the transition to the new meaning of YYERROR, for GCC.
1.1 parser 850: Once GCC version 2 has supplanted version 1, this can go. */
1.112 paf 851:
1.1 parser 852: #define YYFAIL goto yyerrlab
1.112 paf 853:
1.1 parser 854: #define YYRECOVERING() (!!yyerrstatus)
1.112 paf 855:
856: #define YYBACKUP(Token, Value) \
1.1 parser 857: do \
858: if (yychar == YYEMPTY && yylen == 1) \
1.112 paf 859: { \
860: yychar = (Token); \
861: yylval = (Value); \
862: yytoken = YYTRANSLATE (yychar); \
1.1 parser 863: YYPOPSTACK; \
864: goto yybackup; \
865: } \
866: else \
1.112 paf 867: { \
868: yyerror ("syntax error: cannot back up");\
869: YYERROR; \
870: } \
1.1 parser 871: while (0)
872:
873: #define YYTERROR 1
874: #define YYERRCODE 256
875:
1.112 paf 876: /* YYLLOC_DEFAULT -- Compute the default location (before the actions
877: are run). */
878:
879: #ifndef YYLLOC_DEFAULT
1.113 paf 880: # define YYLLOC_DEFAULT(Current, Rhs, N) \
881: ((Current).first_line = (Rhs)[1].first_line, \
882: (Current).first_column = (Rhs)[1].first_column, \
883: (Current).last_line = (Rhs)[N].last_line, \
884: (Current).last_column = (Rhs)[N].last_column)
1.109 paf 885: #endif
1.108 paf 886:
1.112 paf 887: /* YYLEX -- calling `yylex' with the right arguments. */
888:
1.109 paf 889: #ifdef YYLEX_PARAM
1.112 paf 890: # define YYLEX yylex (&yylval, YYLEX_PARAM)
1.109 paf 891: #else
1.112 paf 892: # define YYLEX yylex (&yylval)
1.106 paf 893: #endif
1.112 paf 894:
895: /* Enable debugging if requested. */
896: #if YYDEBUG
897:
898: # ifndef YYFPRINTF
899: # include <stdio.h> /* INFRINGES ON USER NAME SPACE */
900: # define YYFPRINTF fprintf
901: # endif
902:
903: # define YYDPRINTF(Args) \
904: do { \
905: if (yydebug) \
906: YYFPRINTF Args; \
907: } while (0)
908:
909: # define YYDSYMPRINT(Args) \
910: do { \
911: if (yydebug) \
912: yysymprint Args; \
913: } while (0)
914:
915: # define YYDSYMPRINTF(Title, Token, Value, Location) \
916: do { \
917: if (yydebug) \
918: { \
919: YYFPRINTF (stderr, "%s ", Title); \
920: yysymprint (stderr, \
921: Token, Value); \
922: YYFPRINTF (stderr, "\n"); \
923: } \
924: } while (0)
925:
926: /*------------------------------------------------------------------.
927: | yy_stack_print -- Print the state stack from its BOTTOM up to its |
1.113 paf 928: | TOP (included). |
1.112 paf 929: `------------------------------------------------------------------*/
930:
931: #if defined (__STDC__) || defined (__cplusplus)
932: static void
1.114 misha 933: yy_stack_print (short int *bottom, short int *top)
1.106 paf 934: #else
1.112 paf 935: static void
936: yy_stack_print (bottom, top)
1.114 misha 937: short int *bottom;
938: short int *top;
1.1 parser 939: #endif
1.112 paf 940: {
941: YYFPRINTF (stderr, "Stack now");
942: for (/* Nothing. */; bottom <= top; ++bottom)
943: YYFPRINTF (stderr, " %d", *bottom);
944: YYFPRINTF (stderr, "\n");
945: }
1.108 paf 946:
1.112 paf 947: # define YY_STACK_PRINT(Bottom, Top) \
948: do { \
949: if (yydebug) \
950: yy_stack_print ((Bottom), (Top)); \
951: } while (0)
1.108 paf 952:
953:
1.112 paf 954: /*------------------------------------------------.
955: | Report that the YYRULE is going to be reduced. |
956: `------------------------------------------------*/
1.108 paf 957:
1.112 paf 958: #if defined (__STDC__) || defined (__cplusplus)
959: static void
960: yy_reduce_print (int yyrule)
961: #else
962: static void
963: yy_reduce_print (yyrule)
964: int yyrule;
1.1 parser 965: #endif
1.112 paf 966: {
967: int yyi;
968: unsigned int yylno = yyrline[yyrule];
969: YYFPRINTF (stderr, "Reducing stack by rule %d (line %u), ",
970: yyrule - 1, yylno);
971: /* Print the symbols being reduced, and their result. */
972: for (yyi = yyprhs[yyrule]; 0 <= yyrhs[yyi]; yyi++)
973: YYFPRINTF (stderr, "%s ", yytname [yyrhs[yyi]]);
974: YYFPRINTF (stderr, "-> %s\n", yytname [yyr1[yyrule]]);
975: }
1.105 paf 976:
1.112 paf 977: # define YY_REDUCE_PRINT(Rule) \
978: do { \
979: if (yydebug) \
980: yy_reduce_print (Rule); \
981: } while (0)
982:
983: /* Nonzero means print parse trace. It is left uninitialized so that
984: multiple parsers can coexist. */
985: int yydebug;
986: #else /* !YYDEBUG */
987: # define YYDPRINTF(Args)
988: # define YYDSYMPRINT(Args)
989: # define YYDSYMPRINTF(Title, Token, Value, Location)
990: # define YY_STACK_PRINT(Bottom, Top)
991: # define YY_REDUCE_PRINT(Rule)
992: #endif /* !YYDEBUG */
1.1 parser 993:
994:
1.112 paf 995: /* YYINITDEPTH -- initial size of the parser's stacks. */
1.1 parser 996: #ifndef YYINITDEPTH
1.112 paf 997: # define YYINITDEPTH 200
1.1 parser 998: #endif
999:
1.112 paf 1000: /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
1001: if the built-in stack extension method is used).
1002:
1003: Do not make this value too large; the results are undefined if
1004: SIZE_MAX < YYSTACK_BYTES (YYMAXDEPTH)
1005: evaluated with infinite-precision integer arithmetic. */
1.1 parser 1006:
1.113 paf 1007: #if defined (YYMAXDEPTH) && YYMAXDEPTH == 0
1.112 paf 1008: # undef YYMAXDEPTH
1.1 parser 1009: #endif
1010:
1011: #ifndef YYMAXDEPTH
1.112 paf 1012: # define YYMAXDEPTH 10000
1.1 parser 1013: #endif
1.112 paf 1014:
1.1 parser 1015:
1016:
1.112 paf 1017: #if YYERROR_VERBOSE
1018:
1019: # ifndef yystrlen
1020: # if defined (__GLIBC__) && defined (_STRING_H)
1021: # define yystrlen strlen
1022: # else
1023: /* Return the length of YYSTR. */
1024: static YYSIZE_T
1025: # if defined (__STDC__) || defined (__cplusplus)
1026: yystrlen (const char *yystr)
1027: # else
1028: yystrlen (yystr)
1029: const char *yystr;
1030: # endif
1031: {
1032: register const char *yys = yystr;
1033:
1034: while (*yys++ != '\0')
1035: continue;
1036:
1037: return yys - yystr - 1;
1038: }
1039: # endif
1040: # endif
1041:
1042: # ifndef yystpcpy
1043: # if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE)
1044: # define yystpcpy stpcpy
1045: # else
1046: /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
1047: YYDEST. */
1048: static char *
1049: # if defined (__STDC__) || defined (__cplusplus)
1050: yystpcpy (char *yydest, const char *yysrc)
1051: # else
1052: yystpcpy (yydest, yysrc)
1053: char *yydest;
1054: const char *yysrc;
1055: # endif
1056: {
1057: register char *yyd = yydest;
1058: register const char *yys = yysrc;
1059:
1060: while ((*yyd++ = *yys++) != '\0')
1061: continue;
1.105 paf 1062:
1.112 paf 1063: return yyd - 1;
1.105 paf 1064: }
1.112 paf 1065: # endif
1066: # endif
1067:
1068: #endif /* !YYERROR_VERBOSE */
1069:
1070:
1.105 paf 1071:
1.112 paf 1072: #if YYDEBUG
1073: /*--------------------------------.
1074: | Print this symbol on YYOUTPUT. |
1075: `--------------------------------*/
1.1 parser 1076:
1.112 paf 1077: #if defined (__STDC__) || defined (__cplusplus)
1.105 paf 1078: static void
1.112 paf 1079: yysymprint (FILE *yyoutput, int yytype, YYSTYPE *yyvaluep)
1080: #else
1081: static void
1082: yysymprint (yyoutput, yytype, yyvaluep)
1083: FILE *yyoutput;
1084: int yytype;
1085: YYSTYPE *yyvaluep;
1086: #endif
1.1 parser 1087: {
1.112 paf 1088: /* Pacify ``unused variable'' warnings. */
1089: (void) yyvaluep;
1090:
1091: if (yytype < YYNTOKENS)
1092: {
1093: YYFPRINTF (yyoutput, "token %s (", yytname[yytype]);
1094: # ifdef YYPRINT
1095: YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
1096: # endif
1097: }
1098: else
1099: YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]);
1.105 paf 1100:
1.112 paf 1101: switch (yytype)
1102: {
1103: default:
1104: break;
1105: }
1106: YYFPRINTF (yyoutput, ")");
1.1 parser 1107: }
1108:
1.112 paf 1109: #endif /* ! YYDEBUG */
1110: /*-----------------------------------------------.
1111: | Release the memory associated to this symbol. |
1112: `-----------------------------------------------*/
1113:
1114: #if defined (__STDC__) || defined (__cplusplus)
1115: static void
1116: yydestruct (int yytype, YYSTYPE *yyvaluep)
1117: #else
1118: static void
1119: yydestruct (yytype, yyvaluep)
1120: int yytype;
1121: YYSTYPE *yyvaluep;
1.1 parser 1122: #endif
1.112 paf 1123: {
1124: /* Pacify ``unused variable'' warnings. */
1125: (void) yyvaluep;
1126:
1127: switch (yytype)
1128: {
1129:
1130: default:
1131: break;
1132: }
1133: }
1.1 parser 1134:
1135:
1.112 paf 1136: /* Prevent warnings from -Wmissing-prototypes. */
1.1 parser 1137:
1138: #ifdef YYPARSE_PARAM
1.112 paf 1139: # if defined (__STDC__) || defined (__cplusplus)
1140: int yyparse (void *YYPARSE_PARAM);
1141: # else
1142: int yyparse ();
1143: # endif
1144: #else /* ! YYPARSE_PARAM */
1145: #if defined (__STDC__) || defined (__cplusplus)
1146: int yyparse (void);
1147: #else
1148: int yyparse ();
1149: #endif
1150: #endif /* ! YYPARSE_PARAM */
1151:
1152:
1153:
1154:
1155:
1156:
1157: /*----------.
1158: | yyparse. |
1159: `----------*/
1.1 parser 1160:
1161: #ifdef YYPARSE_PARAM
1.112 paf 1162: # if defined (__STDC__) || defined (__cplusplus)
1163: int yyparse (void *YYPARSE_PARAM)
1164: # else
1165: int yyparse (YYPARSE_PARAM)
1166: void *YYPARSE_PARAM;
1167: # endif
1168: #else /* ! YYPARSE_PARAM */
1169: #if defined (__STDC__) || defined (__cplusplus)
1170: int
1171: yyparse (void)
1.1 parser 1172: #else
1.112 paf 1173: int
1174: yyparse ()
1175:
1.1 parser 1176: #endif
1177: #endif
1.112 paf 1178: {
1179: /* The lookahead symbol. */
1180: int yychar;
1181:
1182: /* The semantic value of the lookahead symbol. */
1183: YYSTYPE yylval;
1184:
1185: /* Number of syntax errors so far. */
1186: int yynerrs;
1.109 paf 1187:
1.1 parser 1188: register int yystate;
1189: register int yyn;
1.112 paf 1190: int yyresult;
1191: /* Number of tokens to shift before error messages enabled. */
1192: int yyerrstatus;
1193: /* Lookahead token as an internal (translated) token number. */
1194: int yytoken = 0;
1195:
1196: /* Three stacks and their tools:
1197: `yyss': related to states,
1198: `yyvs': related to semantic values,
1199: `yyls': related to locations.
1200:
1201: Refer to the stacks thru separate pointers, to allow yyoverflow
1202: to reallocate them elsewhere. */
1203:
1204: /* The state stack. */
1.114 misha 1205: short int yyssa[YYINITDEPTH];
1206: short int *yyss = yyssa;
1207: register short int *yyssp;
1.112 paf 1208:
1209: /* The semantic value stack. */
1210: YYSTYPE yyvsa[YYINITDEPTH];
1211: YYSTYPE *yyvs = yyvsa;
1.106 paf 1212: register YYSTYPE *yyvsp;
1.1 parser 1213:
1214:
1.109 paf 1215:
1.1 parser 1216: #define YYPOPSTACK (yyvsp--, yyssp--)
1217:
1.112 paf 1218: YYSIZE_T yystacksize = YYINITDEPTH;
1.1 parser 1219:
1.112 paf 1220: /* The variables used to return semantic value and location from the
1221: action routines. */
1222: YYSTYPE yyval;
1.1 parser 1223:
1224:
1.112 paf 1225: /* When reducing, the number of symbols on the RHS of the reduced
1226: rule. */
1.1 parser 1227: int yylen;
1228:
1.112 paf 1229: YYDPRINTF ((stderr, "Starting parse\n"));
1.1 parser 1230:
1231: yystate = 0;
1232: yyerrstatus = 0;
1233: yynerrs = 0;
1234: yychar = YYEMPTY; /* Cause a token to be read. */
1235:
1236: /* Initialize stack pointers.
1237: Waste one element of value and location stack
1238: so that they stay on the same level as the state stack.
1239: The wasted elements are never initialized. */
1240:
1.112 paf 1241: yyssp = yyss;
1.1 parser 1242: yyvsp = yyvs;
1243:
1.114 misha 1244:
1.112 paf 1245: goto yysetstate;
1246:
1247: /*------------------------------------------------------------.
1248: | yynewstate -- Push a new state, which is found in yystate. |
1249: `------------------------------------------------------------*/
1250: yynewstate:
1251: /* In all cases, when you get here, the value and location stacks
1252: have just been pushed. so pushing a state here evens the stacks.
1253: */
1254: yyssp++;
1.105 paf 1255:
1.112 paf 1256: yysetstate:
1257: *yyssp = yystate;
1.108 paf 1258:
1.112 paf 1259: if (yyss + yystacksize - 1 <= yyssp)
1.109 paf 1260: {
1.1 parser 1261: /* Get the current used size of the three stacks, in elements. */
1.112 paf 1262: YYSIZE_T yysize = yyssp - yyss + 1;
1.1 parser 1263:
1264: #ifdef yyoverflow
1.112 paf 1265: {
1266: /* Give user a chance to reallocate the stack. Use copies of
1267: these so that the &'s don't force the real ones into
1268: memory. */
1269: YYSTYPE *yyvs1 = yyvs;
1.114 misha 1270: short int *yyss1 = yyss;
1.112 paf 1271:
1272:
1273: /* Each stack pointer address is followed by the size of the
1274: data in use in that stack, in bytes. This used to be a
1275: conditional around just the two extra args, but that might
1276: be undefined if yyoverflow is a macro. */
1277: yyoverflow ("parser stack overflow",
1278: &yyss1, yysize * sizeof (*yyssp),
1279: &yyvs1, yysize * sizeof (*yyvsp),
1280:
1281: &yystacksize);
1282:
1283: yyss = yyss1;
1284: yyvs = yyvs1;
1285: }
1.1 parser 1286: #else /* no yyoverflow */
1.112 paf 1287: # ifndef YYSTACK_RELOCATE
1288: goto yyoverflowlab;
1289: # else
1.1 parser 1290: /* Extend the stack our own way. */
1.112 paf 1291: if (YYMAXDEPTH <= yystacksize)
1292: goto yyoverflowlab;
1.1 parser 1293: yystacksize *= 2;
1.112 paf 1294: if (YYMAXDEPTH < yystacksize)
1.1 parser 1295: yystacksize = YYMAXDEPTH;
1.112 paf 1296:
1297: {
1.114 misha 1298: short int *yyss1 = yyss;
1.112 paf 1299: union yyalloc *yyptr =
1300: (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
1301: if (! yyptr)
1302: goto yyoverflowlab;
1303: YYSTACK_RELOCATE (yyss);
1304: YYSTACK_RELOCATE (yyvs);
1305:
1306: # undef YYSTACK_RELOCATE
1307: if (yyss1 != yyssa)
1308: YYSTACK_FREE (yyss1);
1309: }
1310: # endif
1.1 parser 1311: #endif /* no yyoverflow */
1312:
1.112 paf 1313: yyssp = yyss + yysize - 1;
1314: yyvsp = yyvs + yysize - 1;
1315:
1.108 paf 1316:
1.112 paf 1317: YYDPRINTF ((stderr, "Stack size increased to %lu\n",
1318: (unsigned long int) yystacksize));
1.105 paf 1319:
1.112 paf 1320: if (yyss + yystacksize - 1 <= yyssp)
1.1 parser 1321: YYABORT;
1322: }
1323:
1.112 paf 1324: YYDPRINTF ((stderr, "Entering state %d\n", yystate));
1.1 parser 1325:
1326: goto yybackup;
1.112 paf 1327:
1328: /*-----------.
1329: | yybackup. |
1330: `-----------*/
1331: yybackup:
1.1 parser 1332:
1333: /* Do appropriate processing given the current state. */
1334: /* Read a lookahead token if we need one and don't already have one. */
1335: /* yyresume: */
1336:
1337: /* First try to decide what to do without reference to lookahead token. */
1338:
1339: yyn = yypact[yystate];
1.112 paf 1340: if (yyn == YYPACT_NINF)
1.1 parser 1341: goto yydefault;
1342:
1343: /* Not known => get a lookahead token if don't already have one. */
1344:
1.112 paf 1345: /* YYCHAR is either YYEMPTY or YYEOF or a valid lookahead symbol. */
1.1 parser 1346: if (yychar == YYEMPTY)
1347: {
1.112 paf 1348: YYDPRINTF ((stderr, "Reading a token: "));
1.1 parser 1349: yychar = YYLEX;
1350: }
1351:
1.112 paf 1352: if (yychar <= YYEOF)
1.1 parser 1353: {
1.112 paf 1354: yychar = yytoken = YYEOF;
1355: YYDPRINTF ((stderr, "Now at end of input.\n"));
1.1 parser 1356: }
1357: else
1358: {
1.112 paf 1359: yytoken = YYTRANSLATE (yychar);
1360: YYDSYMPRINTF ("Next token is", yytoken, &yylval, &yylloc);
1.1 parser 1361: }
1362:
1.112 paf 1363: /* If the proper action on seeing token YYTOKEN is to reduce or to
1364: detect an error, take that action. */
1365: yyn += yytoken;
1366: if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
1.1 parser 1367: goto yydefault;
1368: yyn = yytable[yyn];
1.112 paf 1369: if (yyn <= 0)
1.1 parser 1370: {
1.112 paf 1371: if (yyn == 0 || yyn == YYTABLE_NINF)
1.1 parser 1372: goto yyerrlab;
1373: yyn = -yyn;
1374: goto yyreduce;
1375: }
1376:
1377: if (yyn == YYFINAL)
1378: YYACCEPT;
1379:
1380: /* Shift the lookahead token. */
1.112 paf 1381: YYDPRINTF ((stderr, "Shifting token %s, ", yytname[yytoken]));
1.1 parser 1382:
1383: /* Discard the token being shifted unless it is eof. */
1384: if (yychar != YYEOF)
1385: yychar = YYEMPTY;
1386:
1387: *++yyvsp = yylval;
1388:
1.112 paf 1389:
1390: /* Count tokens shifted since error; after three, turn off error
1391: status. */
1392: if (yyerrstatus)
1393: yyerrstatus--;
1.1 parser 1394:
1395: yystate = yyn;
1396: goto yynewstate;
1397:
1.112 paf 1398:
1399: /*-----------------------------------------------------------.
1400: | yydefault -- do the default action for the current state. |
1401: `-----------------------------------------------------------*/
1.109 paf 1402: yydefault:
1.1 parser 1403: yyn = yydefact[yystate];
1404: if (yyn == 0)
1405: goto yyerrlab;
1.112 paf 1406: goto yyreduce;
1407:
1.105 paf 1408:
1.112 paf 1409: /*-----------------------------.
1410: | yyreduce -- Do a reduction. |
1411: `-----------------------------*/
1.1 parser 1412: yyreduce:
1.112 paf 1413: /* yyn is the number of a rule to reduce with. */
1.1 parser 1414: yylen = yyr2[yyn];
1.109 paf 1415:
1.112 paf 1416: /* If YYLEN is nonzero, implement the default value of the action:
1417: `$$ = $1'.
1.109 paf 1418:
1.112 paf 1419: Otherwise, the following line sets YYVAL to garbage.
1420: This behavior is undocumented and Bison
1421: users should not rely upon it. Assigning to YYVAL
1422: unconditionally makes the parser a bit smaller, and it avoids a
1423: GCC warning that YYVAL may be used uninitialized. */
1424: yyval = yyvsp[1-yylen];
1.106 paf 1425:
1.1 parser 1426:
1.112 paf 1427: YY_REDUCE_PRINT (yyn);
1428: switch (yyn)
1429: {
1430: case 2:
1.131 misha 1431: #line 132 "compile.y"
1.112 paf 1432: {
1.144 misha 1433: Method* method=new Method(Method::CT_ANY,
1.1 parser 1434: 0, 0, /*min, max numbered_params_count*/
1435: 0/*param_names*/, 0/*local_names*/,
1436: yyvsp[0]/*parser_code*/, 0/*native_code*/);
1.144 misha 1437: PC.cclass->set_method(PC.alias_method(main_method_name), method);
1.112 paf 1438: ;}
1439: break;
1440:
1441: case 9:
1.131 misha 1442: #line 147 "compile.y"
1.112 paf 1443: {
1.84 paf 1444: const String& command=*LA2S(*yyvsp[-2]);
1.1 parser 1445: YYSTYPE strings_code=yyvsp[0];
1.84 paf 1446: if(strings_code->count()<1*OPERATIONS_PER_OPVALUE) {
1.1 parser 1447: strcpy(PC.error, "@");
1448: strcat(PC.error, command.cstr());
1449: strcat(PC.error, " is empty");
1450: YYERROR;
1451: }
1452: if(command==CLASS_NAME) {
1.84 paf 1453: if(strings_code->count()==1*OPERATIONS_PER_OPVALUE) {
1.1 parser 1454: // new class' name
1.84 paf 1455: const String& name=*LA2S(*strings_code);
1.1 parser 1456: // creating the class
1.84 paf 1457: VStateless_class* cclass=new VClass;
1.119 misha 1458: PC.cclass_new=cclass;
1459: PC.cclass_new->set_name(name);
1.1 parser 1460: } else {
1.84 paf 1461: strcpy(PC.error, "@"CLASS_NAME" must contain only one line with class name (contains more then one)");
1.1 parser 1462: YYERROR;
1463: }
1464: } else if(command==USE_CONTROL_METHOD_NAME) {
1.84 paf 1465: for(size_t i=0; i<strings_code->count(); i+=OPERATIONS_PER_OPVALUE)
1466: PC.request.use_file(PC.request.main_class, *LA2S(*strings_code, i));
1.1 parser 1467: } else if(command==BASE_NAME) {
1.119 misha 1468: if(PC.append){
1469: strcpy(PC.error, "can't set base while appending methods to class '");
1470: strncat(PC.error, PC.cclass->name().cstr(), MAX_STRING/2);
1471: strcat(PC.error, "'");
1472: YYERROR;
1473: }
1474: PC.class_add();
1.59 paf 1475: if(PC.cclass->base_class()) { // already changed from default?
1.1 parser 1476: strcpy(PC.error, "class already have a base '");
1.119 misha 1477: strncat(PC.error, PC.cclass->base_class()->name().cstr(), MAX_STRING/2);
1.1 parser 1478: strcat(PC.error, "'");
1479: YYERROR;
1480: }
1.84 paf 1481: if(strings_code->count()==1*OPERATIONS_PER_OPVALUE) {
1482: const String& base_name=*LA2S(*strings_code);
1.145 misha 1483: if(Value* base_class_value=PC.request.get_class(base_name)) {
1.84 paf 1484: // @CLASS == @BASE sanity check
1485: if(VStateless_class *base_class=base_class_value->get_class()) {
1486: if(PC.cclass==base_class) {
1487: strcpy(PC.error, "@"CLASS_NAME" equals @"BASE_NAME);
1488: YYERROR;
1489: }
1490: PC.cclass->get_class()->set_base(base_class);
1491: } else { // they asked to derive from a class without methods ['env' & co]
1492: strcpy(PC.error, base_name.cstr());
1493: strcat(PC.error, ": you can not derive from this class in @"BASE_NAME);
1494: YYERROR;
1495: }
1496: } else {
1.1 parser 1497: strcpy(PC.error, base_name.cstr());
1498: strcat(PC.error, ": undefined class in @"BASE_NAME);
1499: YYERROR;
1500: }
1501: } else {
1502: strcpy(PC.error, "@"BASE_NAME" must contain sole name");
1503: YYERROR;
1504: }
1.116 misha 1505: } else if(command==OPTIONS_CONTROL_METHOD_NAME) {
1.118 misha 1506: for(size_t i=0; i<strings_code->count(); i+=OPERATIONS_PER_OPVALUE) {
1507: const String& option=*LA2S(*strings_code, i);
1.119 misha 1508: if(option==OPTION_ALL_VARS_LOCAL_NAME){
1509: PC.set_all_vars_local();
1.123 misha 1510: } else if(option==OPTION_PARTIAL_CLASS){
1511: if(PC.cclass_new){
1512: if(VStateless_class* existed=PC.get_existed_class(PC.cclass_new)){
1513: if(!PC.reuse_existed_class(existed)){
1514: strcpy(PC.error, "can't append methods to '");
1515: strncat(PC.error, PC.cclass_new->name().cstr(), MAX_STRING/2);
1516: strcat(PC.error, "' - the class wasn't marked as partial");
1517: YYERROR;
1518: }
1.119 misha 1519: } else {
1.123 misha 1520: // mark new class as partial. we can add methods to it later.
1521: PC.cclass_new->set_partial();
1.119 misha 1522: }
1.123 misha 1523: } else {
1524: strcpy(PC.error, "'"OPTION_PARTIAL_CLASS"' option should be used straight after @"CLASS_NAME);
1.119 misha 1525: YYERROR;
1526: }
1.118 misha 1527: } else {
1.119 misha 1528: strcpy(PC.error, "'");
1529: strncat(PC.error, option.cstr(), MAX_STRING/2);
1530: strcat(PC.error, "' invalid option. valid options are "
1.123 misha 1531: "'"OPTION_PARTIAL_CLASS"' and '"OPTION_ALL_VARS_LOCAL_NAME"'");
1.118 misha 1532: YYERROR;
1.116 misha 1533: }
1534: }
1.1 parser 1535: } else {
1536: strcpy(PC.error, "'");
1537: strncat(PC.error, command.cstr(), MAX_STRING/2);
1538: strcat(PC.error, "' invalid special name. valid names are "
1.116 misha 1539: "'"CLASS_NAME"', '"USE_CONTROL_METHOD_NAME"', '"BASE_NAME"' and '"OPTIONS_CONTROL_METHOD_NAME"'.");
1.1 parser 1540: YYERROR;
1541: }
1.112 paf 1542: ;}
1543: break;
1544:
1545: case 13:
1.131 misha 1546: #line 248 "compile.y"
1.112 paf 1547: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1548: break;
1549:
1550: case 17:
1.131 misha 1551: #line 252 "compile.y"
1.112 paf 1552: {
1.119 misha 1553: PC.class_add();
1.96 paf 1554: PC.explicit_result=false;
1.1 parser 1555:
1.115 misha 1556: YYSTYPE params_names_code=yyvsp[-3];
1.84 paf 1557: ArrayString* params_names=0;
1558: if(int size=params_names_code->count()) {
1559: params_names=new ArrayString;
1560: for(int i=0; i<size; i+=OPERATIONS_PER_OPVALUE)
1561: *params_names+=LA2S(*params_names_code, i);
1.1 parser 1562: }
1563:
1.115 misha 1564: YYSTYPE locals_names_code=yyvsp[-2];
1.84 paf 1565: ArrayString* locals_names=0;
1.116 misha 1566: bool all_vars_local=false;
1.84 paf 1567: if(int size=locals_names_code->count()) {
1568: locals_names=new ArrayString;
1.96 paf 1569: for(int i=0; i<size; i+=OPERATIONS_PER_OPVALUE) {
1570: const String* local_name=LA2S(*locals_names_code, i);
1571: if(*local_name==RESULT_VAR_NAME)
1572: PC.explicit_result=true;
1.119 misha 1573: else if(*local_name==OPTION_ALL_VARS_LOCAL_NAME)
1.116 misha 1574: all_vars_local=true;
1.96 paf 1575: else
1576: *locals_names+=local_name;
1577: }
1.1 parser 1578: }
1.124 misha 1579: if(!all_vars_local && PC.cclass && PC.cclass->is_vars_local())
1.116 misha 1580: all_vars_local=true;
1.1 parser 1581:
1.96 paf 1582: Method* method=new Method(
1.84 paf 1583: //name,
1.1 parser 1584: Method::CT_ANY,
1585: 0, 0/*min,max numbered_params_count*/,
1586: params_names, locals_names,
1.116 misha 1587: 0/*to be filled later in next {} */, 0, all_vars_local);
1.114 misha 1588:
1.96 paf 1589: *reinterpret_cast<Method**>(&yyval)=method;
1590:
1591: // todo: check [][;result;]
1.112 paf 1592: ;}
1593: break;
1594:
1.115 misha 1595: case 18:
1.131 misha 1596: #line 292 "compile.y"
1.115 misha 1597: {
1.144 misha 1598: Method* method=reinterpret_cast<Method*>(yyvsp[-1]);
1.124 misha 1599: // fill in the code
1.144 misha 1600: method->parser_code=yyvsp[0];
1.124 misha 1601:
1602: // register in class
1603: const String& name=*LA2S(*yyvsp[-6]);
1.144 misha 1604: PC.cclass->set_method(PC.alias_method(name), method);
1.115 misha 1605: ;}
1606: break;
1607:
1608: case 21:
1.131 misha 1609: #line 303 "compile.y"
1.114 misha 1610: {yyval=yyvsp[-1];}
1.112 paf 1611: break;
1612:
1.115 misha 1613: case 25:
1.131 misha 1614: #line 305 "compile.y"
1.112 paf 1615: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]) ;}
1616: break;
1617:
1.115 misha 1618: case 31:
1.131 misha 1619: #line 313 "compile.y"
1.112 paf 1620: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1621: break;
1622:
1.115 misha 1623: case 37:
1.131 misha 1624: #line 319 "compile.y"
1.112 paf 1625: {
1.131 misha 1626: yyval=N();
1627: YYSTYPE code=yyvsp[0];
1.140 misha 1628: size_t count=code->count();
1.138 misha 1629:
1.128 misha 1630: #ifdef OPTIMIZE_BYTECODE_GET_ELEMENT
1.140 misha 1631: if(
1632: count!=3
1633: || !maybe_change_first_opcode(*code, OP::OP_VALUE__GET_ELEMENT, /*=>*/OP::OP_VALUE__GET_ELEMENT__WRITE)
1634: )
1.131 misha 1635: #endif
1.140 misha 1636:
1.138 misha 1637: #ifdef OPTIMIZE_BYTECODE_GET_SELF_ELEMENT
1.140 misha 1638: if(
1639: count!=3
1640: || !maybe_change_first_opcode(*code, OP::OP_WITH_SELF__VALUE__GET_ELEMENT, /*=>*/OP::OP_WITH_SELF__VALUE__GET_ELEMENT__WRITE)
1641: )
1.138 misha 1642: #endif
1643:
1.132 misha 1644: #ifdef OPTIMIZE_BYTECODE_GET_OBJECT_ELEMENT
1.140 misha 1645: if(
1646: count!=5
1647: || !maybe_change_first_opcode(*code, OP::OP_GET_OBJECT_ELEMENT, /*=>*/OP::OP_GET_OBJECT_ELEMENT__WRITE)
1648: )
1.128 misha 1649: #endif
1.132 misha 1650:
1651: #ifdef OPTIMIZE_BYTECODE_GET_OBJECT_VAR_ELEMENT
1.140 misha 1652: if(
1653: count!=5
1654: || !maybe_change_first_opcode(*code, OP::OP_GET_OBJECT_VAR_ELEMENT, /*=>*/OP::OP_GET_OBJECT_VAR_ELEMENT__WRITE)
1655: )
1.131 misha 1656: #endif
1.140 misha 1657: {
1658: changetail_or_append(*code,
1659: OP::OP_GET_ELEMENT, false, /*=>*/OP::OP_GET_ELEMENT__WRITE,
1660: /*or */OP::OP_WRITE_VALUE
1661: ); /* value=pop; wcontext.write(value) */
1.139 misha 1662: }
1.140 misha 1663:
1.131 misha 1664: P(*yyval, *code);
1.112 paf 1665: ;}
1666: break;
1667:
1.115 misha 1668: case 38:
1.140 misha 1669: #line 360 "compile.y"
1.112 paf 1670: { yyval=yyvsp[0] ;}
1671: break;
1672:
1.115 misha 1673: case 41:
1.140 misha 1674: #line 362 "compile.y"
1.112 paf 1675: { yyval=yyvsp[-1] ;}
1676: break;
1677:
1.115 misha 1678: case 44:
1.140 misha 1679: #line 366 "compile.y"
1.112 paf 1680: {
1.84 paf 1681: yyval=N();
1.131 misha 1682: YYSTYPE diving_code=yyvsp[0];
1.132 misha 1683: size_t count=diving_code->count();
1.140 misha 1684:
1685: if(maybe_make_self(*yyval, *diving_code, count)) {
1686: // $self.
1687: } else
1.132 misha 1688:
1689: #ifdef OPTIMIZE_BYTECODE_GET_OBJECT_ELEMENT
1.140 misha 1690: if(maybe_make_get_object_element(*yyval, *diving_code, count)){
1.138 misha 1691: // optimization for $object.field + ^object.method[
1.140 misha 1692: } else
1.131 misha 1693: #endif
1.132 misha 1694:
1695: #ifdef OPTIMIZE_BYTECODE_GET_OBJECT_VAR_ELEMENT
1.140 misha 1696: if(maybe_make_get_object_var_element(*yyval, *diving_code, count)){
1.138 misha 1697: // optimization for $object.$var
1.140 misha 1698: } else
1.131 misha 1699: #endif
1.132 misha 1700:
1701: #ifdef OPTIMIZE_BYTECODE_GET_ELEMENT
1.141 misha 1702: if(
1703: count>=4
1704: && (*diving_code)[0].code==OP::OP_VALUE
1705: && (*diving_code)[3].code==OP::OP_GET_ELEMENT
1706: ){
1707: // optimization
1.132 misha 1708: O(*yyval,
1.140 misha 1709: (PC.in_call_value && count==4)
1.132 misha 1710: ? OP::OP_VALUE__GET_ELEMENT_OR_OPERATOR // ^object[ : OP_VALUE+origin+string+OP_GET_ELEMENT => OP_VALUE__GET_ELEMENT_OR_OPERATOR+origin+string
1711: : OP::OP_VALUE__GET_ELEMENT // $object : OP_VALUE+origin+string+OP_GET_ELEMENT => OP_VALUE__GET_ELEMENT+origin+string
1712: );
1713: P(*yyval, *diving_code, 1/*offset*/, 2/*limit*/); // copy origin+value
1.140 misha 1714: if(count>4)
1715: P(*yyval, *diving_code, 4); // copy tail
1.132 misha 1716: } else {
1717: O(*yyval, OP::OP_WITH_READ); /* stack: starting context */
1718: P(*yyval, *diving_code);
1719: }
1.126 misha 1720: #else
1.140 misha 1721: {
1.122 misha 1722: O(*yyval, OP::OP_WITH_READ); /* stack: starting context */
1.37 paf 1723:
1.131 misha 1724: // ^if OP_ELEMENT => ^if OP_ELEMENT_OR_OPERATOR
1725: // optimized OP_VALUE+origin+string+OP_GET_ELEMENT. => OP_VALUE+origin+string+OP_GET_ELEMENT_OR_OPERATOR.
1.132 misha 1726: if(PC.in_call_value && count==4)
1727: diving_code->put(count-1, OP::OP_GET_ELEMENT_OR_OPERATOR);
1.84 paf 1728: P(*yyval, *diving_code);
1.132 misha 1729: }
1.126 misha 1730: #endif
1.1 parser 1731: /* diving code; stack: current context */
1.112 paf 1732: ;}
1733: break;
1734:
1.115 misha 1735: case 45:
1.141 misha 1736: #line 419 "compile.y"
1.112 paf 1737: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1738: break;
1739:
1.115 misha 1740: case 47:
1.141 misha 1741: #line 420 "compile.y"
1.112 paf 1742: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1743: break;
1744:
1.115 misha 1745: case 48:
1.141 misha 1746: #line 424 "compile.y"
1.112 paf 1747: {
1.134 misha 1748: yyval=N();
1.137 misha 1749: #ifdef OPTIMIZE_BYTECODE_CONSTRUCT
1750: if(maybe_optimize_construct(*yyval, *yyvsp[-1], *yyvsp[0])){
1.139 misha 1751: // $a(expr), $.a(expr), $a[value], $.a[value], $self.a[value], $self.a(expr)
1.134 misha 1752: } else
1753: #endif
1754: {
1755: P(*yyval, *yyvsp[-1]); /* stack: context,name */
1756: P(*yyval, *yyvsp[0]); /* stack: context,name,constructor_value */
1757: }
1.112 paf 1758: ;}
1759: break;
1760:
1.115 misha 1761: case 52:
1.141 misha 1762: #line 440 "compile.y"
1.112 paf 1763: {
1.84 paf 1764: yyval=N();
1.131 misha 1765: YYSTYPE diving_code=yyvsp[0];
1.140 misha 1766: size_t count=diving_code->count();
1767:
1768: if(maybe_make_self(*yyval, *diving_code, count)) {
1769: // $self.
1770: } else
1771: #ifdef OPTIMIZE_BYTECODE_GET_ELEMENT
1772: if(
1773: count>=4
1774: && (*diving_code)[0].code==OP::OP_VALUE
1775: && (*diving_code)[3].code==OP::OP_GET_ELEMENT
1776: ){
1777: O(*yyval, OP::OP_WITH_ROOT__VALUE__GET_ELEMENT);
1778: P(*yyval, *diving_code, 1/*offset*/, 2/*limit*/); // copy origin+value
1779: if(count>4)
1780: P(*yyval, *diving_code, 4); // tail
1781: } else
1782: #endif
1783: {
1.122 misha 1784: O(*yyval, OP::OP_WITH_ROOT); /* stack: starting context */
1.84 paf 1785: P(*yyval, *diving_code);
1.1 parser 1786: }
1787: /* diving code; stack: current context */
1.112 paf 1788: ;}
1789: break;
1790:
1.115 misha 1791: case 53:
1.141 misha 1792: #line 466 "compile.y"
1.112 paf 1793: {
1.84 paf 1794: yyval=N();
1.122 misha 1795: O(*yyval, OP::OP_WITH_WRITE); /* stack: starting context */
1.84 paf 1796: P(*yyval, *yyvsp[0]); /* diving code; stack: context,name */
1.112 paf 1797: ;}
1798: break;
1799:
1.115 misha 1800: case 54:
1.141 misha 1801: #line 471 "compile.y"
1.112 paf 1802: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1803: break;
1804:
1.115 misha 1805: case 58:
1.141 misha 1806: #line 478 "compile.y"
1.112 paf 1807: {
1.100 paf 1808: // allow $result_or_other_variable[ letters here any time ]
1.99 paf 1809: *reinterpret_cast<bool*>(&yyval)=PC.explicit_result; PC.explicit_result=false;
1.112 paf 1810: ;}
1811: break;
1812:
1.115 misha 1813: case 59:
1.141 misha 1814: #line 481 "compile.y"
1.112 paf 1815: {
1.106 paf 1816: PC.explicit_result=*reinterpret_cast<bool*>(&yyvsp[-1]);
1.112 paf 1817: ;}
1818: break;
1819:
1.115 misha 1820: case 60:
1.141 misha 1821: #line 483 "compile.y"
1.112 paf 1822: {
1.1 parser 1823: // stack: context, name
1.99 paf 1824: yyval=yyvsp[-2]; // stack: context, name, value
1.122 misha 1825: O(*yyval, OP::OP_CONSTRUCT_VALUE); /* value=pop; name=pop; context=pop; construct(context,name,value) */
1.112 paf 1826: ;}
1827: break;
1828:
1.115 misha 1829: case 61:
1.141 misha 1830: #line 489 "compile.y"
1.112 paf 1831: {
1.84 paf 1832: yyval=N();
1.122 misha 1833: O(*yyval, OP::OP_PREPARE_TO_EXPRESSION);
1.1 parser 1834: // stack: context, name
1.84 paf 1835: P(*yyval, *yyvsp[-1]); // stack: context, name, value
1.122 misha 1836: O(*yyval, OP::OP_CONSTRUCT_EXPR); /* value=pop->as_expr_result; name=pop; context=pop; construct(context,name,value) */
1.112 paf 1837: ;}
1838: break;
1839:
1.115 misha 1840: case 62:
1.141 misha 1841: #line 497 "compile.y"
1.112 paf 1842: {
1.1 parser 1843: // stack: context, name
1.84 paf 1844: yyval=N();
1.122 misha 1845: OA(*yyval, OP::OP_CURLY_CODE__CONSTRUCT, yyvsp[-1]); /* code=pop; name=pop; context=pop; construct(context,name,junction(code)) */
1.112 paf 1846: ;}
1847: break;
1848:
1.115 misha 1849: case 66:
1.141 misha 1850: #line 508 "compile.y"
1.112 paf 1851: {
1.84 paf 1852: yyval=N();
1.122 misha 1853: OA(*yyval, OP::OP_OBJECT_POOL, yyvsp[0]); /* stack: empty write context */
1.47 paf 1854: /* some code that writes to that context */
1855: /* context=pop; stack: context.value() */
1.112 paf 1856: ;}
1857: break;
1858:
1.115 misha 1859: case 69:
1.141 misha 1860: #line 515 "compile.y"
1.112 paf 1861: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1862: break;
1863:
1.115 misha 1864: case 70:
1.141 misha 1865: #line 519 "compile.y"
1.112 paf 1866: {
1.131 misha 1867: #ifdef OPTIMIZE_BYTECODE_CUT_REM_OPERATOR
1868: if((*yyvsp[0]).count())
1869: #endif
1870: {
1871: yyval=yyvsp[0]; /* stack: value */
1.142 misha 1872: if(!maybe_change_first_opcode(*yyval, OP::OP_CONSTRUCT_OBJECT, /*=>*/OP::OP_CONSTRUCT_OBJECT__WRITE))
1873: changetail_or_append(*yyval,
1874: OP::OP_CALL, true, /*=>*/ OP::OP_CALL__WRITE,
1875: /*or */OP::OP_WRITE_VALUE); /* value=pop; wcontext.write(value) */
1.131 misha 1876: }
1.112 paf 1877: ;}
1878: break;
1879:
1.115 misha 1880: case 71:
1.143 misha 1881: #line 531 "compile.y"
1.112 paf 1882: {
1.39 paf 1883: PC.in_call_value=true;
1.112 paf 1884: ;}
1885: break;
1886:
1.115 misha 1887: case 72:
1.143 misha 1888: #line 534 "compile.y"
1.112 paf 1889: {
1.39 paf 1890: PC.in_call_value=false;
1.112 paf 1891: ;}
1892: break;
1893:
1.115 misha 1894: case 73:
1.143 misha 1895: #line 537 "compile.y"
1.112 paf 1896: { /* ^field.$method{vasya} */
1.131 misha 1897: #ifdef OPTIMIZE_BYTECODE_CUT_REM_OPERATOR
1.135 misha 1898: #ifdef OPTIMIZE_BYTECODE_GET_ELEMENT
1.131 misha 1899: const String* operator_name=LA2S(*yyvsp[-3], 0, OP::OP_VALUE__GET_ELEMENT_OR_OPERATOR);
1.135 misha 1900: #else
1901: const String* operator_name=LA2S(*yyvsp[-3], 1);
1902: #endif
1.142 misha 1903: if(operator_name && *operator_name==REM_OPERATOR_NAME){
1.131 misha 1904: yyval=N();
1905: } else
1906: #endif
1907: {
1908: YYSTYPE params_code=yyvsp[-1];
1909: if(params_code->count()==3) { // probably [] case. [OP::OP_VALUE+origin+Void]
1910: if(Value* value=LA2V(*params_code)) // it is OP_VALUE+origin+value?
1911: if(value->is_void()) // value is VVoid?
1912: params_code=0; // ^zzz[] case. don't append lone empty param.
1913: }
1914: /* stack: context, method_junction */
1.142 misha 1915:
1916: YYSTYPE var_code=yyvsp[-3];
1917: if(
1918: var_code->count()==8
1919: && (*var_code)[0].code==OP::OP_VALUE__GET_CLASS
1920: && (*var_code)[3].code==OP::OP_PREPARE_TO_CONSTRUCT_OBJECT
1921: && (*var_code)[4].code==OP::OP_VALUE
1922: && (*var_code)[7].code==OP::OP_GET_ELEMENT
1923: ){
1924: yyval=N();
1925: O(*yyval, OP::OP_CONSTRUCT_OBJECT);
1926: P(*yyval, *var_code, 1/*offset*/, 2/*limit*/); // class name
1927: P(*yyval, *var_code, 5/*offset*/, 2/*limit*/); // constructor name
1928: OA(*yyval, params_code);
1929: } else
1930: {
1931: yyval=var_code; /* with_xxx,diving code; stack: context,method_junction */
1932: OA(*yyval, OP::OP_CALL, params_code); // method_frame=make frame(pop junction); ncontext=pop; call(ncontext,method_frame) stack: value
1933: }
1.131 misha 1934: }
1.112 paf 1935: ;}
1936: break;
1937:
1.115 misha 1938: case 76:
1.143 misha 1939: #line 580 "compile.y"
1.112 paf 1940: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
1941: break;
1942:
1.115 misha 1943: case 80:
1.143 misha 1944: #line 586 "compile.y"
1.112 paf 1945: {
1.100 paf 1946: // allow ^call[ letters here any time ]
1.98 paf 1947: *reinterpret_cast<bool*>(&yyval)=PC.explicit_result; PC.explicit_result=false;
1.112 paf 1948: ;}
1949: break;
1950:
1.115 misha 1951: case 81:
1.143 misha 1952: #line 589 "compile.y"
1.112 paf 1953: {
1.106 paf 1954: PC.explicit_result=*reinterpret_cast<bool*>(&yyvsp[-1]);
1.112 paf 1955: ;}
1956: break;
1957:
1.115 misha 1958: case 82:
1.143 misha 1959: #line 591 "compile.y"
1.112 paf 1960: {yyval=yyvsp[-2];}
1961: break;
1962:
1.115 misha 1963: case 83:
1.143 misha 1964: #line 592 "compile.y"
1.112 paf 1965: {yyval=yyvsp[-1];}
1966: break;
1967:
1.115 misha 1968: case 84:
1.143 misha 1969: #line 593 "compile.y"
1.112 paf 1970: {yyval=yyvsp[-1];}
1971: break;
1972:
1.115 misha 1973: case 86:
1.143 misha 1974: #line 596 "compile.y"
1.112 paf 1975: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]) ;}
1976: break;
1977:
1.115 misha 1978: case 88:
1.143 misha 1979: #line 600 "compile.y"
1.112 paf 1980: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]) ;}
1981: break;
1982:
1.115 misha 1983: case 90:
1.143 misha 1984: #line 604 "compile.y"
1.112 paf 1985: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]) ;}
1986: break;
1987:
1.115 misha 1988: case 91:
1.143 misha 1989: #line 606 "compile.y"
1.112 paf 1990: {
1.1 parser 1991: yyval=yyvsp[0];
1.112 paf 1992: ;}
1993: break;
1994:
1.115 misha 1995: case 92:
1.143 misha 1996: #line 609 "compile.y"
1.112 paf 1997: {
1.104 paf 1998: YYSTYPE expr_code=yyvsp[0];
1.106 paf 1999: if(expr_code->count()==3
1.127 misha 2000: && (*expr_code)[0].code==OP::OP_VALUE) { // optimizing (double/bool/incidently 'string' too) case. [OP::OP_VALUE+origin+Double]. no evaluating
1.104 paf 2001: yyval=expr_code;
2002: } else {
1.131 misha 2003: YYSTYPE code=N();
1.122 misha 2004: O(*code, OP::OP_PREPARE_TO_EXPRESSION);
1.104 paf 2005: P(*code, *expr_code);
1.122 misha 2006: O(*code, OP::OP_WRITE_EXPR_RESULT);
1.104 paf 2007: yyval=N();
1.122 misha 2008: OA(*yyval, OP::OP_EXPR_CODE__STORE_PARAM, code);
1.104 paf 2009: }
1.112 paf 2010: ;}
2011: break;
2012:
1.115 misha 2013: case 93:
1.143 misha 2014: #line 623 "compile.y"
1.112 paf 2015: {
1.84 paf 2016: yyval=N();
1.122 misha 2017: OA(*yyval, OP::OP_CURLY_CODE__STORE_PARAM, yyvsp[0]);
1.112 paf 2018: ;}
2019: break;
2020:
1.115 misha 2021: case 98:
1.143 misha 2022: #line 635 "compile.y"
1.112 paf 2023: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
2024: break;
2025:
1.115 misha 2026: case 100:
1.143 misha 2027: #line 637 "compile.y"
1.112 paf 2028: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
2029: break;
2030:
1.115 misha 2031: case 102:
1.143 misha 2032: #line 639 "compile.y"
1.112 paf 2033: {
1.33 paf 2034: // we know that name_advance1 not called from ^xxx context
2035: // so we'll not check for operator call possibility as we do in name_advance2
2036:
1.1 parser 2037: /* stack: context */
2038: yyval=yyvsp[0]; /* stack: context,name */
1.122 misha 2039: O(*yyval, OP::OP_GET_ELEMENT); /* name=pop; context=pop; stack: context.get_element(name) */
1.112 paf 2040: ;}
2041: break;
2042:
1.115 misha 2043: case 103:
1.143 misha 2044: #line 647 "compile.y"
1.112 paf 2045: {
1.1 parser 2046: /* stack: context */
2047: yyval=yyvsp[0]; /* stack: context,name */
1.122 misha 2048: O(*yyval, OP::OP_GET_ELEMENT); /* name=pop; context=pop; stack: context.get_element(name) */
1.112 paf 2049: ;}
2050: break;
2051:
1.115 misha 2052: case 109:
1.143 misha 2053: #line 660 "compile.y"
1.112 paf 2054: {
1.1 parser 2055: yyval=yyvsp[0];
1.122 misha 2056: O(*yyval, OP::OP_GET_ELEMENT);
1.112 paf 2057: ;}
2058: break;
2059:
1.115 misha 2060: case 110:
1.143 misha 2061: #line 664 "compile.y"
1.112 paf 2062: {
1.131 misha 2063: YYSTYPE code;
1.47 paf 2064: {
1.84 paf 2065: change_string_literal_to_write_string_literal(*(code=yyvsp[-1]));
2066: P(*code, *yyvsp[0]);
1.47 paf 2067: }
1.84 paf 2068: yyval=N();
1.122 misha 2069: OA(*yyval, OP::OP_STRING_POOL, code);
1.112 paf 2070: ;}
2071: break;
2072:
1.115 misha 2073: case 111:
1.143 misha 2074: #line 673 "compile.y"
1.112 paf 2075: {
1.100 paf 2076: // allow $result_or_other_variable[ letters here any time ]
2077: *reinterpret_cast<bool*>(&yyval)=PC.explicit_result; PC.explicit_result=false;
1.112 paf 2078: ;}
2079: break;
2080:
1.115 misha 2081: case 112:
1.143 misha 2082: #line 676 "compile.y"
1.112 paf 2083: {
1.101 paf 2084: PC.explicit_result=*reinterpret_cast<bool*>(&yyvsp[-1]);
1.112 paf 2085: ;}
2086: break;
2087:
1.115 misha 2088: case 113:
1.143 misha 2089: #line 678 "compile.y"
1.112 paf 2090: {
1.84 paf 2091: yyval=N();
1.122 misha 2092: OA(*yyval, OP::OP_OBJECT_POOL, yyvsp[-2]); /* stack: empty write context */
1.47 paf 2093: /* some code that writes to that context */
2094: /* context=pop; stack: context.value() */
1.112 paf 2095: ;}
2096: break;
2097:
1.115 misha 2098: case 114:
1.143 misha 2099: #line 684 "compile.y"
1.112 paf 2100: {
1.84 paf 2101: yyval=N();
1.122 misha 2102: O(*yyval, OP::OP_WITH_READ);
1.84 paf 2103: P(*yyval, *yyvsp[0]);
1.112 paf 2104: ;}
2105: break;
2106:
1.115 misha 2107: case 116:
1.143 misha 2108: #line 689 "compile.y"
1.112 paf 2109: { yyval=yyvsp[-1]; P(*yyval, *yyvsp[0]) ;}
2110: break;
2111:
1.115 misha 2112: case 117:
1.143 misha 2113: #line 690 "compile.y"
1.112 paf 2114: {
1.1 parser 2115: yyval=yyvsp[0];
1.122 misha 2116: O(*yyval, OP::OP_GET_ELEMENT__WRITE);
1.112 paf 2117: ;}
2118: break;
2119:
1.115 misha 2120: case 120:
1.143 misha 2121: #line 699 "compile.y"
1.112 paf 2122: {
1.1 parser 2123: yyval=yyvsp[-1]; // stack: class name string
1.84 paf 2124: if(*LA2S(*yyval) == BASE_NAME) { // pseudo BASE class
2125: if(VStateless_class* base=PC.cclass->base_class()) {
2126: change_string_literal_value(*yyval, base->name());
1.61 paf 2127: } else {
2128: strcpy(PC.error, "no base class declared");
2129: YYERROR;
2130: }
2131: }
1.131 misha 2132: // optimized OP_VALUE+origin+string+OP_GET_CLASS => OP_VALUE__GET_CLASS+origin+string
1.138 misha 2133: maybe_change_first_opcode(*yyval, OP::OP_VALUE, OP::OP_VALUE__GET_CLASS)
1.112 paf 2134: ;}
2135: break;
2136:
1.115 misha 2137: case 121:
1.143 misha 2138: #line 716 "compile.y"
1.112 paf 2139: {
1.1 parser 2140: yyval=yyvsp[-1];
1.39 paf 2141: if(!PC.in_call_value) {
1.1 parser 2142: strcpy(PC.error, ":: not allowed here");
2143: YYERROR;
2144: }
1.122 misha 2145: O(*yyval, OP::OP_PREPARE_TO_CONSTRUCT_OBJECT);
1.112 paf 2146: ;}
2147: break;
2148:
1.115 misha 2149: case 128:
1.143 misha 2150: #line 735 "compile.y"
1.114 misha 2151: { yyval = yyvsp[-1] ;}
2152: break;
2153:
1.115 misha 2154: case 129:
1.143 misha 2155: #line 736 "compile.y"
1.112 paf 2156: { yyval = yyvsp[-1] ;}
2157: break;
2158:
1.115 misha 2159: case 130:
1.143 misha 2160: #line 737 "compile.y"
1.114 misha 2161: { yyval = yyvsp[-1]; ;}
1.112 paf 2162: break;
2163:
1.115 misha 2164: case 131:
1.143 misha 2165: #line 739 "compile.y"
1.122 misha 2166: { yyval=yyvsp[0]; O(*yyval, OP::OP_NEG) ;}
1.112 paf 2167: break;
2168:
1.115 misha 2169: case 132:
1.143 misha 2170: #line 740 "compile.y"
1.114 misha 2171: { yyval=yyvsp[0] ;}
1.112 paf 2172: break;
2173:
1.115 misha 2174: case 133:
1.143 misha 2175: #line 741 "compile.y"
1.122 misha 2176: { yyval=yyvsp[0]; O(*yyval, OP::OP_INV) ;}
1.112 paf 2177: break;
2178:
1.115 misha 2179: case 134:
1.143 misha 2180: #line 742 "compile.y"
1.122 misha 2181: { yyval=yyvsp[0]; O(*yyval, OP::OP_NOT) ;}
1.112 paf 2182: break;
2183:
1.115 misha 2184: case 135:
1.143 misha 2185: #line 743 "compile.y"
1.122 misha 2186: { yyval=yyvsp[0]; O(*yyval, OP::OP_DEF) ;}
1.112 paf 2187: break;
2188:
1.115 misha 2189: case 136:
1.143 misha 2190: #line 744 "compile.y"
1.122 misha 2191: { yyval=yyvsp[0]; O(*yyval, OP::OP_IN) ;}
1.112 paf 2192: break;
2193:
1.115 misha 2194: case 137:
1.143 misha 2195: #line 745 "compile.y"
1.122 misha 2196: { yyval=yyvsp[0]; O(*yyval, OP::OP_FEXISTS) ;}
1.112 paf 2197: break;
2198:
1.115 misha 2199: case 138:
1.143 misha 2200: #line 746 "compile.y"
1.122 misha 2201: { yyval=yyvsp[0]; O(*yyval, OP::OP_DEXISTS) ;}
1.112 paf 2202: break;
2203:
1.115 misha 2204: case 139:
1.143 misha 2205: #line 748 "compile.y"
1.122 misha 2206: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_SUB) ;}
1.112 paf 2207: break;
2208:
1.115 misha 2209: case 140:
1.143 misha 2210: #line 749 "compile.y"
1.122 misha 2211: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_ADD) ;}
1.112 paf 2212: break;
2213:
1.115 misha 2214: case 141:
1.143 misha 2215: #line 750 "compile.y"
1.122 misha 2216: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_MUL) ;}
1.112 paf 2217: break;
2218:
1.115 misha 2219: case 142:
1.143 misha 2220: #line 751 "compile.y"
1.122 misha 2221: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_DIV) ;}
1.112 paf 2222: break;
2223:
1.115 misha 2224: case 143:
1.143 misha 2225: #line 752 "compile.y"
1.122 misha 2226: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_MOD) ;}
1.112 paf 2227: break;
2228:
1.115 misha 2229: case 144:
1.143 misha 2230: #line 753 "compile.y"
1.122 misha 2231: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_INTDIV) ;}
1.112 paf 2232: break;
2233:
1.115 misha 2234: case 145:
1.143 misha 2235: #line 754 "compile.y"
1.122 misha 2236: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_BIN_SL) ;}
1.112 paf 2237: break;
2238:
1.115 misha 2239: case 146:
1.143 misha 2240: #line 755 "compile.y"
1.122 misha 2241: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_BIN_SR) ;}
1.112 paf 2242: break;
2243:
1.115 misha 2244: case 147:
1.143 misha 2245: #line 756 "compile.y"
1.122 misha 2246: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_BIN_AND) ;}
1.112 paf 2247: break;
2248:
1.115 misha 2249: case 148:
1.143 misha 2250: #line 757 "compile.y"
1.122 misha 2251: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_BIN_OR) ;}
1.112 paf 2252: break;
2253:
1.115 misha 2254: case 149:
1.143 misha 2255: #line 758 "compile.y"
1.122 misha 2256: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_BIN_XOR) ;}
1.112 paf 2257: break;
2258:
1.115 misha 2259: case 150:
1.143 misha 2260: #line 759 "compile.y"
1.122 misha 2261: { yyval=yyvsp[-2]; OA(*yyval, OP::OP_NESTED_CODE, yyvsp[0]); O(*yyval, OP::OP_LOG_AND) ;}
1.112 paf 2262: break;
2263:
1.115 misha 2264: case 151:
1.143 misha 2265: #line 760 "compile.y"
1.122 misha 2266: { yyval=yyvsp[-2]; OA(*yyval, OP::OP_NESTED_CODE, yyvsp[0]); O(*yyval, OP::OP_LOG_OR) ;}
1.112 paf 2267: break;
2268:
1.115 misha 2269: case 152:
1.143 misha 2270: #line 761 "compile.y"
1.122 misha 2271: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_LOG_XOR) ;}
1.112 paf 2272: break;
2273:
1.115 misha 2274: case 153:
1.143 misha 2275: #line 762 "compile.y"
1.122 misha 2276: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_NUM_LT) ;}
1.112 paf 2277: break;
2278:
1.115 misha 2279: case 154:
1.143 misha 2280: #line 763 "compile.y"
1.122 misha 2281: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_NUM_GT) ;}
1.112 paf 2282: break;
2283:
1.115 misha 2284: case 155:
1.143 misha 2285: #line 764 "compile.y"
1.122 misha 2286: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_NUM_LE) ;}
1.112 paf 2287: break;
2288:
1.115 misha 2289: case 156:
1.143 misha 2290: #line 765 "compile.y"
1.122 misha 2291: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_NUM_GE) ;}
1.112 paf 2292: break;
2293:
1.115 misha 2294: case 157:
1.143 misha 2295: #line 766 "compile.y"
1.122 misha 2296: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_NUM_EQ) ;}
1.112 paf 2297: break;
2298:
1.115 misha 2299: case 158:
1.143 misha 2300: #line 767 "compile.y"
1.122 misha 2301: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_NUM_NE) ;}
1.112 paf 2302: break;
2303:
1.115 misha 2304: case 159:
1.143 misha 2305: #line 768 "compile.y"
1.122 misha 2306: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_STR_LT) ;}
1.112 paf 2307: break;
2308:
1.115 misha 2309: case 160:
1.143 misha 2310: #line 769 "compile.y"
1.122 misha 2311: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_STR_GT) ;}
1.112 paf 2312: break;
2313:
1.115 misha 2314: case 161:
1.143 misha 2315: #line 770 "compile.y"
1.122 misha 2316: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_STR_LE) ;}
1.112 paf 2317: break;
2318:
1.115 misha 2319: case 162:
1.143 misha 2320: #line 771 "compile.y"
1.122 misha 2321: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_STR_GE) ;}
1.112 paf 2322: break;
2323:
1.115 misha 2324: case 163:
1.143 misha 2325: #line 772 "compile.y"
1.122 misha 2326: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_STR_EQ) ;}
1.112 paf 2327: break;
2328:
1.115 misha 2329: case 164:
1.143 misha 2330: #line 773 "compile.y"
1.122 misha 2331: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_STR_NE) ;}
1.112 paf 2332: break;
2333:
1.115 misha 2334: case 165:
1.143 misha 2335: #line 774 "compile.y"
1.122 misha 2336: { yyval=yyvsp[-2]; P(*yyval, *yyvsp[0]); O(*yyval, OP::OP_IS) ;}
1.112 paf 2337: break;
2338:
1.115 misha 2339: case 166:
1.143 misha 2340: #line 777 "compile.y"
1.112 paf 2341: {
1.131 misha 2342: // optimized OP_STRING => OP_VALUE for doubles
1.104 paf 2343: maybe_change_string_literal_to_double_literal(*(yyval=yyvsp[0]));
1.112 paf 2344: ;}
2345: break;
2346:
1.115 misha 2347: case 167:
1.143 misha 2348: #line 782 "compile.y"
1.112 paf 2349: {
1.131 misha 2350: #ifdef OPTIMIZE_BYTECODE_STRING_POOL
2351: // it brakes ^if(" 09 "){...}
2352: YYSTYPE code=yyvsp[0];
2353: yyval=N();
1.132 misha 2354: if(code->count()==3 && maybe_change_first_opcode(*code, OP::OP_STRING__WRITE, OP::OP_VALUE)){
1.131 misha 2355: // optimized OP_STRING__WRITE+origin+value => OP_VALUE+origin+value without starting OP_STRING_POOL
2356: P(*yyval, *code);
2357: } else {
2358: OA(*yyval, OP::OP_STRING_POOL, code); /* stack: empty write context */
2359: }
2360: #else
1.84 paf 2361: yyval=N();
1.122 misha 2362: OA(*yyval, OP::OP_STRING_POOL, yyvsp[0]); /* stack: empty write context */
1.131 misha 2363: #endif
1.47 paf 2364: /* some code that writes to that context */
2365: /* context=pop; stack: context.get_string() */
1.112 paf 2366: ;}
2367: break;
2368:
1.115 misha 2369: case 168:
1.143 misha 2370: #line 803 "compile.y"
1.112 paf 2371: {
1.131 misha 2372: // optimized OP_STRING+OP_WRITE_VALUE => OP_STRING__WRITE
1.97 paf 2373: change_string_literal_to_write_string_literal(*(yyval=yyvsp[0]))
1.112 paf 2374: ;}
2375: break;
2376:
1.115 misha 2377: case 169:
1.143 misha 2378: #line 808 "compile.y"
1.112 paf 2379: { yyval=VL(/*we know that we will not change it*/const_cast<VVoid*>(&vvoid), 0, 0, 0) ;}
2380: break;
2381:
1.115 misha 2382: case 170:
1.143 misha 2383: #line 809 "compile.y"
1.112 paf 2384: { yyval = VL(/*we know that we will not change it*/const_cast<VBool*>(&vtrue), 0, 0, 0) ;}
2385: break;
2386:
1.115 misha 2387: case 171:
1.143 misha 2388: #line 810 "compile.y"
1.112 paf 2389: { yyval = VL(/*we know that we will not change it*/const_cast<VBool*>(&vfalse), 0, 0, 0) ;}
2390: break;
2391:
1.115 misha 2392: case 172:
1.143 misha 2393: #line 812 "compile.y"
1.112 paf 2394: { yyval=N() ;}
2395: break;
2396:
2397:
2398: }
2399:
1.114 misha 2400: /* Line 1010 of yacc.c. */
1.143 misha 2401: #line 2406 "compile.tab.C"
1.1 parser 2402:
2403: yyvsp -= yylen;
2404: yyssp -= yylen;
2405:
1.112 paf 2406:
2407: YY_STACK_PRINT (yyss, yyssp);
1.1 parser 2408:
2409: *++yyvsp = yyval;
2410:
2411:
1.112 paf 2412: /* Now `shift' the result of the reduction. Determine what state
2413: that goes to, based on the state we popped back to and the rule
2414: number reduced by. */
1.1 parser 2415:
2416: yyn = yyr1[yyn];
2417:
1.112 paf 2418: yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
2419: if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
1.1 parser 2420: yystate = yytable[yystate];
2421: else
1.112 paf 2422: yystate = yydefgoto[yyn - YYNTOKENS];
1.1 parser 2423:
2424: goto yynewstate;
2425:
2426:
1.112 paf 2427: /*------------------------------------.
2428: | yyerrlab -- here on detecting error |
2429: `------------------------------------*/
2430: yyerrlab:
2431: /* If not already recovering from an error, report this error. */
2432: if (!yyerrstatus)
1.1 parser 2433: {
2434: ++yynerrs;
1.112 paf 2435: #if YYERROR_VERBOSE
1.1 parser 2436: yyn = yypact[yystate];
2437:
1.112 paf 2438: if (YYPACT_NINF < yyn && yyn < YYLAST)
1.1 parser 2439: {
1.112 paf 2440: YYSIZE_T yysize = 0;
2441: int yytype = YYTRANSLATE (yychar);
2442: const char* yyprefix;
2443: char *yymsg;
2444: int yyx;
2445:
2446: /* Start YYX at -YYN if negative to avoid negative indexes in
2447: YYCHECK. */
2448: int yyxbegin = yyn < 0 ? -yyn : 0;
2449:
2450: /* Stay within bounds of both yycheck and yytname. */
2451: int yychecklim = YYLAST - yyn;
2452: int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
2453: int yycount = 0;
2454:
2455: yyprefix = ", expecting ";
2456: for (yyx = yyxbegin; yyx < yyxend; ++yyx)
2457: if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
2458: {
2459: yysize += yystrlen (yyprefix) + yystrlen (yytname [yyx]);
2460: yycount += 1;
2461: if (yycount == 5)
2462: {
2463: yysize = 0;
2464: break;
2465: }
2466: }
2467: yysize += (sizeof ("syntax error, unexpected ")
2468: + yystrlen (yytname[yytype]));
2469: yymsg = (char *) YYSTACK_ALLOC (yysize);
2470: if (yymsg != 0)
1.1 parser 2471: {
1.112 paf 2472: char *yyp = yystpcpy (yymsg, "syntax error, unexpected ");
2473: yyp = yystpcpy (yyp, yytname[yytype]);
1.1 parser 2474:
1.112 paf 2475: if (yycount < 5)
1.1 parser 2476: {
1.112 paf 2477: yyprefix = ", expecting ";
2478: for (yyx = yyxbegin; yyx < yyxend; ++yyx)
2479: if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
1.1 parser 2480: {
1.112 paf 2481: yyp = yystpcpy (yyp, yyprefix);
2482: yyp = yystpcpy (yyp, yytname[yyx]);
2483: yyprefix = " or ";
1.1 parser 2484: }
2485: }
1.112 paf 2486: yyerror (yymsg);
2487: YYSTACK_FREE (yymsg);
1.1 parser 2488: }
2489: else
1.112 paf 2490: yyerror ("syntax error; also virtual memory exhausted");
1.1 parser 2491: }
2492: else
2493: #endif /* YYERROR_VERBOSE */
1.112 paf 2494: yyerror ("syntax error");
1.1 parser 2495: }
2496:
1.112 paf 2497:
1.1 parser 2498:
2499: if (yyerrstatus == 3)
2500: {
1.112 paf 2501: /* If just tried and failed to reuse lookahead token after an
2502: error, discard it. */
1.109 paf 2503:
1.113 paf 2504: if (yychar <= YYEOF)
1.112 paf 2505: {
1.113 paf 2506: /* If at end of input, pop the error token,
2507: then the rest of the stack, then return failure. */
2508: if (yychar == YYEOF)
2509: for (;;)
2510: {
2511: YYPOPSTACK;
2512: if (yyssp == yyss)
2513: YYABORT;
2514: YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
2515: yydestruct (yystos[*yyssp], yyvsp);
2516: }
1.112 paf 2517: }
1.113 paf 2518: else
2519: {
2520: YYDSYMPRINTF ("Error: discarding", yytoken, &yylval, &yylloc);
2521: yydestruct (yytoken, &yylval);
2522: yychar = YYEMPTY;
1.1 parser 2523:
1.113 paf 2524: }
1.106 paf 2525: }
1.1 parser 2526:
1.112 paf 2527: /* Else will try to reuse lookahead token after shifting the error
2528: token. */
2529: goto yyerrlab1;
1.109 paf 2530:
1.1 parser 2531:
1.113 paf 2532: /*---------------------------------------------------.
2533: | yyerrorlab -- error raised explicitly by YYERROR. |
2534: `---------------------------------------------------*/
2535: yyerrorlab:
2536:
2537: #ifdef __GNUC__
2538: /* Pacify GCC when the user code never invokes YYERROR and the label
2539: yyerrorlab therefore never appears in user code. */
2540: if (0)
2541: goto yyerrorlab;
2542: #endif
2543:
2544: yyvsp -= yylen;
2545: yyssp -= yylen;
2546: yystate = *yyssp;
2547: goto yyerrlab1;
2548:
2549:
2550: /*-------------------------------------------------------------.
2551: | yyerrlab1 -- common code for both syntax error and YYERROR. |
2552: `-------------------------------------------------------------*/
1.112 paf 2553: yyerrlab1:
2554: yyerrstatus = 3; /* Each real token shifted decrements this. */
1.1 parser 2555:
1.112 paf 2556: for (;;)
1.109 paf 2557: {
1.112 paf 2558: yyn = yypact[yystate];
2559: if (yyn != YYPACT_NINF)
2560: {
2561: yyn += YYTERROR;
2562: if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
2563: {
2564: yyn = yytable[yyn];
2565: if (0 < yyn)
2566: break;
2567: }
2568: }
1.1 parser 2569:
1.112 paf 2570: /* Pop the current state because it cannot handle the error token. */
2571: if (yyssp == yyss)
2572: YYABORT;
1.1 parser 2573:
1.112 paf 2574: YYDSYMPRINTF ("Error: popping", yystos[*yyssp], yyvsp, yylsp);
2575: yydestruct (yystos[yystate], yyvsp);
1.113 paf 2576: YYPOPSTACK;
2577: yystate = *yyssp;
1.112 paf 2578: YY_STACK_PRINT (yyss, yyssp);
1.1 parser 2579: }
2580:
2581: if (yyn == YYFINAL)
2582: YYACCEPT;
2583:
1.112 paf 2584: YYDPRINTF ((stderr, "Shifting error token, "));
1.1 parser 2585:
2586: *++yyvsp = yylval;
1.112 paf 2587:
1.1 parser 2588:
2589: yystate = yyn;
2590: goto yynewstate;
2591:
2592:
1.112 paf 2593: /*-------------------------------------.
2594: | yyacceptlab -- YYACCEPT comes here. |
2595: `-------------------------------------*/
2596: yyacceptlab:
2597: yyresult = 0;
2598: goto yyreturn;
2599:
2600: /*-----------------------------------.
2601: | yyabortlab -- YYABORT comes here. |
2602: `-----------------------------------*/
2603: yyabortlab:
2604: yyresult = 1;
2605: goto yyreturn;
2606:
2607: #ifndef yyoverflow
2608: /*----------------------------------------------.
2609: | yyoverflowlab -- parser overflow comes here. |
2610: `----------------------------------------------*/
2611: yyoverflowlab:
2612: yyerror ("parser stack overflow");
2613: yyresult = 2;
2614: /* Fall through. */
2615: #endif
2616:
2617: yyreturn:
2618: #ifndef yyoverflow
2619: if (yyss != yyssa)
2620: YYSTACK_FREE (yyss);
1.1 parser 2621: #endif
1.112 paf 2622: return yyresult;
1.1 parser 2623: }
1.112 paf 2624:
2625:
1.143 misha 2626: #line 814 "compile.y"
1.1 parser 2627:
2628: #endif
2629:
2630: /*
2631: 000$111(2222)00
2632: 000$111{3333}00
2633: $,^: push,=0
2634: 1:( { break=pop
2635: 2:( ) pop
2636: 3:{ } pop
2637:
2638: 000^111(2222)4444{33333}4000
2639: $,^: push,=0
2640: 1:( { break=pop
2641: 2:( )=4
2642: 3:{ }=4
2643: 4:[^({]=pop
2644: */
2645:
1.84 paf 2646: inline void ungetc(Parse_control& pc, uint last_line_end_col) {
2647: pc.source--;
2648: if(pc.pos.col==0) {
2649: --pc.pos.line; pc.pos.col=last_line_end_col;
2650: } else
2651: --pc.pos.col;
2652:
2653: }
2654: static int yylex(YYSTYPE *lvalp, void *apc) {
2655: register Parse_control& pc=*static_cast<Parse_control*>(apc);
2656:
2657: #define lexical_brackets_nestage pc.brackets_nestages[pc.ls_sp]
1.1 parser 2658: #define RC {result=c; goto break2; }
2659:
1.84 paf 2660: register int c;
2661: int result;
1.1 parser 2662:
1.84 paf 2663: if(pc.pending_state) {
2664: result=pc.pending_state;
2665: pc.pending_state=0;
1.1 parser 2666: return result;
2667: }
2668:
1.84 paf 2669: const char *begin=pc.source;
2670: Pos begin_pos=pc.pos;
1.1 parser 2671: const char *end;
2672: int skip_analized=0;
2673: while(true) {
1.84 paf 2674: c=*(end=(pc.source++));
2675: // fprintf(stderr, "\nchar: %c %02X; nestage: %d, sp=%d", c, c, lexical_brackets_nestage, pc.sp);
1.1 parser 2676:
1.96 paf 2677: if(c=='\n')
1.84 paf 2678: pc.pos_next_line();
1.96 paf 2679: else
1.84 paf 2680: pc.pos_next_c(c);
1.96 paf 2681: // fprintf(stderr, "\nchar: %c file(%d:%d)", c, pc.pos.line, pc.pos.col);
1.1 parser 2682:
1.96 paf 2683: if(pc.pos.col==0+1 && c=='@') {
1.84 paf 2684: if(pc.ls==LS_DEF_SPECIAL_BODY) {
1.31 paf 2685: // @SPECIAL
2686: // ...
2687: // @<here =
1.84 paf 2688: pop_LS(pc); // exiting from LS_DEF_SPECIAL_BODY state
1.31 paf 2689: } // continuing checks
1.84 paf 2690: if(pc.ls==LS_USER) {
2691: push_LS(pc, LS_DEF_NAME);
1.20 parser 2692: RC;
1.31 paf 2693: } else // @ in first column inside some code [when could that be?]
1.20 parser 2694: result=BAD_METHOD_DECL_START;
2695: goto break2;
1.97 paf 2696: }
2697: if(c=='^') {
1.84 paf 2698: if(pc.ls==LS_METHOD_AFTER) {
1.75 paf 2699: // handle after-method situation
1.84 paf 2700: pop_LS(pc);
1.75 paf 2701: result=EON;
2702: skip_analized=-1; // return to punctuation afterwards to assure it's literality
2703: goto break2;
2704: }
1.84 paf 2705: switch(pc.ls) {
1.15 parser 2706: case LS_EXPRESSION_VAR_NAME_WITH_COLON:
2707: case LS_EXPRESSION_VAR_NAME_WITHOUT_COLON:
2708: case LS_VAR_NAME_SIMPLE_WITH_COLON:
2709: case LS_VAR_NAME_SIMPLE_WITHOUT_COLON:
2710: case LS_VAR_NAME_CURLY:
2711: case LS_METHOD_NAME:
1.66 paf 2712: case LS_USER_COMMENT:
1.15 parser 2713: case LS_DEF_COMMENT:
2714: // no literals in names, please
2715: break;
2716: default:
1.84 paf 2717: switch(*pc.source) {
1.10 parser 2718: // ^escaping some punctuators
1.121 misha 2719: case '^': case '$': case ';': case '@':
1.1 parser 2720: case '(': case ')':
2721: case '[': case ']':
2722: case '{': case '}':
1.23 parser 2723: case '"': case ':':
1.1 parser 2724: if(end!=begin) {
1.84 paf 2725: if(!pc.string_start)
2726: pc.string_start=begin_pos;
1.1 parser 2727: // append piece till ^
1.84 paf 2728: pc.string.append_strdup_know_length(begin, end-begin);
1.1 parser 2729: }
2730: // reset piece 'begin' position & line
1.84 paf 2731: begin=pc.source; // ->punctuation
2732: begin_pos=pc.pos;
1.75 paf 2733: // skip over _ after ^
1.84 paf 2734: pc.source++; pc.pos.col++;
1.75 paf 2735: // skip analysis = forced literal
2736: continue;
1.1 parser 2737:
2738: // converting ^#HH into char(hex(HH))
2739: case '#':
2740: if(end!=begin) {
1.84 paf 2741: if(!pc.string_start)
2742: pc.string_start=begin_pos;
1.1 parser 2743: // append piece till ^
1.84 paf 2744: pc.string.append_strdup_know_length(begin, end-begin);
1.1 parser 2745: }
2746: // #HH ?
1.121 misha 2747: if(pc.source[1] && isxdigit(pc.source[1]) && pc.source[2] && isxdigit(pc.source[2])) {
1.110 paf 2748: char c=(char)(
1.84 paf 2749: hex_value[(unsigned char)pc.source[1]]*0x10+
1.110 paf 2750: hex_value[(unsigned char)pc.source[2]]);
1.84 paf 2751: if(c==0) {
1.1 parser 2752: result=BAD_HEX_LITERAL;
2753: goto break2; // wrong hex value[no ^#00 chars allowed]: bail out
2754: }
2755: // append char(hex(HH))
1.84 paf 2756: pc.string.append(c);
1.1 parser 2757: // skip over ^#HH
1.84 paf 2758: pc.source+=3;
2759: pc.pos.col+=3;
1.1 parser 2760: // reset piece 'begin' position & line
1.84 paf 2761: begin=pc.source; // ->after ^#HH
2762: begin_pos=pc.pos;
1.75 paf 2763: // skip analysis = forced literal
1.1 parser 2764: continue;
2765: }
1.121 misha 2766: // just escaped char
2767: // reset piece 'begin' position & line
2768: begin=pc.source;
2769: begin_pos=pc.pos;
2770: // skip over _ after ^
2771: pc.source++; pc.pos.col++;
2772: // skip analysis = forced literal
2773: continue;
1.1 parser 2774: }
1.15 parser 2775: break;
1.75 paf 2776: }
1.15 parser 2777: }
1.1 parser 2778: // #comment start skipping
1.84 paf 2779: if(c=='#' && pc.pos.col==1) {
1.1 parser 2780: if(end!=begin) {
1.84 paf 2781: if(!pc.string_start)
2782: pc.string_start=begin_pos;
1.1 parser 2783: // append piece till #
1.84 paf 2784: pc.string.append_strdup_know_length(begin, end-begin);
1.1 parser 2785: }
2786: // fall into COMMENT lexical state [wait for \n]
1.84 paf 2787: push_LS(pc, LS_USER_COMMENT);
1.31 paf 2788: continue;
1.1 parser 2789: }
1.84 paf 2790: switch(pc.ls) {
1.1 parser 2791:
2792: // USER'S = NOT OURS
2793: case LS_USER:
1.84 paf 2794: case LS_NAME_SQUARE_PART: // name.[here].xxx
2795: if(pc.trim_bof)
1.1 parser 2796: switch(c) {
2797: case '\n': case ' ': case '\t':
1.84 paf 2798: begin=pc.source;
2799: begin_pos=pc.pos;
1.1 parser 2800: continue; // skip it
2801: default:
1.84 paf 2802: pc.trim_bof=false;
1.1 parser 2803: }
2804: switch(c) {
2805: case '$':
1.84 paf 2806: push_LS(pc, LS_VAR_NAME_SIMPLE_WITH_COLON);
1.1 parser 2807: RC;
2808: case '^':
1.84 paf 2809: push_LS(pc, LS_METHOD_NAME);
1.1 parser 2810: RC;
1.11 parser 2811: case ']':
1.84 paf 2812: if(pc.ls==LS_NAME_SQUARE_PART)
1.11 parser 2813: if(--lexical_brackets_nestage==0) {// $name.[co<]?>de<]?>
1.84 paf 2814: pop_LS(pc); // $name.[co<]>de<]!>
1.11 parser 2815: RC;
2816: }
1.3 parser 2817: break;
1.11 parser 2818: case '[': // $name.[co<[>de]
1.84 paf 2819: if(pc.ls==LS_NAME_SQUARE_PART)
1.11 parser 2820: lexical_brackets_nestage++;
1.4 parser 2821: break;
1.1 parser 2822: }
1.97 paf 2823: if(pc.explicit_result && c)
2824: switch(c) {
2825: case '\n': case ' ': case '\t':
2826: begin=pc.source;
2827: begin_pos=pc.pos;
2828: continue; // skip it
2829: default:
2830: result=BAD_NONWHITESPACE_CHARACTER_IN_EXPLICIT_RESULT_MODE;
2831: goto break2;
2832: }
1.1 parser 2833: break;
2834:
2835: // #COMMENT
1.66 paf 2836: case LS_USER_COMMENT:
1.1 parser 2837: if(c=='\n') {
2838: // skip comment
1.84 paf 2839: begin=pc.source;
2840: begin_pos=pc.pos;
1.1 parser 2841:
1.84 paf 2842: pop_LS(pc);
1.1 parser 2843: continue;
2844: }
2845: break;
2846:
2847: // STRING IN EXPRESSION
2848: case LS_EXPRESSION_STRING_QUOTED:
2849: case LS_EXPRESSION_STRING_APOSTROFED:
2850: switch(c) {
2851: case '"':
2852: case '\'':
2853: if(
1.84 paf 2854: pc.ls == LS_EXPRESSION_STRING_QUOTED && c=='"' ||
2855: pc.ls == LS_EXPRESSION_STRING_APOSTROFED && c=='\'') {
2856: pop_LS(pc); //"abc". | 'abc'.
1.1 parser 2857: RC;
2858: }
2859: break;
2860: case '$':
1.84 paf 2861: push_LS(pc, LS_VAR_NAME_SIMPLE_WITH_COLON);
1.1 parser 2862: RC;
2863: case '^':
1.84 paf 2864: push_LS(pc, LS_METHOD_NAME);
1.1 parser 2865: RC;
2866: }
2867: break;
2868:
2869: // METHOD DEFINITION
2870: case LS_DEF_NAME:
2871: switch(c) {
2872: case '[':
1.84 paf 2873: pc.ls=LS_DEF_PARAMS;
1.1 parser 2874: RC;
2875: case '\n':
1.84 paf 2876: pc.ls=LS_DEF_SPECIAL_BODY;
1.1 parser 2877: RC;
2878: }
2879: break;
2880:
2881: case LS_DEF_PARAMS:
2882: switch(c) {
1.64 paf 2883: case '$': // common error
1.65 paf 2884: result=BAD_METHOD_PARAMETER_NAME_CHARACTER;
2885: goto break2;
1.1 parser 2886: case ';':
2887: RC;
2888: case ']':
1.84 paf 2889: pc.ls=*pc.source=='['?LS_DEF_LOCALS:LS_DEF_COMMENT;
1.1 parser 2890: RC;
2891: case '\n': // wrong. bailing out
1.84 paf 2892: pop_LS(pc);
1.1 parser 2893: RC;
2894: }
2895: break;
2896:
2897: case LS_DEF_LOCALS:
2898: switch(c) {
2899: case '[':
2900: case ';':
2901: RC;
2902: case ']':
1.84 paf 2903: pc.ls=LS_DEF_COMMENT;
1.1 parser 2904: RC;
2905: case '\n': // wrong. bailing out
1.84 paf 2906: pop_LS(pc);
1.1 parser 2907: RC;
2908: }
2909: break;
2910:
2911: case LS_DEF_COMMENT:
2912: if(c=='\n') {
1.84 paf 2913: pop_LS(pc);
1.1 parser 2914: RC;
2915: }
2916: break;
2917:
2918: case LS_DEF_SPECIAL_BODY:
1.31 paf 2919: if(c=='\n')
1.1 parser 2920: RC;
2921: break;
2922:
2923: // (EXPRESSION)
2924: case LS_VAR_ROUND:
2925: case LS_METHOD_ROUND:
2926: switch(c) {
2927: case ')':
2928: if(--lexical_brackets_nestage==0)
1.84 paf 2929: if(pc.ls==LS_METHOD_ROUND) // method round param ended
2930: pc.ls=LS_METHOD_AFTER; // look for method end
2931: else // pc.ls==LS_VAR_ROUND // variable constructor ended
2932: pop_LS(pc); // return to normal life
1.1 parser 2933: RC;
1.66 paf 2934: case '#': // comment start skipping
2935: if(end!=begin) {
1.84 paf 2936: if(!pc.string_start)
2937: pc.string_start=begin_pos;
1.66 paf 2938: // append piece till #
1.84 paf 2939: pc.string.append_strdup_know_length(begin, end-begin);
1.66 paf 2940: }
2941: // fall into COMMENT lexical state [wait for \n]
1.84 paf 2942: push_LS(pc, LS_EXPRESSION_COMMENT);
1.66 paf 2943: lexical_brackets_nestage=1;
2944: continue;
1.1 parser 2945: case '$':
1.84 paf 2946: push_LS(pc, LS_EXPRESSION_VAR_NAME_WITH_COLON);
1.1 parser 2947: RC;
2948: case '^':
1.84 paf 2949: push_LS(pc, LS_METHOD_NAME);
1.1 parser 2950: RC;
2951: case '(':
2952: lexical_brackets_nestage++;
2953: RC;
2954: case '-':
1.84 paf 2955: switch(*pc.source) {
1.1 parser 2956: case 'f': // -f
2957: skip_analized=1;
2958: result=FEXISTS;
2959: goto break2;
2960: case 'd': // -d
2961: skip_analized=1;
2962: result=DEXISTS;
2963: goto break2;
1.63 paf 2964: default: // minus
1.1 parser 2965: result=c;
2966: goto break2;
2967: }
2968: goto break2;
1.25 paf 2969: case '+': case '*': case '/': case '%': case '\\':
1.1 parser 2970: case '~':
2971: case ';':
2972: RC;
1.65 paf 2973: case '&': case '|':
1.84 paf 2974: if(*pc.source==c) { // && ||
1.65 paf 2975: result=c=='&'?LAND:LOR;
1.1 parser 2976: skip_analized=1;
2977: } else
2978: result=c;
2979: goto break2;
1.65 paf 2980: case '!':
1.84 paf 2981: switch(pc.source[0]) {
1.65 paf 2982: case '|': // !| !||
2983: skip_analized=1;
1.84 paf 2984: if(pc.source[1]=='|') {
1.65 paf 2985: skip_analized++;
2986: result=LXOR;
2987: } else
2988: result=NXOR;
2989: goto break2;
2990: case '=': // !=
2991: skip_analized=1;
2992: result=NNE;
2993: goto break2;
2994: }
2995: RC;
1.67 paf 2996:
2997: case '<': // <<, <=, <
1.84 paf 2998: switch(*pc.source) {
1.67 paf 2999: case '<': // <[<]
3000: skip_analized=1; result=NSL; break;
3001: case '=': // <[=]
3002: skip_analized=1; result=NLE; break;
3003: default: // <[]
3004: result=c; break;
3005: }
3006: goto break2;
3007: case '>': // >>, >=, >
1.84 paf 3008: switch(*pc.source) {
1.67 paf 3009: case '>': // >[>]
3010: skip_analized=1; result=NSR; break;
3011: case '=': // >[=]
3012: skip_analized=1; result=NGE; break;
3013: default: // >[]
3014: result=c; break;
3015: }
3016: goto break2;
3017: case '=': // ==
1.84 paf 3018: switch(*pc.source) {
1.67 paf 3019: case '=': // =[=]
3020: skip_analized=1; result=NEQ; break;
3021: default: // =[]
3022: result=c; break; // not used now
3023: }
1.1 parser 3024: goto break2;
1.67 paf 3025:
1.1 parser 3026: case '"':
1.84 paf 3027: push_LS(pc, LS_EXPRESSION_STRING_QUOTED);
1.1 parser 3028: RC;
3029: case '\'':
1.84 paf 3030: push_LS(pc, LS_EXPRESSION_STRING_APOSTROFED);
1.1 parser 3031: RC;
3032: case 'l': case 'g': case 'e': case 'n':
3033: if(end==begin) // right after whitespace
1.84 paf 3034: if(isspace(pc.source[1])) {
3035: switch(*pc.source) {
1.1 parser 3036: // case '?': // ok [and bad cases, yacc would bark at them]
3037: case 't': // lt gt [et nt]
3038: result=c=='l'?SLT:c=='g'?SGT:BAD_STRING_COMPARISON_OPERATOR;
3039: skip_analized=1;
3040: goto break2;
3041: case 'e': // le ge ne [ee]
3042: result=c=='l'?SLE:c=='g'?SGE:c=='n'?SNE:BAD_STRING_COMPARISON_OPERATOR;
3043: skip_analized=1;
3044: goto break2;
3045: case 'q': // eq [lq gq nq]
3046: result=c=='e'?SEQ:BAD_STRING_COMPARISON_OPERATOR;
3047: skip_analized=1;
3048: goto break2;
3049: }
3050: }
3051: break;
3052: case 'i':
3053: if(end==begin) // right after whitespace
1.84 paf 3054: if(isspace(pc.source[1])) {
3055: switch(pc.source[0]) {
1.1 parser 3056: case 'n': // in
3057: skip_analized=1;
3058: result=IN;
3059: goto break2;
3060: case 's': // is
3061: skip_analized=1;
3062: result=IS;
3063: goto break2;
3064: }
3065: }
3066: break;
3067: case 'd':
3068: if(end==begin) // right after whitespace
1.84 paf 3069: if(pc.source[0]=='e' && pc.source[1]=='f') { // def
1.118 misha 3070: switch(pc.source[2]){
3071: case ' ': case '\t': case '\n': case '"': case '\'': case '^': case '$': // non-quoted string without whitespace after 'def' is not allowed
3072: skip_analized=2;
3073: result=DEF;
3074: goto break2;
3075: }
3076: // error: incorrect char after 'def'
1.1 parser 3077: }
3078: break;
1.107 paf 3079: case 't':
3080: if(end==begin) // right after whitespace
1.118 misha 3081: if(pc.source[0]=='r' && pc.source[1]=='u' && pc.source[2]=='e') { // true
1.107 paf 3082: skip_analized=3;
3083: result=LITERAL_TRUE;
3084: goto break2;
3085: }
3086: break;
3087: case 'f':
3088: if(end==begin) // right after whitespace
1.118 misha 3089: if(pc.source[0]=='a' && pc.source[1]=='l' && pc.source[2]=='s' && pc.source[3]=='e') { // false
1.107 paf 3090: skip_analized=4;
3091: result=LITERAL_FALSE;
3092: goto break2;
3093: }
3094: break;
1.1 parser 3095: case ' ': case '\t': case '\n':
3096: if(end!=begin) { // there were a string after previous operator?
3097: result=0; // return that string
3098: goto break2;
3099: }
3100: // that's a leading|traling space or after-operator-space
3101: // ignoring it
3102: // reset piece 'begin' position & line
1.84 paf 3103: begin=pc.source; // after whitespace char
3104: begin_pos=pc.pos;
1.1 parser 3105: continue;
3106: }
3107: break;
1.66 paf 3108: case LS_EXPRESSION_COMMENT:
3109: if(c=='(')
3110: lexical_brackets_nestage++;
3111:
1.84 paf 3112: switch(*pc.source) {
1.66 paf 3113: case '\n': case ')':
1.84 paf 3114: if(*pc.source==')')
1.66 paf 3115: if(--lexical_brackets_nestage!=0)
3116: continue;
3117:
3118: // skip comment
1.84 paf 3119: begin=pc.source;
3120: begin_pos=pc.pos;
1.66 paf 3121:
1.84 paf 3122: pop_LS(pc);
1.66 paf 3123: continue;
3124: }
3125: break;
1.1 parser 3126:
3127: // VARIABLE GET/PUT/WITH
1.11 parser 3128: case LS_VAR_NAME_SIMPLE_WITH_COLON:
3129: case LS_VAR_NAME_SIMPLE_WITHOUT_COLON:
3130: case LS_EXPRESSION_VAR_NAME_WITH_COLON:
3131: case LS_EXPRESSION_VAR_NAME_WITHOUT_COLON:
3132: if(
1.84 paf 3133: pc.ls==LS_EXPRESSION_VAR_NAME_WITH_COLON ||
3134: pc.ls==LS_EXPRESSION_VAR_NAME_WITHOUT_COLON) {
1.41 paf 3135: // name in expr ends also before
1.1 parser 3136: switch(c) {
1.41 paf 3137: // expression minus
1.1 parser 3138: case '-':
1.41 paf 3139: // expression integer division
3140: case '\\':
1.84 paf 3141: pop_LS(pc);
3142: pc.ungetc();
1.1 parser 3143: result=EON;
3144: goto break2;
3145: }
3146: }
1.11 parser 3147: if(
1.84 paf 3148: pc.ls==LS_VAR_NAME_SIMPLE_WITHOUT_COLON ||
3149: pc.ls==LS_EXPRESSION_VAR_NAME_WITHOUT_COLON) {
1.1 parser 3150: // name already has ':', stop before next
3151: switch(c) {
3152: case ':':
1.84 paf 3153: pop_LS(pc);
3154: pc.ungetc();
1.1 parser 3155: result=EON;
3156: goto break2;
3157: }
3158: }
3159: switch(c) {
3160: case 0:
3161: case ' ': case '\t': case '\n':
3162: case ';':
3163: case ']': case '}': case ')':
3164: case '"': case '\'':
3165: case '<': case '>': // these stand for HTML brackets AND expression binary ops
1.146 misha 3166: case '+': case '*': case '/': case '\\': case '%':
1.1 parser 3167: case '&': case '|':
3168: case '=': case '!':
3169: // common delimiters
1.62 paf 3170: case ',': case '?': case '#':
1.113 paf 3171: // mysql column separators
3172: case '`':
1.1 parser 3173: // before call
3174: case '^':
1.84 paf 3175: pop_LS(pc);
3176: pc.ungetc();
1.1 parser 3177: result=EON;
3178: goto break2;
3179: case '[':
1.5 parser 3180: // $name.<[>code]
1.84 paf 3181: if(pc.pos.col>1/*not first column*/ && (
1.6 parser 3182: end[-1]=='$'/*was start of get*/ ||
3183: end[-1]==':'/*was class name delim */ ||
3184: end[-1]=='.'/*was name delim */
1.5 parser 3185: )) {
1.84 paf 3186: push_LS(pc, LS_NAME_SQUARE_PART);
1.5 parser 3187: lexical_brackets_nestage=1;
3188: RC;
3189: }
1.84 paf 3190: pc.ls=LS_VAR_SQUARE;
1.1 parser 3191: lexical_brackets_nestage=1;
3192: RC;
3193: case '{':
3194: if(begin==end) { // ${name}, no need of EON, switching LS
1.84 paf 3195: pc.ls=LS_VAR_NAME_CURLY;
1.1 parser 3196: } else {
1.84 paf 3197: pc.ls=LS_VAR_CURLY;
1.1 parser 3198: lexical_brackets_nestage=1;
3199: }
3200:
3201: RC;
3202: case '(':
1.84 paf 3203: pc.ls=LS_VAR_ROUND;
1.1 parser 3204: lexical_brackets_nestage=1;
3205: RC;
3206: case '.': // name part delim
3207: case '$': // name part subvar
1.3 parser 3208: case ':': // class<:>name
1.11 parser 3209: // go to _WITHOUT_COLON state variant...
1.84 paf 3210: if(pc.ls==LS_VAR_NAME_SIMPLE_WITH_COLON)
3211: pc.ls=LS_VAR_NAME_SIMPLE_WITHOUT_COLON;
3212: else if(pc.ls==LS_EXPRESSION_VAR_NAME_WITH_COLON)
3213: pc.ls=LS_EXPRESSION_VAR_NAME_WITHOUT_COLON;
1.11 parser 3214: // ...stop before next ':'
1.1 parser 3215: RC;
3216: }
3217: break;
3218:
3219: case LS_VAR_NAME_CURLY:
3220: switch(c) {
1.5 parser 3221: case '[':
1.11 parser 3222: // ${name.<[>code]}
1.84 paf 3223: push_LS(pc, LS_NAME_SQUARE_PART);
1.3 parser 3224: lexical_brackets_nestage=1;
3225: RC;
1.1 parser 3226: case '}': // ${name} finished, restoring LS
1.84 paf 3227: pop_LS(pc);
1.1 parser 3228: RC;
3229: case '.': // name part delim
3230: case '$': // name part subvar
3231: case ':': // ':name' or 'class:name'
3232: RC;
3233: }
3234: break;
3235:
3236: case LS_VAR_SQUARE:
3237: switch(c) {
3238: case '$':
1.84 paf 3239: push_LS(pc, LS_VAR_NAME_SIMPLE_WITH_COLON);
1.1 parser 3240: RC;
3241: case '^':
1.84 paf 3242: push_LS(pc, LS_METHOD_NAME);
1.1 parser 3243: RC;
3244: case ']':
3245: if(--lexical_brackets_nestage==0) {
1.84 paf 3246: pop_LS(pc);
1.1 parser 3247: RC;
3248: }
3249: break;
3250: case ';': // operator_or_fmt;value delim
3251: RC;
3252: case '[':
3253: lexical_brackets_nestage++;
3254: break;
3255: }
3256: break;
3257:
3258: case LS_VAR_CURLY:
3259: switch(c) {
3260: case '$':
1.84 paf 3261: push_LS(pc, LS_VAR_NAME_SIMPLE_WITH_COLON);
1.1 parser 3262: RC;
3263: case '^':
1.84 paf 3264: push_LS(pc, LS_METHOD_NAME);
1.1 parser 3265: RC;
3266: case '}':
3267: if(--lexical_brackets_nestage==0) {
1.84 paf 3268: pop_LS(pc);
1.1 parser 3269: RC;
3270: }
3271: break;
3272: case '{':
3273: lexical_brackets_nestage++;
3274: break;
3275: }
3276: break;
3277:
3278: // METHOD CALL
3279: case LS_METHOD_NAME:
3280: switch(c) {
3281: case '[':
1.11 parser 3282: // ^name.<[>code].xxx
1.84 paf 3283: if(pc.pos.col>1/*not first column*/ && (
1.6 parser 3284: end[-1]=='^'/*was start of call*/ || // never, ^[ is literal...
3285: end[-1]==':'/*was class name delim */ ||
3286: end[-1]=='.'/*was name delim */
1.5 parser 3287: )) {
1.84 paf 3288: push_LS(pc, LS_NAME_SQUARE_PART);
1.5 parser 3289: lexical_brackets_nestage=1;
3290: RC;
3291: }
1.84 paf 3292: pc.ls=LS_METHOD_SQUARE;
1.1 parser 3293: lexical_brackets_nestage=1;
3294: RC;
3295: case '{':
1.84 paf 3296: pc.ls=LS_METHOD_CURLY;
1.1 parser 3297: lexical_brackets_nestage=1;
3298: RC;
3299: case '(':
1.84 paf 3300: pc.ls=LS_METHOD_ROUND;
1.1 parser 3301: lexical_brackets_nestage=1;
3302: RC;
3303: case '.': // name part delim
3304: case '$': // name part subvar
3305: case ':': // ':name' or 'class:name'
1.19 parser 3306: case '^': // ^abc^xxx wrong. bailing out
3307: case ']': case '}': case ')': // ^abc]}) wrong. bailing out
1.90 paf 3308: case ' ': // ^if ( wrong. bailing out
1.1 parser 3309: RC;
3310: }
3311: break;
3312:
3313: case LS_METHOD_SQUARE:
3314: switch(c) {
3315: case '$':
1.84 paf 3316: push_LS(pc, LS_VAR_NAME_SIMPLE_WITH_COLON);
1.1 parser 3317: RC;
3318: case '^':
1.84 paf 3319: push_LS(pc, LS_METHOD_NAME);
1.1 parser 3320: RC;
3321: case ';': // param delim
3322: RC;
3323: case ']':
3324: if(--lexical_brackets_nestage==0) {
1.84 paf 3325: pc.ls=LS_METHOD_AFTER;
1.1 parser 3326: RC;
3327: }
3328: break;
3329: case '[':
3330: lexical_brackets_nestage++;
3331: break;
3332: }
3333: break;
3334:
3335: case LS_METHOD_CURLY:
3336: switch(c) {
3337: case '$':
1.84 paf 3338: push_LS(pc, LS_VAR_NAME_SIMPLE_WITH_COLON);
1.1 parser 3339: RC;
3340: case '^':
1.84 paf 3341: push_LS(pc, LS_METHOD_NAME);
1.1 parser 3342: RC;
3343: case ';': // param delim
3344: RC;
3345: case '}':
3346: if(--lexical_brackets_nestage==0) {
1.84 paf 3347: pc.ls=LS_METHOD_AFTER;
1.1 parser 3348: RC;
3349: }
3350: break;
3351: case '{':
3352: lexical_brackets_nestage++;
3353: break;
3354: }
1.97 paf 3355: if(pc.explicit_result && c)
3356: switch(c) {
3357: case '\n': case ' ': case '\t':
3358: begin=pc.source;
3359: begin_pos=pc.pos;
3360: continue; // skip it
3361: default:
3362: result=BAD_NONWHITESPACE_CHARACTER_IN_EXPLICIT_RESULT_MODE;
3363: goto break2;
3364: }
1.1 parser 3365: break;
3366:
3367: case LS_METHOD_AFTER:
3368: if(c=='[') {/* ][ }[ )[ */
1.84 paf 3369: pc.ls=LS_METHOD_SQUARE;
1.1 parser 3370: lexical_brackets_nestage=1;
3371: RC;
3372: }
3373: if(c=='{') {/* ]{ }{ ){ */
1.84 paf 3374: pc.ls=LS_METHOD_CURLY;
1.1 parser 3375: lexical_brackets_nestage=1;
3376: RC;
3377: }
3378: if(c=='(') {/* ]( }( )( */
1.84 paf 3379: pc.ls=LS_METHOD_ROUND;
1.1 parser 3380: lexical_brackets_nestage=1;
3381: RC;
3382: }
1.84 paf 3383: pop_LS(pc);
3384: pc.ungetc();
1.1 parser 3385: result=EON;
3386: goto break2;
3387: }
3388: if(c==0) {
3389: result=-1;
3390: break;
3391: }
3392: }
3393:
3394: break2:
3395: if(end!=begin) { // there is last piece?
3396: if((c=='@' || c==0) && end[-1]=='\n') { // we are before LS_DEF_NAME or EOF?
3397: // strip last \n
3398: end--;
3399: if(end!=begin && end[-1]=='\n') // allow one empty line before LS_DEF_NAME
3400: end--;
3401: }
1.84 paf 3402: if(end!=begin && pc.ls!=LS_USER_COMMENT) { // last piece still alive and not comment?
3403: if(!pc.string_start)
3404: pc.string_start=begin_pos;
1.1 parser 3405: // append it
1.84 paf 3406: pc.string.append_strdup_know_length(begin, end-begin);
1.1 parser 3407: }
3408: }
1.84 paf 3409: if(!pc.string.is_empty()) { // something accumulated?
3410: // create STRING value: array of OP_VALUE+origin+vstring
3411: *lvalp=VL(
3412: new VString(*new String(pc.string, String::L_CLEAN)),
3413: pc.file_no, pc.string_start.line, pc.string_start.col);
1.1 parser 3414: // new pieces storage
1.84 paf 3415: pc.string.clear();
3416: pc.string_start.clear();
1.1 parser 3417: // make current result be pending for next call, return STRING for now
1.84 paf 3418: pc.pending_state=result; result=STRING;
1.1 parser 3419: }
3420: if(skip_analized) {
1.84 paf 3421: pc.source+=skip_analized; pc.pos.col+=skip_analized;
1.1 parser 3422: }
3423: return result;
3424: }
3425:
1.84 paf 3426: static int real_yyerror(Parse_control *pc, char *s) { // Called by yyparse on error
1.10 parser 3427: strncpy(PC.error, s, MAX_STRING);
1.1 parser 3428: return 1;
3429: }
3430:
3431: static void yyprint(FILE *file, int type, YYSTYPE value) {
3432: if(type==STRING)
1.84 paf 3433: fprintf(file, " \"%s\"", LA2S(*value)->cstr());
1.1 parser 3434: }
1.112 paf 3435:
3436:
E-mail: