xref: /PHP-7.2/Zend/zend_language_parser.y (revision 85e8ccd5)
1 %{
2 /*
3    +----------------------------------------------------------------------+
4    | Zend Engine                                                          |
5    +----------------------------------------------------------------------+
6    | Copyright (c) 1998-2018 Zend Technologies Ltd. (http://www.zend.com) |
7    +----------------------------------------------------------------------+
8    | This source file is subject to version 2.00 of the Zend license,     |
9    | that is bundled with this package in the file LICENSE, and is        |
10    | available through the world-wide-web at the following url:           |
11    | http://www.zend.com/license/2_00.txt.                                |
12    | If you did not receive a copy of the Zend license and are unable to  |
13    | obtain it through the world-wide-web, please send a note to          |
14    | license@zend.com so we can mail you a copy immediately.              |
15    +----------------------------------------------------------------------+
16    | Authors: Andi Gutmans <andi@zend.com>                                |
17    |          Zeev Suraski <zeev@zend.com>                                |
18    |          Nikita Popov <nikic@php.net>                                |
19    +----------------------------------------------------------------------+
20 */
21 
22 /* $Id$ */
23 
24 #include "zend_compile.h"
25 #include "zend.h"
26 #include "zend_list.h"
27 #include "zend_globals.h"
28 #include "zend_API.h"
29 #include "zend_constants.h"
30 #include "zend_language_scanner.h"
31 
32 #define YYSIZE_T size_t
33 #define yytnamerr zend_yytnamerr
34 static YYSIZE_T zend_yytnamerr(char*, const char*);
35 
36 #define YYERROR_VERBOSE
37 #define YYSTYPE zend_parser_stack_elem
38 
39 #ifdef _MSC_VER
40 #define YYMALLOC malloc
41 #define YYFREE free
42 #endif
43 
44 %}
45 
46 %pure-parser
47 %expect 0
48 
49 %code requires {
50 }
51 
52 %destructor { zend_ast_destroy($$); } <ast>
53 %destructor { if ($$) zend_string_release($$); } <str>
54 
55 %left T_INCLUDE T_INCLUDE_ONCE T_EVAL T_REQUIRE T_REQUIRE_ONCE
56 %left ','
57 %left T_LOGICAL_OR
58 %left T_LOGICAL_XOR
59 %left T_LOGICAL_AND
60 %right T_PRINT
61 %right T_YIELD
62 %right T_DOUBLE_ARROW
63 %right T_YIELD_FROM
64 %left '=' T_PLUS_EQUAL T_MINUS_EQUAL T_MUL_EQUAL T_DIV_EQUAL T_CONCAT_EQUAL T_MOD_EQUAL T_AND_EQUAL T_OR_EQUAL T_XOR_EQUAL T_SL_EQUAL T_SR_EQUAL T_POW_EQUAL
65 %left '?' ':'
66 %right T_COALESCE
67 %left T_BOOLEAN_OR
68 %left T_BOOLEAN_AND
69 %left '|'
70 %left '^'
71 %left '&'
72 %nonassoc T_IS_EQUAL T_IS_NOT_EQUAL T_IS_IDENTICAL T_IS_NOT_IDENTICAL T_SPACESHIP
73 %nonassoc '<' T_IS_SMALLER_OR_EQUAL '>' T_IS_GREATER_OR_EQUAL
74 %left T_SL T_SR
75 %left '+' '-' '.'
76 %left '*' '/' '%'
77 %right '!'
78 %nonassoc T_INSTANCEOF
79 %right '~' T_INC T_DEC T_INT_CAST T_DOUBLE_CAST T_STRING_CAST T_ARRAY_CAST T_OBJECT_CAST T_BOOL_CAST T_UNSET_CAST '@'
80 %right T_POW
81 %right '['
82 %nonassoc T_NEW T_CLONE
83 %left T_NOELSE
84 %left T_ELSEIF
85 %left T_ELSE
86 %left T_ENDIF
87 %right T_STATIC T_ABSTRACT T_FINAL T_PRIVATE T_PROTECTED T_PUBLIC
88 
89 %token <ast> T_LNUMBER   "integer number (T_LNUMBER)"
90 %token <ast> T_DNUMBER   "floating-point number (T_DNUMBER)"
91 %token <ast> T_STRING    "identifier (T_STRING)"
92 %token <ast> T_VARIABLE  "variable (T_VARIABLE)"
93 %token <ast> T_INLINE_HTML
94 %token <ast> T_ENCAPSED_AND_WHITESPACE  "quoted-string and whitespace (T_ENCAPSED_AND_WHITESPACE)"
95 %token <ast> T_CONSTANT_ENCAPSED_STRING "quoted-string (T_CONSTANT_ENCAPSED_STRING)"
96 %token <ast> T_STRING_VARNAME "variable name (T_STRING_VARNAME)"
97 %token <ast> T_NUM_STRING "number (T_NUM_STRING)"
98 
99 %token END 0 "end of file"
100 %token T_INCLUDE      "include (T_INCLUDE)"
101 %token T_INCLUDE_ONCE "include_once (T_INCLUDE_ONCE)"
102 %token T_EVAL         "eval (T_EVAL)"
103 %token T_REQUIRE      "require (T_REQUIRE)"
104 %token T_REQUIRE_ONCE "require_once (T_REQUIRE_ONCE)"
105 %token T_LOGICAL_OR   "or (T_LOGICAL_OR)"
106 %token T_LOGICAL_XOR  "xor (T_LOGICAL_XOR)"
107 %token T_LOGICAL_AND  "and (T_LOGICAL_AND)"
108 %token T_PRINT        "print (T_PRINT)"
109 %token T_YIELD        "yield (T_YIELD)"
110 %token T_YIELD_FROM   "yield from (T_YIELD_FROM)"
111 %token T_PLUS_EQUAL   "+= (T_PLUS_EQUAL)"
112 %token T_MINUS_EQUAL  "-= (T_MINUS_EQUAL)"
113 %token T_MUL_EQUAL    "*= (T_MUL_EQUAL)"
114 %token T_DIV_EQUAL    "/= (T_DIV_EQUAL)"
115 %token T_CONCAT_EQUAL ".= (T_CONCAT_EQUAL)"
116 %token T_MOD_EQUAL    "%= (T_MOD_EQUAL)"
117 %token T_AND_EQUAL    "&= (T_AND_EQUAL)"
118 %token T_OR_EQUAL     "|= (T_OR_EQUAL)"
119 %token T_XOR_EQUAL    "^= (T_XOR_EQUAL)"
120 %token T_SL_EQUAL     "<<= (T_SL_EQUAL)"
121 %token T_SR_EQUAL     ">>= (T_SR_EQUAL)"
122 %token T_BOOLEAN_OR   "|| (T_BOOLEAN_OR)"
123 %token T_BOOLEAN_AND  "&& (T_BOOLEAN_AND)"
124 %token T_IS_EQUAL     "== (T_IS_EQUAL)"
125 %token T_IS_NOT_EQUAL "!= (T_IS_NOT_EQUAL)"
126 %token T_IS_IDENTICAL "=== (T_IS_IDENTICAL)"
127 %token T_IS_NOT_IDENTICAL "!== (T_IS_NOT_IDENTICAL)"
128 %token T_IS_SMALLER_OR_EQUAL "<= (T_IS_SMALLER_OR_EQUAL)"
129 %token T_IS_GREATER_OR_EQUAL ">= (T_IS_GREATER_OR_EQUAL)"
130 %token T_SPACESHIP "<=> (T_SPACESHIP)"
131 %token T_SL "<< (T_SL)"
132 %token T_SR ">> (T_SR)"
133 %token T_INSTANCEOF  "instanceof (T_INSTANCEOF)"
134 %token T_INC "++ (T_INC)"
135 %token T_DEC "-- (T_DEC)"
136 %token T_INT_CAST    "(int) (T_INT_CAST)"
137 %token T_DOUBLE_CAST "(double) (T_DOUBLE_CAST)"
138 %token T_STRING_CAST "(string) (T_STRING_CAST)"
139 %token T_ARRAY_CAST  "(array) (T_ARRAY_CAST)"
140 %token T_OBJECT_CAST "(object) (T_OBJECT_CAST)"
141 %token T_BOOL_CAST   "(bool) (T_BOOL_CAST)"
142 %token T_UNSET_CAST  "(unset) (T_UNSET_CAST)"
143 %token T_NEW       "new (T_NEW)"
144 %token T_CLONE     "clone (T_CLONE)"
145 %token T_EXIT      "exit (T_EXIT)"
146 %token T_IF        "if (T_IF)"
147 %token T_ELSEIF    "elseif (T_ELSEIF)"
148 %token T_ELSE      "else (T_ELSE)"
149 %token T_ENDIF     "endif (T_ENDIF)"
150 %token T_ECHO       "echo (T_ECHO)"
151 %token T_DO         "do (T_DO)"
152 %token T_WHILE      "while (T_WHILE)"
153 %token T_ENDWHILE   "endwhile (T_ENDWHILE)"
154 %token T_FOR        "for (T_FOR)"
155 %token T_ENDFOR     "endfor (T_ENDFOR)"
156 %token T_FOREACH    "foreach (T_FOREACH)"
157 %token T_ENDFOREACH "endforeach (T_ENDFOREACH)"
158 %token T_DECLARE    "declare (T_DECLARE)"
159 %token T_ENDDECLARE "enddeclare (T_ENDDECLARE)"
160 %token T_AS         "as (T_AS)"
161 %token T_SWITCH     "switch (T_SWITCH)"
162 %token T_ENDSWITCH  "endswitch (T_ENDSWITCH)"
163 %token T_CASE       "case (T_CASE)"
164 %token T_DEFAULT    "default (T_DEFAULT)"
165 %token T_BREAK      "break (T_BREAK)"
166 %token T_CONTINUE   "continue (T_CONTINUE)"
167 %token T_GOTO       "goto (T_GOTO)"
168 %token T_FUNCTION   "function (T_FUNCTION)"
169 %token T_CONST      "const (T_CONST)"
170 %token T_RETURN     "return (T_RETURN)"
171 %token T_TRY        "try (T_TRY)"
172 %token T_CATCH      "catch (T_CATCH)"
173 %token T_FINALLY    "finally (T_FINALLY)"
174 %token T_THROW      "throw (T_THROW)"
175 %token T_USE        "use (T_USE)"
176 %token T_INSTEADOF  "insteadof (T_INSTEADOF)"
177 %token T_GLOBAL     "global (T_GLOBAL)"
178 %token T_STATIC     "static (T_STATIC)"
179 %token T_ABSTRACT   "abstract (T_ABSTRACT)"
180 %token T_FINAL      "final (T_FINAL)"
181 %token T_PRIVATE    "private (T_PRIVATE)"
182 %token T_PROTECTED  "protected (T_PROTECTED)"
183 %token T_PUBLIC     "public (T_PUBLIC)"
184 %token T_VAR        "var (T_VAR)"
185 %token T_UNSET      "unset (T_UNSET)"
186 %token T_ISSET      "isset (T_ISSET)"
187 %token T_EMPTY      "empty (T_EMPTY)"
188 %token T_HALT_COMPILER "__halt_compiler (T_HALT_COMPILER)"
189 %token T_CLASS      "class (T_CLASS)"
190 %token T_TRAIT      "trait (T_TRAIT)"
191 %token T_INTERFACE  "interface (T_INTERFACE)"
192 %token T_EXTENDS    "extends (T_EXTENDS)"
193 %token T_IMPLEMENTS "implements (T_IMPLEMENTS)"
194 %token T_OBJECT_OPERATOR "-> (T_OBJECT_OPERATOR)"
195 %token T_DOUBLE_ARROW    "=> (T_DOUBLE_ARROW)"
196 %token T_LIST            "list (T_LIST)"
197 %token T_ARRAY           "array (T_ARRAY)"
198 %token T_CALLABLE        "callable (T_CALLABLE)"
199 %token T_LINE            "__LINE__ (T_LINE)"
200 %token T_FILE            "__FILE__ (T_FILE)"
201 %token T_DIR             "__DIR__ (T_DIR)"
202 %token T_CLASS_C         "__CLASS__ (T_CLASS_C)"
203 %token T_TRAIT_C         "__TRAIT__ (T_TRAIT_C)"
204 %token T_METHOD_C        "__METHOD__ (T_METHOD_C)"
205 %token T_FUNC_C          "__FUNCTION__ (T_FUNC_C)"
206 %token T_COMMENT         "comment (T_COMMENT)"
207 %token T_DOC_COMMENT     "doc comment (T_DOC_COMMENT)"
208 %token T_OPEN_TAG        "open tag (T_OPEN_TAG)"
209 %token T_OPEN_TAG_WITH_ECHO "open tag with echo (T_OPEN_TAG_WITH_ECHO)"
210 %token T_CLOSE_TAG       "close tag (T_CLOSE_TAG)"
211 %token T_WHITESPACE      "whitespace (T_WHITESPACE)"
212 %token T_START_HEREDOC   "heredoc start (T_START_HEREDOC)"
213 %token T_END_HEREDOC     "heredoc end (T_END_HEREDOC)"
214 %token T_DOLLAR_OPEN_CURLY_BRACES "${ (T_DOLLAR_OPEN_CURLY_BRACES)"
215 %token T_CURLY_OPEN      "{$ (T_CURLY_OPEN)"
216 %token T_PAAMAYIM_NEKUDOTAYIM ":: (T_PAAMAYIM_NEKUDOTAYIM)"
217 %token T_NAMESPACE       "namespace (T_NAMESPACE)"
218 %token T_NS_C            "__NAMESPACE__ (T_NS_C)"
219 %token T_NS_SEPARATOR    "\\ (T_NS_SEPARATOR)"
220 %token T_ELLIPSIS        "... (T_ELLIPSIS)"
221 %token T_COALESCE        "?? (T_COALESCE)"
222 %token T_POW             "** (T_POW)"
223 %token T_POW_EQUAL       "**= (T_POW_EQUAL)"
224 
225 /* Token used to force a parse error from the lexer */
226 %token T_ERROR
227 
228 %type <ast> top_statement namespace_name name statement function_declaration_statement
229 %type <ast> class_declaration_statement trait_declaration_statement
230 %type <ast> interface_declaration_statement interface_extends_list
231 %type <ast> group_use_declaration inline_use_declarations inline_use_declaration
232 %type <ast> mixed_group_use_declaration use_declaration unprefixed_use_declaration
233 %type <ast> unprefixed_use_declarations const_decl inner_statement
234 %type <ast> expr optional_expr while_statement for_statement foreach_variable
235 %type <ast> foreach_statement declare_statement finally_statement unset_variable variable
236 %type <ast> extends_from parameter optional_type argument expr_without_variable global_var
237 %type <ast> static_var class_statement trait_adaptation trait_precedence trait_alias
238 %type <ast> absolute_trait_method_reference trait_method_reference property echo_expr
239 %type <ast> new_expr anonymous_class class_name class_name_reference simple_variable
240 %type <ast> internal_functions_in_yacc
241 %type <ast> exit_expr scalar backticks_expr lexical_var function_call member_name property_name
242 %type <ast> variable_class_name dereferencable_scalar constant dereferencable
243 %type <ast> callable_expr callable_variable static_member new_variable
244 %type <ast> encaps_var encaps_var_offset isset_variables
245 %type <ast> top_statement_list use_declarations const_list inner_statement_list if_stmt
246 %type <ast> alt_if_stmt for_exprs switch_case_list global_var_list static_var_list
247 %type <ast> echo_expr_list unset_variables catch_name_list catch_list parameter_list class_statement_list
248 %type <ast> implements_list case_list if_stmt_without_else
249 %type <ast> non_empty_parameter_list argument_list non_empty_argument_list property_list
250 %type <ast> class_const_list class_const_decl name_list trait_adaptations method_body non_empty_for_exprs
251 %type <ast> ctor_arguments alt_if_stmt_without_else trait_adaptation_list lexical_vars
252 %type <ast> lexical_var_list encaps_list
253 %type <ast> array_pair non_empty_array_pair_list array_pair_list possible_array_pair
254 %type <ast> isset_variable type return_type type_expr
255 %type <ast> identifier
256 
257 %type <num> returns_ref function is_reference is_variadic variable_modifiers
258 %type <num> method_modifiers non_empty_member_modifiers member_modifier
259 %type <num> class_modifiers class_modifier use_type backup_fn_flags
260 
261 %type <str> backup_doc_comment
262 
263 %% /* Rules */
264 
265 start:
266 	top_statement_list	{ CG(ast) = $1; }
267 ;
268 
269 reserved_non_modifiers:
270 	  T_INCLUDE | T_INCLUDE_ONCE | T_EVAL | T_REQUIRE | T_REQUIRE_ONCE | T_LOGICAL_OR | T_LOGICAL_XOR | T_LOGICAL_AND
271 	| T_INSTANCEOF | T_NEW | T_CLONE | T_EXIT | T_IF | T_ELSEIF | T_ELSE | T_ENDIF | T_ECHO | T_DO | T_WHILE | T_ENDWHILE
272 	| T_FOR | T_ENDFOR | T_FOREACH | T_ENDFOREACH | T_DECLARE | T_ENDDECLARE | T_AS | T_TRY | T_CATCH | T_FINALLY
273 	| T_THROW | T_USE | T_INSTEADOF | T_GLOBAL | T_VAR | T_UNSET | T_ISSET | T_EMPTY | T_CONTINUE | T_GOTO
274 	| T_FUNCTION | T_CONST | T_RETURN | T_PRINT | T_YIELD | T_LIST | T_SWITCH | T_ENDSWITCH | T_CASE | T_DEFAULT | T_BREAK
275 	| T_ARRAY | T_CALLABLE | T_EXTENDS | T_IMPLEMENTS | T_NAMESPACE | T_TRAIT | T_INTERFACE | T_CLASS
276 	| T_CLASS_C | T_TRAIT_C | T_FUNC_C | T_METHOD_C | T_LINE | T_FILE | T_DIR | T_NS_C
277 ;
278 
279 semi_reserved:
280 	  reserved_non_modifiers
281 	| T_STATIC | T_ABSTRACT | T_FINAL | T_PRIVATE | T_PROTECTED | T_PUBLIC
282 ;
283 
284 identifier:
285 		T_STRING { $$ = $1; }
286 	| 	semi_reserved  {
287 			zval zv;
288 			zend_lex_tstring(&zv);
289 			$$ = zend_ast_create_zval(&zv);
290 		}
291 ;
292 
293 top_statement_list:
294 		top_statement_list top_statement { $$ = zend_ast_list_add($1, $2); }
295 	|	/* empty */ { $$ = zend_ast_create_list(0, ZEND_AST_STMT_LIST); }
296 ;
297 
298 namespace_name:
299 		T_STRING								{ $$ = $1; }
300 	|	namespace_name T_NS_SEPARATOR T_STRING	{ $$ = zend_ast_append_str($1, $3); }
301 ;
302 
303 name:
304 		namespace_name								{ $$ = $1; $$->attr = ZEND_NAME_NOT_FQ; }
305 	|	T_NAMESPACE T_NS_SEPARATOR namespace_name	{ $$ = $3; $$->attr = ZEND_NAME_RELATIVE; }
306 	|	T_NS_SEPARATOR namespace_name				{ $$ = $2; $$->attr = ZEND_NAME_FQ; }
307 ;
308 
309 top_statement:
310 		statement							{ $$ = $1; }
311 	|	function_declaration_statement		{ $$ = $1; }
312 	|	class_declaration_statement			{ $$ = $1; }
313 	|	trait_declaration_statement			{ $$ = $1; }
314 	|	interface_declaration_statement		{ $$ = $1; }
315 	|	T_HALT_COMPILER '(' ')' ';'
316 			{ $$ = zend_ast_create(ZEND_AST_HALT_COMPILER,
317 			      zend_ast_create_zval_from_long(zend_get_scanned_file_offset()));
318 			  zend_stop_lexing(); }
319 	|	T_NAMESPACE namespace_name ';'
320 			{ $$ = zend_ast_create(ZEND_AST_NAMESPACE, $2, NULL);
321 			  RESET_DOC_COMMENT(); }
322 	|	T_NAMESPACE namespace_name { RESET_DOC_COMMENT(); }
323 		'{' top_statement_list '}'
324 			{ $$ = zend_ast_create(ZEND_AST_NAMESPACE, $2, $5); }
325 	|	T_NAMESPACE { RESET_DOC_COMMENT(); }
326 		'{' top_statement_list '}'
327 			{ $$ = zend_ast_create(ZEND_AST_NAMESPACE, NULL, $4); }
328 	|	T_USE mixed_group_use_declaration ';'		{ $$ = $2; }
329 	|	T_USE use_type group_use_declaration ';'	{ $$ = $3; $$->attr = $2; }
330 	|	T_USE use_declarations ';'					{ $$ = $2; $$->attr = ZEND_SYMBOL_CLASS; }
331 	|	T_USE use_type use_declarations ';'			{ $$ = $3; $$->attr = $2; }
332 	|	T_CONST const_list ';'						{ $$ = $2; }
333 ;
334 
335 use_type:
336 	 	T_FUNCTION 		{ $$ = ZEND_SYMBOL_FUNCTION; }
337 	| 	T_CONST 		{ $$ = ZEND_SYMBOL_CONST; }
338 ;
339 
340 group_use_declaration:
341 		namespace_name T_NS_SEPARATOR '{' unprefixed_use_declarations possible_comma '}'
342 			{ $$ = zend_ast_create(ZEND_AST_GROUP_USE, $1, $4); }
343 	|	T_NS_SEPARATOR namespace_name T_NS_SEPARATOR '{' unprefixed_use_declarations possible_comma '}'
344 			{ $$ = zend_ast_create(ZEND_AST_GROUP_USE, $2, $5); }
345 ;
346 
347 mixed_group_use_declaration:
348 		namespace_name T_NS_SEPARATOR '{' inline_use_declarations possible_comma '}'
349 			{ $$ = zend_ast_create(ZEND_AST_GROUP_USE, $1, $4);}
350 	|	T_NS_SEPARATOR namespace_name T_NS_SEPARATOR '{' inline_use_declarations possible_comma '}'
351 			{ $$ = zend_ast_create(ZEND_AST_GROUP_USE, $2, $5); }
352 ;
353 
354 possible_comma:
355 		/* empty */
356 	|	','
357 ;
358 
359 inline_use_declarations:
360 		inline_use_declarations ',' inline_use_declaration
361 			{ $$ = zend_ast_list_add($1, $3); }
362 	|	inline_use_declaration
363 			{ $$ = zend_ast_create_list(1, ZEND_AST_USE, $1); }
364 ;
365 
366 unprefixed_use_declarations:
367 		unprefixed_use_declarations ',' unprefixed_use_declaration
368 			{ $$ = zend_ast_list_add($1, $3); }
369 	|	unprefixed_use_declaration
370 			{ $$ = zend_ast_create_list(1, ZEND_AST_USE, $1); }
371 ;
372 
373 use_declarations:
374 		use_declarations ',' use_declaration
375 			{ $$ = zend_ast_list_add($1, $3); }
376 	|	use_declaration
377 			{ $$ = zend_ast_create_list(1, ZEND_AST_USE, $1); }
378 ;
379 
380 inline_use_declaration:
381 		unprefixed_use_declaration { $$ = $1; $$->attr = ZEND_SYMBOL_CLASS; }
382 	|	use_type unprefixed_use_declaration { $$ = $2; $$->attr = $1; }
383 ;
384 
385 unprefixed_use_declaration:
386 		namespace_name
387 			{ $$ = zend_ast_create(ZEND_AST_USE_ELEM, $1, NULL); }
388 	|	namespace_name T_AS T_STRING
389 			{ $$ = zend_ast_create(ZEND_AST_USE_ELEM, $1, $3); }
390 ;
391 
392 use_declaration:
393 		unprefixed_use_declaration                { $$ = $1; }
394 	|	T_NS_SEPARATOR unprefixed_use_declaration { $$ = $2; }
395 ;
396 
397 const_list:
398 		const_list ',' const_decl { $$ = zend_ast_list_add($1, $3); }
399 	|	const_decl { $$ = zend_ast_create_list(1, ZEND_AST_CONST_DECL, $1); }
400 ;
401 
402 inner_statement_list:
403 		inner_statement_list inner_statement
404 			{ $$ = zend_ast_list_add($1, $2); }
405 	|	/* empty */
406 			{ $$ = zend_ast_create_list(0, ZEND_AST_STMT_LIST); }
407 ;
408 
409 
410 inner_statement:
411 		statement { $$ = $1; }
412 	|	function_declaration_statement 		{ $$ = $1; }
413 	|	class_declaration_statement 		{ $$ = $1; }
414 	|	trait_declaration_statement			{ $$ = $1; }
415 	|	interface_declaration_statement		{ $$ = $1; }
416 	|	T_HALT_COMPILER '(' ')' ';'
417 			{ $$ = NULL; zend_error_noreturn(E_COMPILE_ERROR,
418 			      "__HALT_COMPILER() can only be used from the outermost scope"); }
419 ;
420 
421 
422 statement:
423 		'{' inner_statement_list '}' { $$ = $2; }
424 	|	if_stmt { $$ = $1; }
425 	|	alt_if_stmt { $$ = $1; }
426 	|	T_WHILE '(' expr ')' while_statement
427 			{ $$ = zend_ast_create(ZEND_AST_WHILE, $3, $5); }
428 	|	T_DO statement T_WHILE '(' expr ')' ';'
429 			{ $$ = zend_ast_create(ZEND_AST_DO_WHILE, $2, $5); }
430 	|	T_FOR '(' for_exprs ';' for_exprs ';' for_exprs ')' for_statement
431 			{ $$ = zend_ast_create(ZEND_AST_FOR, $3, $5, $7, $9); }
432 	|	T_SWITCH '(' expr ')' switch_case_list
433 			{ $$ = zend_ast_create(ZEND_AST_SWITCH, $3, $5); }
434 	|	T_BREAK optional_expr ';'		{ $$ = zend_ast_create(ZEND_AST_BREAK, $2); }
435 	|	T_CONTINUE optional_expr ';'	{ $$ = zend_ast_create(ZEND_AST_CONTINUE, $2); }
436 	|	T_RETURN optional_expr ';'		{ $$ = zend_ast_create(ZEND_AST_RETURN, $2); }
437 	|	T_GLOBAL global_var_list ';'	{ $$ = $2; }
438 	|	T_STATIC static_var_list ';'	{ $$ = $2; }
439 	|	T_ECHO echo_expr_list ';'		{ $$ = $2; }
440 	|	T_INLINE_HTML { $$ = zend_ast_create(ZEND_AST_ECHO, $1); }
441 	|	expr ';' { $$ = $1; }
442 	|	T_UNSET '(' unset_variables ')' ';' { $$ = $3; }
443 	|	T_FOREACH '(' expr T_AS foreach_variable ')' foreach_statement
444 			{ $$ = zend_ast_create(ZEND_AST_FOREACH, $3, $5, NULL, $7); }
445 	|	T_FOREACH '(' expr T_AS foreach_variable T_DOUBLE_ARROW foreach_variable ')'
446 		foreach_statement
447 			{ $$ = zend_ast_create(ZEND_AST_FOREACH, $3, $7, $5, $9); }
448 	|	T_DECLARE '(' const_list ')'
449 			{ zend_handle_encoding_declaration($3); }
450 		declare_statement
451 			{ $$ = zend_ast_create(ZEND_AST_DECLARE, $3, $6); }
452 	|	';'	/* empty statement */ { $$ = NULL; }
453 	|	T_TRY '{' inner_statement_list '}' catch_list finally_statement
454 			{ $$ = zend_ast_create(ZEND_AST_TRY, $3, $5, $6); }
455 	|	T_THROW expr ';' { $$ = zend_ast_create(ZEND_AST_THROW, $2); }
456 	|	T_GOTO T_STRING ';' { $$ = zend_ast_create(ZEND_AST_GOTO, $2); }
457 	|	T_STRING ':' { $$ = zend_ast_create(ZEND_AST_LABEL, $1); }
458 ;
459 
460 catch_list:
461 		/* empty */
462 			{ $$ = zend_ast_create_list(0, ZEND_AST_CATCH_LIST); }
463 	|	catch_list T_CATCH '(' catch_name_list T_VARIABLE ')' '{' inner_statement_list '}'
464 			{ $$ = zend_ast_list_add($1, zend_ast_create(ZEND_AST_CATCH, $4, $5, $8)); }
465 ;
466 
467 catch_name_list:
468 		name { $$ = zend_ast_create_list(1, ZEND_AST_NAME_LIST, $1); }
469 	|	catch_name_list '|' name { $$ = zend_ast_list_add($1, $3); }
470 ;
471 
472 finally_statement:
473 		/* empty */ { $$ = NULL; }
474 	|	T_FINALLY '{' inner_statement_list '}' { $$ = $3; }
475 ;
476 
477 unset_variables:
478 		unset_variable { $$ = zend_ast_create_list(1, ZEND_AST_STMT_LIST, $1); }
479 	|	unset_variables ',' unset_variable { $$ = zend_ast_list_add($1, $3); }
480 ;
481 
482 unset_variable:
483 		variable { $$ = zend_ast_create(ZEND_AST_UNSET, $1); }
484 ;
485 
486 function_declaration_statement:
487 	function returns_ref T_STRING backup_doc_comment '(' parameter_list ')' return_type
488 	backup_fn_flags '{' inner_statement_list '}' backup_fn_flags
489 		{ $$ = zend_ast_create_decl(ZEND_AST_FUNC_DECL, $2 | $13, $1, $4,
490 		      zend_ast_get_str($3), $6, NULL, $11, $8); CG(extra_fn_flags) = $9; }
491 ;
492 
493 is_reference:
494 		/* empty */	{ $$ = 0; }
495 	|	'&'			{ $$ = ZEND_PARAM_REF; }
496 ;
497 
498 is_variadic:
499 		/* empty */ { $$ = 0; }
500 	|	T_ELLIPSIS  { $$ = ZEND_PARAM_VARIADIC; }
501 ;
502 
503 class_declaration_statement:
504 		class_modifiers T_CLASS { $<num>$ = CG(zend_lineno); }
505 		T_STRING extends_from implements_list backup_doc_comment '{' class_statement_list '}'
506 			{ $$ = zend_ast_create_decl(ZEND_AST_CLASS, $1, $<num>3, $7, zend_ast_get_str($4), $5, $6, $9, NULL); }
507 	|	T_CLASS { $<num>$ = CG(zend_lineno); }
508 		T_STRING extends_from implements_list backup_doc_comment '{' class_statement_list '}'
509 			{ $$ = zend_ast_create_decl(ZEND_AST_CLASS, 0, $<num>2, $6, zend_ast_get_str($3), $4, $5, $8, NULL); }
510 ;
511 
512 class_modifiers:
513 		class_modifier 					{ $$ = $1; }
514 	|	class_modifiers class_modifier 	{ $$ = zend_add_class_modifier($1, $2); }
515 ;
516 
517 class_modifier:
518 		T_ABSTRACT 		{ $$ = ZEND_ACC_EXPLICIT_ABSTRACT_CLASS; }
519 	|	T_FINAL 		{ $$ = ZEND_ACC_FINAL; }
520 ;
521 
522 trait_declaration_statement:
523 		T_TRAIT { $<num>$ = CG(zend_lineno); }
524 		T_STRING backup_doc_comment '{' class_statement_list '}'
525 			{ $$ = zend_ast_create_decl(ZEND_AST_CLASS, ZEND_ACC_TRAIT, $<num>2, $4, zend_ast_get_str($3), NULL, NULL, $6, NULL); }
526 ;
527 
528 interface_declaration_statement:
529 		T_INTERFACE { $<num>$ = CG(zend_lineno); }
530 		T_STRING interface_extends_list backup_doc_comment '{' class_statement_list '}'
531 			{ $$ = zend_ast_create_decl(ZEND_AST_CLASS, ZEND_ACC_INTERFACE, $<num>2, $5, zend_ast_get_str($3), NULL, $4, $7, NULL); }
532 ;
533 
534 extends_from:
535 		/* empty */		{ $$ = NULL; }
536 	|	T_EXTENDS name	{ $$ = $2; }
537 ;
538 
539 interface_extends_list:
540 		/* empty */			{ $$ = NULL; }
541 	|	T_EXTENDS name_list	{ $$ = $2; }
542 ;
543 
544 implements_list:
545 		/* empty */				{ $$ = NULL; }
546 	|	T_IMPLEMENTS name_list	{ $$ = $2; }
547 ;
548 
549 foreach_variable:
550 		variable			{ $$ = $1; }
551 	|	'&' variable		{ $$ = zend_ast_create(ZEND_AST_REF, $2); }
552 	|	T_LIST '(' array_pair_list ')' { $$ = $3; $$->attr = ZEND_ARRAY_SYNTAX_LIST; }
553 	|	'[' array_pair_list ']' { $$ = $2; $$->attr = ZEND_ARRAY_SYNTAX_SHORT; }
554 ;
555 
556 for_statement:
557 		statement { $$ = $1; }
558 	|	':' inner_statement_list T_ENDFOR ';' { $$ = $2; }
559 ;
560 
561 foreach_statement:
562 		statement { $$ = $1; }
563 	|	':' inner_statement_list T_ENDFOREACH ';' { $$ = $2; }
564 ;
565 
566 declare_statement:
567 		statement { $$ = $1; }
568 	|	':' inner_statement_list T_ENDDECLARE ';' { $$ = $2; }
569 ;
570 
571 switch_case_list:
572 		'{' case_list '}'					{ $$ = $2; }
573 	|	'{' ';' case_list '}'				{ $$ = $3; }
574 	|	':' case_list T_ENDSWITCH ';'		{ $$ = $2; }
575 	|	':' ';' case_list T_ENDSWITCH ';'	{ $$ = $3; }
576 ;
577 
578 case_list:
579 		/* empty */ { $$ = zend_ast_create_list(0, ZEND_AST_SWITCH_LIST); }
580 	|	case_list T_CASE expr case_separator inner_statement_list
581 			{ $$ = zend_ast_list_add($1, zend_ast_create(ZEND_AST_SWITCH_CASE, $3, $5)); }
582 	|	case_list T_DEFAULT case_separator inner_statement_list
583 			{ $$ = zend_ast_list_add($1, zend_ast_create(ZEND_AST_SWITCH_CASE, NULL, $4)); }
584 ;
585 
586 case_separator:
587 		':'
588 	|	';'
589 ;
590 
591 
592 while_statement:
593 		statement { $$ = $1; }
594 	|	':' inner_statement_list T_ENDWHILE ';' { $$ = $2; }
595 ;
596 
597 
598 if_stmt_without_else:
599 		T_IF '(' expr ')' statement
600 			{ $$ = zend_ast_create_list(1, ZEND_AST_IF,
601 			      zend_ast_create(ZEND_AST_IF_ELEM, $3, $5)); }
602 	|	if_stmt_without_else T_ELSEIF '(' expr ')' statement
603 			{ $$ = zend_ast_list_add($1,
604 			      zend_ast_create(ZEND_AST_IF_ELEM, $4, $6)); }
605 ;
606 
607 if_stmt:
608 		if_stmt_without_else %prec T_NOELSE { $$ = $1; }
609 	|	if_stmt_without_else T_ELSE statement
610 			{ $$ = zend_ast_list_add($1, zend_ast_create(ZEND_AST_IF_ELEM, NULL, $3)); }
611 ;
612 
613 alt_if_stmt_without_else:
614 		T_IF '(' expr ')' ':' inner_statement_list
615 			{ $$ = zend_ast_create_list(1, ZEND_AST_IF,
616 			      zend_ast_create(ZEND_AST_IF_ELEM, $3, $6)); }
617 	|	alt_if_stmt_without_else T_ELSEIF '(' expr ')' ':' inner_statement_list
618 			{ $$ = zend_ast_list_add($1,
619 			      zend_ast_create(ZEND_AST_IF_ELEM, $4, $7)); }
620 ;
621 
622 alt_if_stmt:
623 		alt_if_stmt_without_else T_ENDIF ';' { $$ = $1; }
624 	|	alt_if_stmt_without_else T_ELSE ':' inner_statement_list T_ENDIF ';'
625 			{ $$ = zend_ast_list_add($1,
626 			      zend_ast_create(ZEND_AST_IF_ELEM, NULL, $4)); }
627 ;
628 
629 parameter_list:
630 		non_empty_parameter_list { $$ = $1; }
631 	|	/* empty */	{ $$ = zend_ast_create_list(0, ZEND_AST_PARAM_LIST); }
632 ;
633 
634 
635 non_empty_parameter_list:
636 		parameter
637 			{ $$ = zend_ast_create_list(1, ZEND_AST_PARAM_LIST, $1); }
638 	|	non_empty_parameter_list ',' parameter
639 			{ $$ = zend_ast_list_add($1, $3); }
640 ;
641 
642 parameter:
643 		optional_type is_reference is_variadic T_VARIABLE
644 			{ $$ = zend_ast_create_ex(ZEND_AST_PARAM, $2 | $3, $1, $4, NULL); }
645 	|	optional_type is_reference is_variadic T_VARIABLE '=' expr
646 			{ $$ = zend_ast_create_ex(ZEND_AST_PARAM, $2 | $3, $1, $4, $6); }
647 ;
648 
649 
650 optional_type:
651 		/* empty */	{ $$ = NULL; }
652 	|	type_expr	{ $$ = $1; }
653 ;
654 
655 type_expr:
656 		type		{ $$ = $1; }
657 	|	'?' type	{ $$ = $2; $$->attr |= ZEND_TYPE_NULLABLE; }
658 ;
659 
660 type:
661 		T_ARRAY		{ $$ = zend_ast_create_ex(ZEND_AST_TYPE, IS_ARRAY); }
662 	|	T_CALLABLE	{ $$ = zend_ast_create_ex(ZEND_AST_TYPE, IS_CALLABLE); }
663 	|	name		{ $$ = $1; }
664 ;
665 
666 return_type:
667 		/* empty */	{ $$ = NULL; }
668 	|	':' type_expr	{ $$ = $2; }
669 ;
670 
671 argument_list:
672 		'(' ')'	{ $$ = zend_ast_create_list(0, ZEND_AST_ARG_LIST); }
673 	|	'(' non_empty_argument_list ')' { $$ = $2; }
674 ;
675 
676 non_empty_argument_list:
677 		argument
678 			{ $$ = zend_ast_create_list(1, ZEND_AST_ARG_LIST, $1); }
679 	|	non_empty_argument_list ',' argument
680 			{ $$ = zend_ast_list_add($1, $3); }
681 ;
682 
683 argument:
684 		expr			{ $$ = $1; }
685 	|	T_ELLIPSIS expr	{ $$ = zend_ast_create(ZEND_AST_UNPACK, $2); }
686 ;
687 
688 global_var_list:
689 		global_var_list ',' global_var { $$ = zend_ast_list_add($1, $3); }
690 	|	global_var { $$ = zend_ast_create_list(1, ZEND_AST_STMT_LIST, $1); }
691 ;
692 
693 global_var:
694 	simple_variable
695 		{ $$ = zend_ast_create(ZEND_AST_GLOBAL, zend_ast_create(ZEND_AST_VAR, $1)); }
696 ;
697 
698 
699 static_var_list:
700 		static_var_list ',' static_var { $$ = zend_ast_list_add($1, $3); }
701 	|	static_var { $$ = zend_ast_create_list(1, ZEND_AST_STMT_LIST, $1); }
702 ;
703 
704 static_var:
705 		T_VARIABLE			{ $$ = zend_ast_create(ZEND_AST_STATIC, $1, NULL); }
706 	|	T_VARIABLE '=' expr	{ $$ = zend_ast_create(ZEND_AST_STATIC, $1, $3); }
707 ;
708 
709 
710 class_statement_list:
711 		class_statement_list class_statement
712 			{ $$ = zend_ast_list_add($1, $2); }
713 	|	/* empty */
714 			{ $$ = zend_ast_create_list(0, ZEND_AST_STMT_LIST); }
715 ;
716 
717 
718 class_statement:
719 		variable_modifiers property_list ';'
720 			{ $$ = $2; $$->attr = $1; }
721 	|	method_modifiers T_CONST class_const_list ';'
722 			{ $$ = $3; $$->attr = $1; }
723 	|	T_USE name_list trait_adaptations
724 			{ $$ = zend_ast_create(ZEND_AST_USE_TRAIT, $2, $3); }
725 	|	method_modifiers function returns_ref identifier backup_doc_comment '(' parameter_list ')'
726 		return_type backup_fn_flags method_body backup_fn_flags
727 			{ $$ = zend_ast_create_decl(ZEND_AST_METHOD, $3 | $1 | $12, $2, $5,
728 				  zend_ast_get_str($4), $7, NULL, $11, $9); CG(extra_fn_flags) = $10; }
729 ;
730 
731 name_list:
732 		name { $$ = zend_ast_create_list(1, ZEND_AST_NAME_LIST, $1); }
733 	|	name_list ',' name { $$ = zend_ast_list_add($1, $3); }
734 ;
735 
736 trait_adaptations:
737 		';'								{ $$ = NULL; }
738 	|	'{' '}'							{ $$ = NULL; }
739 	|	'{' trait_adaptation_list '}'	{ $$ = $2; }
740 ;
741 
742 trait_adaptation_list:
743 		trait_adaptation
744 			{ $$ = zend_ast_create_list(1, ZEND_AST_TRAIT_ADAPTATIONS, $1); }
745 	|	trait_adaptation_list trait_adaptation
746 			{ $$ = zend_ast_list_add($1, $2); }
747 ;
748 
749 trait_adaptation:
750 		trait_precedence ';'	{ $$ = $1; }
751 	|	trait_alias ';'			{ $$ = $1; }
752 ;
753 
754 trait_precedence:
755 	absolute_trait_method_reference T_INSTEADOF name_list
756 		{ $$ = zend_ast_create(ZEND_AST_TRAIT_PRECEDENCE, $1, $3); }
757 ;
758 
759 trait_alias:
760 		trait_method_reference T_AS T_STRING
761 			{ $$ = zend_ast_create_ex(ZEND_AST_TRAIT_ALIAS, 0, $1, $3); }
762 	|	trait_method_reference T_AS reserved_non_modifiers
763 			{ zval zv; zend_lex_tstring(&zv); $$ = zend_ast_create_ex(ZEND_AST_TRAIT_ALIAS, 0, $1, zend_ast_create_zval(&zv)); }
764 	|	trait_method_reference T_AS member_modifier identifier
765 			{ $$ = zend_ast_create_ex(ZEND_AST_TRAIT_ALIAS, $3, $1, $4); }
766 	|	trait_method_reference T_AS member_modifier
767 			{ $$ = zend_ast_create_ex(ZEND_AST_TRAIT_ALIAS, $3, $1, NULL); }
768 ;
769 
770 trait_method_reference:
771 		identifier
772 			{ $$ = zend_ast_create(ZEND_AST_METHOD_REFERENCE, NULL, $1); }
773 	|	absolute_trait_method_reference { $$ = $1; }
774 ;
775 
776 absolute_trait_method_reference:
777 	name T_PAAMAYIM_NEKUDOTAYIM identifier
778 		{ $$ = zend_ast_create(ZEND_AST_METHOD_REFERENCE, $1, $3); }
779 ;
780 
781 method_body:
782 		';' /* abstract method */		{ $$ = NULL; }
783 	|	'{' inner_statement_list '}'	{ $$ = $2; }
784 ;
785 
786 variable_modifiers:
787 		non_empty_member_modifiers		{ $$ = $1; }
788 	|	T_VAR							{ $$ = ZEND_ACC_PUBLIC; }
789 ;
790 
791 method_modifiers:
792 		/* empty */						{ $$ = ZEND_ACC_PUBLIC; }
793 	|	non_empty_member_modifiers
794 			{ $$ = $1; if (!($$ & ZEND_ACC_PPP_MASK)) { $$ |= ZEND_ACC_PUBLIC; } }
795 ;
796 
797 non_empty_member_modifiers:
798 		member_modifier			{ $$ = $1; }
799 	|	non_empty_member_modifiers member_modifier
800 			{ $$ = zend_add_member_modifier($1, $2); }
801 ;
802 
803 member_modifier:
804 		T_PUBLIC				{ $$ = ZEND_ACC_PUBLIC; }
805 	|	T_PROTECTED				{ $$ = ZEND_ACC_PROTECTED; }
806 	|	T_PRIVATE				{ $$ = ZEND_ACC_PRIVATE; }
807 	|	T_STATIC				{ $$ = ZEND_ACC_STATIC; }
808 	|	T_ABSTRACT				{ $$ = ZEND_ACC_ABSTRACT; }
809 	|	T_FINAL					{ $$ = ZEND_ACC_FINAL; }
810 ;
811 
812 property_list:
813 		property_list ',' property { $$ = zend_ast_list_add($1, $3); }
814 	|	property { $$ = zend_ast_create_list(1, ZEND_AST_PROP_DECL, $1); }
815 ;
816 
817 property:
818 		T_VARIABLE backup_doc_comment
819 			{ $$ = zend_ast_create(ZEND_AST_PROP_ELEM, $1, NULL, ($2 ? zend_ast_create_zval_from_str($2) : NULL)); }
820 	|	T_VARIABLE '=' expr backup_doc_comment
821 			{ $$ = zend_ast_create(ZEND_AST_PROP_ELEM, $1, $3, ($4 ? zend_ast_create_zval_from_str($4) : NULL)); }
822 ;
823 
824 class_const_list:
825 		class_const_list ',' class_const_decl { $$ = zend_ast_list_add($1, $3); }
826 	|	class_const_decl { $$ = zend_ast_create_list(1, ZEND_AST_CLASS_CONST_DECL, $1); }
827 ;
828 
829 class_const_decl:
830 	identifier '=' expr backup_doc_comment { $$ = zend_ast_create(ZEND_AST_CONST_ELEM, $1, $3, ($4 ? zend_ast_create_zval_from_str($4) : NULL)); }
831 ;
832 
833 const_decl:
834 	T_STRING '=' expr backup_doc_comment { $$ = zend_ast_create(ZEND_AST_CONST_ELEM, $1, $3, ($4 ? zend_ast_create_zval_from_str($4) : NULL)); }
835 ;
836 
837 echo_expr_list:
838 		echo_expr_list ',' echo_expr { $$ = zend_ast_list_add($1, $3); }
839 	|	echo_expr { $$ = zend_ast_create_list(1, ZEND_AST_STMT_LIST, $1); }
840 ;
841 echo_expr:
842 	expr { $$ = zend_ast_create(ZEND_AST_ECHO, $1); }
843 ;
844 
845 for_exprs:
846 		/* empty */			{ $$ = NULL; }
847 	|	non_empty_for_exprs	{ $$ = $1; }
848 ;
849 
850 non_empty_for_exprs:
851 		non_empty_for_exprs ',' expr { $$ = zend_ast_list_add($1, $3); }
852 	|	expr { $$ = zend_ast_create_list(1, ZEND_AST_EXPR_LIST, $1); }
853 ;
854 
855 anonymous_class:
856         T_CLASS { $<num>$ = CG(zend_lineno); } ctor_arguments
857 		extends_from implements_list backup_doc_comment '{' class_statement_list '}' {
858 			zend_ast *decl = zend_ast_create_decl(
859 				ZEND_AST_CLASS, ZEND_ACC_ANON_CLASS, $<num>2, $6, NULL,
860 				$4, $5, $8, NULL);
861 			$$ = zend_ast_create(ZEND_AST_NEW, decl, $3);
862 		}
863 ;
864 
865 new_expr:
866 		T_NEW class_name_reference ctor_arguments
867 			{ $$ = zend_ast_create(ZEND_AST_NEW, $2, $3); }
868 	|	T_NEW anonymous_class
869 			{ $$ = $2; }
870 ;
871 
872 expr_without_variable:
873 		T_LIST '(' array_pair_list ')' '=' expr
874 			{ $3->attr = ZEND_ARRAY_SYNTAX_LIST; $$ = zend_ast_create(ZEND_AST_ASSIGN, $3, $6); }
875 	|	'[' array_pair_list ']' '=' expr
876 			{ $2->attr = ZEND_ARRAY_SYNTAX_SHORT; $$ = zend_ast_create(ZEND_AST_ASSIGN, $2, $5); }
877 	|	variable '=' expr
878 			{ $$ = zend_ast_create(ZEND_AST_ASSIGN, $1, $3); }
879 	|	variable '=' '&' variable
880 			{ $$ = zend_ast_create(ZEND_AST_ASSIGN_REF, $1, $4); }
881 	|	T_CLONE expr { $$ = zend_ast_create(ZEND_AST_CLONE, $2); }
882 	|	variable T_PLUS_EQUAL expr
883 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_ADD, $1, $3); }
884 	|	variable T_MINUS_EQUAL expr
885 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_SUB, $1, $3); }
886 	|	variable T_MUL_EQUAL expr
887 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_MUL, $1, $3); }
888 	|	variable T_POW_EQUAL expr
889 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_POW, $1, $3); }
890 	|	variable T_DIV_EQUAL expr
891 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_DIV, $1, $3); }
892 	|	variable T_CONCAT_EQUAL expr
893 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_CONCAT, $1, $3); }
894 	|	variable T_MOD_EQUAL expr
895 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_MOD, $1, $3); }
896 	|	variable T_AND_EQUAL expr
897 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_BW_AND, $1, $3); }
898 	|	variable T_OR_EQUAL expr
899 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_BW_OR, $1, $3); }
900 	|	variable T_XOR_EQUAL expr
901 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_BW_XOR, $1, $3); }
902 	|	variable T_SL_EQUAL expr
903 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_SL, $1, $3); }
904 	|	variable T_SR_EQUAL expr
905 			{ $$ = zend_ast_create_assign_op(ZEND_ASSIGN_SR, $1, $3); }
906 	|	variable T_INC { $$ = zend_ast_create(ZEND_AST_POST_INC, $1); }
907 	|	T_INC variable { $$ = zend_ast_create(ZEND_AST_PRE_INC, $2); }
908 	|	variable T_DEC { $$ = zend_ast_create(ZEND_AST_POST_DEC, $1); }
909 	|	T_DEC variable { $$ = zend_ast_create(ZEND_AST_PRE_DEC, $2); }
910 	|	expr T_BOOLEAN_OR expr
911 			{ $$ = zend_ast_create(ZEND_AST_OR, $1, $3); }
912 	|	expr T_BOOLEAN_AND expr
913 			{ $$ = zend_ast_create(ZEND_AST_AND, $1, $3); }
914 	|	expr T_LOGICAL_OR expr
915 			{ $$ = zend_ast_create(ZEND_AST_OR, $1, $3); }
916 	|	expr T_LOGICAL_AND expr
917 			{ $$ = zend_ast_create(ZEND_AST_AND, $1, $3); }
918 	|	expr T_LOGICAL_XOR expr
919 			{ $$ = zend_ast_create_binary_op(ZEND_BOOL_XOR, $1, $3); }
920 	|	expr '|' expr	{ $$ = zend_ast_create_binary_op(ZEND_BW_OR, $1, $3); }
921 	|	expr '&' expr	{ $$ = zend_ast_create_binary_op(ZEND_BW_AND, $1, $3); }
922 	|	expr '^' expr	{ $$ = zend_ast_create_binary_op(ZEND_BW_XOR, $1, $3); }
923 	|	expr '.' expr 	{ $$ = zend_ast_create_binary_op(ZEND_CONCAT, $1, $3); }
924 	|	expr '+' expr 	{ $$ = zend_ast_create_binary_op(ZEND_ADD, $1, $3); }
925 	|	expr '-' expr 	{ $$ = zend_ast_create_binary_op(ZEND_SUB, $1, $3); }
926 	|	expr '*' expr	{ $$ = zend_ast_create_binary_op(ZEND_MUL, $1, $3); }
927 	|	expr T_POW expr	{ $$ = zend_ast_create_binary_op(ZEND_POW, $1, $3); }
928 	|	expr '/' expr	{ $$ = zend_ast_create_binary_op(ZEND_DIV, $1, $3); }
929 	|	expr '%' expr 	{ $$ = zend_ast_create_binary_op(ZEND_MOD, $1, $3); }
930 	| 	expr T_SL expr	{ $$ = zend_ast_create_binary_op(ZEND_SL, $1, $3); }
931 	|	expr T_SR expr	{ $$ = zend_ast_create_binary_op(ZEND_SR, $1, $3); }
932 	|	'+' expr %prec T_INC { $$ = zend_ast_create(ZEND_AST_UNARY_PLUS, $2); }
933 	|	'-' expr %prec T_INC { $$ = zend_ast_create(ZEND_AST_UNARY_MINUS, $2); }
934 	|	'!' expr { $$ = zend_ast_create_ex(ZEND_AST_UNARY_OP, ZEND_BOOL_NOT, $2); }
935 	|	'~' expr { $$ = zend_ast_create_ex(ZEND_AST_UNARY_OP, ZEND_BW_NOT, $2); }
936 	|	expr T_IS_IDENTICAL expr
937 			{ $$ = zend_ast_create_binary_op(ZEND_IS_IDENTICAL, $1, $3); }
938 	|	expr T_IS_NOT_IDENTICAL expr
939 			{ $$ = zend_ast_create_binary_op(ZEND_IS_NOT_IDENTICAL, $1, $3); }
940 	|	expr T_IS_EQUAL expr
941 			{ $$ = zend_ast_create_binary_op(ZEND_IS_EQUAL, $1, $3); }
942 	|	expr T_IS_NOT_EQUAL expr
943 			{ $$ = zend_ast_create_binary_op(ZEND_IS_NOT_EQUAL, $1, $3); }
944 	|	expr '<' expr
945 			{ $$ = zend_ast_create_binary_op(ZEND_IS_SMALLER, $1, $3); }
946 	|	expr T_IS_SMALLER_OR_EQUAL expr
947 			{ $$ = zend_ast_create_binary_op(ZEND_IS_SMALLER_OR_EQUAL, $1, $3); }
948 	|	expr '>' expr
949 			{ $$ = zend_ast_create(ZEND_AST_GREATER, $1, $3); }
950 	|	expr T_IS_GREATER_OR_EQUAL expr
951 			{ $$ = zend_ast_create(ZEND_AST_GREATER_EQUAL, $1, $3); }
952 	|	expr T_SPACESHIP expr
953 			{ $$ = zend_ast_create_binary_op(ZEND_SPACESHIP, $1, $3); }
954 	|	expr T_INSTANCEOF class_name_reference
955 			{ $$ = zend_ast_create(ZEND_AST_INSTANCEOF, $1, $3); }
956 	|	'(' expr ')' { $$ = $2; }
957 	|	new_expr { $$ = $1; }
958 	|	expr '?' expr ':' expr
959 			{ $$ = zend_ast_create(ZEND_AST_CONDITIONAL, $1, $3, $5); }
960 	|	expr '?' ':' expr
961 			{ $$ = zend_ast_create(ZEND_AST_CONDITIONAL, $1, NULL, $4); }
962 	|	expr T_COALESCE expr
963 			{ $$ = zend_ast_create(ZEND_AST_COALESCE, $1, $3); }
964 	|	internal_functions_in_yacc { $$ = $1; }
965 	|	T_INT_CAST expr		{ $$ = zend_ast_create_cast(IS_LONG, $2); }
966 	|	T_DOUBLE_CAST expr	{ $$ = zend_ast_create_cast(IS_DOUBLE, $2); }
967 	|	T_STRING_CAST expr	{ $$ = zend_ast_create_cast(IS_STRING, $2); }
968 	|	T_ARRAY_CAST expr	{ $$ = zend_ast_create_cast(IS_ARRAY, $2); }
969 	|	T_OBJECT_CAST expr	{ $$ = zend_ast_create_cast(IS_OBJECT, $2); }
970 	|	T_BOOL_CAST expr	{ $$ = zend_ast_create_cast(_IS_BOOL, $2); }
971 	|	T_UNSET_CAST expr	{ $$ = zend_ast_create_cast(IS_NULL, $2); }
972 	|	T_EXIT exit_expr	{ $$ = zend_ast_create(ZEND_AST_EXIT, $2); }
973 	|	'@' expr			{ $$ = zend_ast_create(ZEND_AST_SILENCE, $2); }
974 	|	scalar { $$ = $1; }
975 	|	'`' backticks_expr '`' { $$ = zend_ast_create(ZEND_AST_SHELL_EXEC, $2); }
976 	|	T_PRINT expr { $$ = zend_ast_create(ZEND_AST_PRINT, $2); }
977 	|	T_YIELD { $$ = zend_ast_create(ZEND_AST_YIELD, NULL, NULL); CG(extra_fn_flags) |= ZEND_ACC_GENERATOR; }
978 	|	T_YIELD expr { $$ = zend_ast_create(ZEND_AST_YIELD, $2, NULL); CG(extra_fn_flags) |= ZEND_ACC_GENERATOR; }
979 	|	T_YIELD expr T_DOUBLE_ARROW expr { $$ = zend_ast_create(ZEND_AST_YIELD, $4, $2); CG(extra_fn_flags) |= ZEND_ACC_GENERATOR; }
980 	|	T_YIELD_FROM expr { $$ = zend_ast_create(ZEND_AST_YIELD_FROM, $2); CG(extra_fn_flags) |= ZEND_ACC_GENERATOR; }
981 	|	function returns_ref backup_doc_comment '(' parameter_list ')' lexical_vars return_type
982 		backup_fn_flags '{' inner_statement_list '}' backup_fn_flags
983 			{ $$ = zend_ast_create_decl(ZEND_AST_CLOSURE, $2 | $13, $1, $3,
984 				  zend_string_init("{closure}", sizeof("{closure}") - 1, 0),
985 			      $5, $7, $11, $8); CG(extra_fn_flags) = $9; }
986 	|	T_STATIC function returns_ref backup_doc_comment '(' parameter_list ')' lexical_vars
987 		return_type backup_fn_flags '{' inner_statement_list '}' backup_fn_flags
988 			{ $$ = zend_ast_create_decl(ZEND_AST_CLOSURE, $3 | $14 | ZEND_ACC_STATIC, $2, $4,
989 			      zend_string_init("{closure}", sizeof("{closure}") - 1, 0),
990 			      $6, $8, $12, $9); CG(extra_fn_flags) = $10; }
991 ;
992 
993 function:
994 	T_FUNCTION { $$ = CG(zend_lineno); }
995 ;
996 
997 backup_doc_comment:
998 	/* empty */ { $$ = CG(doc_comment); CG(doc_comment) = NULL; }
999 ;
1000 
1001 backup_fn_flags:
1002 	/* empty */ { $$ = CG(extra_fn_flags); CG(extra_fn_flags) = 0; }
1003 ;
1004 
1005 returns_ref:
1006 		/* empty */	{ $$ = 0; }
1007 	|	'&'			{ $$ = ZEND_ACC_RETURN_REFERENCE; }
1008 ;
1009 
1010 lexical_vars:
1011 		/* empty */ { $$ = NULL; }
1012 	|	T_USE '(' lexical_var_list ')' { $$ = $3; }
1013 ;
1014 
1015 lexical_var_list:
1016 		lexical_var_list ',' lexical_var { $$ = zend_ast_list_add($1, $3); }
1017 	|	lexical_var { $$ = zend_ast_create_list(1, ZEND_AST_CLOSURE_USES, $1); }
1018 ;
1019 
1020 lexical_var:
1021 		T_VARIABLE		{ $$ = $1; }
1022 	|	'&' T_VARIABLE	{ $$ = $2; $$->attr = 1; }
1023 ;
1024 
1025 function_call:
1026 		name argument_list
1027 			{ $$ = zend_ast_create(ZEND_AST_CALL, $1, $2); }
1028 	|	class_name T_PAAMAYIM_NEKUDOTAYIM member_name argument_list
1029 			{ $$ = zend_ast_create(ZEND_AST_STATIC_CALL, $1, $3, $4); }
1030 	|	variable_class_name T_PAAMAYIM_NEKUDOTAYIM member_name argument_list
1031 			{ $$ = zend_ast_create(ZEND_AST_STATIC_CALL, $1, $3, $4); }
1032 	|	callable_expr argument_list
1033 			{ $$ = zend_ast_create(ZEND_AST_CALL, $1, $2); }
1034 ;
1035 
1036 class_name:
1037 		T_STATIC
1038 			{ zval zv; ZVAL_INTERNED_STR(&zv, ZSTR_KNOWN(ZEND_STR_STATIC));
1039 			  $$ = zend_ast_create_zval_ex(&zv, ZEND_NAME_NOT_FQ); }
1040 	|	name { $$ = $1; }
1041 ;
1042 
1043 class_name_reference:
1044 		class_name		{ $$ = $1; }
1045 	|	new_variable	{ $$ = $1; }
1046 ;
1047 
1048 exit_expr:
1049 		/* empty */				{ $$ = NULL; }
1050 	|	'(' optional_expr ')'	{ $$ = $2; }
1051 ;
1052 
1053 backticks_expr:
1054 		/* empty */
1055 			{ $$ = zend_ast_create_zval_from_str(ZSTR_EMPTY_ALLOC()); }
1056 	|	T_ENCAPSED_AND_WHITESPACE { $$ = $1; }
1057 	|	encaps_list { $$ = $1; }
1058 ;
1059 
1060 
1061 ctor_arguments:
1062 		/* empty */	{ $$ = zend_ast_create_list(0, ZEND_AST_ARG_LIST); }
1063 	|	argument_list { $$ = $1; }
1064 ;
1065 
1066 
1067 dereferencable_scalar:
1068 		T_ARRAY '(' array_pair_list ')'	{ $$ = $3; $$->attr = ZEND_ARRAY_SYNTAX_LONG; }
1069 	|	'[' array_pair_list ']'			{ $$ = $2; $$->attr = ZEND_ARRAY_SYNTAX_SHORT; }
1070 	|	T_CONSTANT_ENCAPSED_STRING		{ $$ = $1; }
1071 ;
1072 
1073 scalar:
1074 		T_LNUMBER 	{ $$ = $1; }
1075 	|	T_DNUMBER 	{ $$ = $1; }
1076 	|	T_LINE 		{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_LINE); }
1077 	|	T_FILE 		{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_FILE); }
1078 	|	T_DIR   	{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_DIR); }
1079 	|	T_TRAIT_C	{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_TRAIT_C); }
1080 	|	T_METHOD_C	{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_METHOD_C); }
1081 	|	T_FUNC_C	{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_FUNC_C); }
1082 	|	T_NS_C		{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_NS_C); }
1083 	|	T_CLASS_C	{ $$ = zend_ast_create_ex(ZEND_AST_MAGIC_CONST, T_CLASS_C); }
1084 	|	T_START_HEREDOC T_ENCAPSED_AND_WHITESPACE T_END_HEREDOC { $$ = $2; }
1085 	|	T_START_HEREDOC T_END_HEREDOC
1086 			{ $$ = zend_ast_create_zval_from_str(ZSTR_EMPTY_ALLOC()); }
1087 	|	'"' encaps_list '"' 	{ $$ = $2; }
1088 	|	T_START_HEREDOC encaps_list T_END_HEREDOC { $$ = $2; }
1089 	|	dereferencable_scalar	{ $$ = $1; }
1090 	|	constant			{ $$ = $1; }
1091 ;
1092 
1093 constant:
1094 		name { $$ = zend_ast_create(ZEND_AST_CONST, $1); }
1095 	|	class_name T_PAAMAYIM_NEKUDOTAYIM identifier
1096 			{ $$ = zend_ast_create(ZEND_AST_CLASS_CONST, $1, $3); }
1097 	|	variable_class_name T_PAAMAYIM_NEKUDOTAYIM identifier
1098 			{ $$ = zend_ast_create(ZEND_AST_CLASS_CONST, $1, $3); }
1099 ;
1100 
1101 expr:
1102 		variable					{ $$ = $1; }
1103 	|	expr_without_variable		{ $$ = $1; }
1104 ;
1105 
1106 optional_expr:
1107 		/* empty */	{ $$ = NULL; }
1108 	|	expr		{ $$ = $1; }
1109 ;
1110 
1111 variable_class_name:
1112 	dereferencable { $$ = $1; }
1113 ;
1114 
1115 dereferencable:
1116 		variable				{ $$ = $1; }
1117 	|	'(' expr ')'			{ $$ = $2; }
1118 	|	dereferencable_scalar	{ $$ = $1; }
1119 ;
1120 
1121 callable_expr:
1122 		callable_variable		{ $$ = $1; }
1123 	|	'(' expr ')'			{ $$ = $2; }
1124 	|	dereferencable_scalar	{ $$ = $1; }
1125 ;
1126 
1127 callable_variable:
1128 		simple_variable
1129 			{ $$ = zend_ast_create(ZEND_AST_VAR, $1); }
1130 	|	dereferencable '[' optional_expr ']'
1131 			{ $$ = zend_ast_create(ZEND_AST_DIM, $1, $3); }
1132 	|	constant '[' optional_expr ']'
1133 			{ $$ = zend_ast_create(ZEND_AST_DIM, $1, $3); }
1134 	|	dereferencable '{' expr '}'
1135 			{ $$ = zend_ast_create(ZEND_AST_DIM, $1, $3); }
1136 	|	dereferencable T_OBJECT_OPERATOR property_name argument_list
1137 			{ $$ = zend_ast_create(ZEND_AST_METHOD_CALL, $1, $3, $4); }
1138 	|	function_call { $$ = $1; }
1139 ;
1140 
1141 variable:
1142 		callable_variable
1143 			{ $$ = $1; }
1144 	|	static_member
1145 			{ $$ = $1; }
1146 	|	dereferencable T_OBJECT_OPERATOR property_name
1147 			{ $$ = zend_ast_create(ZEND_AST_PROP, $1, $3); }
1148 ;
1149 
1150 simple_variable:
1151 		T_VARIABLE			{ $$ = $1; }
1152 	|	'$' '{' expr '}'	{ $$ = $3; }
1153 	|	'$' simple_variable	{ $$ = zend_ast_create(ZEND_AST_VAR, $2); }
1154 ;
1155 
1156 static_member:
1157 		class_name T_PAAMAYIM_NEKUDOTAYIM simple_variable
1158 			{ $$ = zend_ast_create(ZEND_AST_STATIC_PROP, $1, $3); }
1159 	|	variable_class_name T_PAAMAYIM_NEKUDOTAYIM simple_variable
1160 			{ $$ = zend_ast_create(ZEND_AST_STATIC_PROP, $1, $3); }
1161 ;
1162 
1163 new_variable:
1164 		simple_variable
1165 			{ $$ = zend_ast_create(ZEND_AST_VAR, $1); }
1166 	|	new_variable '[' optional_expr ']'
1167 			{ $$ = zend_ast_create(ZEND_AST_DIM, $1, $3); }
1168 	|	new_variable '{' expr '}'
1169 			{ $$ = zend_ast_create(ZEND_AST_DIM, $1, $3); }
1170 	|	new_variable T_OBJECT_OPERATOR property_name
1171 			{ $$ = zend_ast_create(ZEND_AST_PROP, $1, $3); }
1172 	|	class_name T_PAAMAYIM_NEKUDOTAYIM simple_variable
1173 			{ $$ = zend_ast_create(ZEND_AST_STATIC_PROP, $1, $3); }
1174 	|	new_variable T_PAAMAYIM_NEKUDOTAYIM simple_variable
1175 			{ $$ = zend_ast_create(ZEND_AST_STATIC_PROP, $1, $3); }
1176 ;
1177 
1178 member_name:
1179 		identifier { $$ = $1; }
1180 	|	'{' expr '}'	{ $$ = $2; }
1181 	|	simple_variable	{ $$ = zend_ast_create(ZEND_AST_VAR, $1); }
1182 ;
1183 
1184 property_name:
1185 		T_STRING { $$ = $1; }
1186 	|	'{' expr '}'	{ $$ = $2; }
1187 	|	simple_variable	{ $$ = zend_ast_create(ZEND_AST_VAR, $1); }
1188 ;
1189 
1190 array_pair_list:
1191 		non_empty_array_pair_list
1192 			{ /* allow single trailing comma */ $$ = zend_ast_list_rtrim($1); }
1193 ;
1194 
1195 possible_array_pair:
1196 		/* empty */ { $$ = NULL; }
1197 	|	array_pair  { $$ = $1; }
1198 ;
1199 
1200 non_empty_array_pair_list:
1201 		non_empty_array_pair_list ',' possible_array_pair
1202 			{ $$ = zend_ast_list_add($1, $3); }
1203 	|	possible_array_pair
1204 			{ $$ = zend_ast_create_list(1, ZEND_AST_ARRAY, $1); }
1205 ;
1206 
1207 array_pair:
1208 		expr T_DOUBLE_ARROW expr
1209 			{ $$ = zend_ast_create(ZEND_AST_ARRAY_ELEM, $3, $1); }
1210 	|	expr
1211 			{ $$ = zend_ast_create(ZEND_AST_ARRAY_ELEM, $1, NULL); }
1212 	|	expr T_DOUBLE_ARROW '&' variable
1213 			{ $$ = zend_ast_create_ex(ZEND_AST_ARRAY_ELEM, 1, $4, $1); }
1214 	|	'&' variable
1215 			{ $$ = zend_ast_create_ex(ZEND_AST_ARRAY_ELEM, 1, $2, NULL); }
1216 	|	expr T_DOUBLE_ARROW T_LIST '(' array_pair_list ')'
1217 			{ $5->attr = ZEND_ARRAY_SYNTAX_LIST;
1218 			  $$ = zend_ast_create(ZEND_AST_ARRAY_ELEM, $5, $1); }
1219 	|	T_LIST '(' array_pair_list ')'
1220 			{ $3->attr = ZEND_ARRAY_SYNTAX_LIST;
1221 			  $$ = zend_ast_create(ZEND_AST_ARRAY_ELEM, $3, NULL); }
1222 ;
1223 
1224 encaps_list:
1225 		encaps_list encaps_var
1226 			{ $$ = zend_ast_list_add($1, $2); }
1227 	|	encaps_list T_ENCAPSED_AND_WHITESPACE
1228 			{ $$ = zend_ast_list_add($1, $2); }
1229 	|	encaps_var
1230 			{ $$ = zend_ast_create_list(1, ZEND_AST_ENCAPS_LIST, $1); }
1231 	|	T_ENCAPSED_AND_WHITESPACE encaps_var
1232 			{ $$ = zend_ast_create_list(2, ZEND_AST_ENCAPS_LIST, $1, $2); }
1233 ;
1234 
1235 encaps_var:
1236 		T_VARIABLE
1237 			{ $$ = zend_ast_create(ZEND_AST_VAR, $1); }
1238 	|	T_VARIABLE '[' encaps_var_offset ']'
1239 			{ $$ = zend_ast_create(ZEND_AST_DIM,
1240 			      zend_ast_create(ZEND_AST_VAR, $1), $3); }
1241 	|	T_VARIABLE T_OBJECT_OPERATOR T_STRING
1242 			{ $$ = zend_ast_create(ZEND_AST_PROP,
1243 			      zend_ast_create(ZEND_AST_VAR, $1), $3); }
1244 	|	T_DOLLAR_OPEN_CURLY_BRACES expr '}'
1245 			{ $$ = zend_ast_create(ZEND_AST_VAR, $2); }
1246 	|	T_DOLLAR_OPEN_CURLY_BRACES T_STRING_VARNAME '}'
1247 			{ $$ = zend_ast_create(ZEND_AST_VAR, $2); }
1248 	|	T_DOLLAR_OPEN_CURLY_BRACES T_STRING_VARNAME '[' expr ']' '}'
1249 			{ $$ = zend_ast_create(ZEND_AST_DIM,
1250 			      zend_ast_create(ZEND_AST_VAR, $2), $4); }
1251 	|	T_CURLY_OPEN variable '}' { $$ = $2; }
1252 ;
1253 
1254 encaps_var_offset:
1255 		T_STRING			{ $$ = $1; }
1256 	|	T_NUM_STRING		{ $$ = $1; }
1257 	|	'-' T_NUM_STRING 	{ $$ = zend_negate_num_string($2); }
1258 	|	T_VARIABLE			{ $$ = zend_ast_create(ZEND_AST_VAR, $1); }
1259 ;
1260 
1261 
1262 internal_functions_in_yacc:
1263 		T_ISSET '(' isset_variables ')' { $$ = $3; }
1264 	|	T_EMPTY '(' expr ')' { $$ = zend_ast_create(ZEND_AST_EMPTY, $3); }
1265 	|	T_INCLUDE expr
1266 			{ $$ = zend_ast_create_ex(ZEND_AST_INCLUDE_OR_EVAL, ZEND_INCLUDE, $2); }
1267 	|	T_INCLUDE_ONCE expr
1268 			{ $$ = zend_ast_create_ex(ZEND_AST_INCLUDE_OR_EVAL, ZEND_INCLUDE_ONCE, $2); }
1269 	|	T_EVAL '(' expr ')'
1270 			{ $$ = zend_ast_create_ex(ZEND_AST_INCLUDE_OR_EVAL, ZEND_EVAL, $3); }
1271 	|	T_REQUIRE expr
1272 			{ $$ = zend_ast_create_ex(ZEND_AST_INCLUDE_OR_EVAL, ZEND_REQUIRE, $2); }
1273 	|	T_REQUIRE_ONCE expr
1274 			{ $$ = zend_ast_create_ex(ZEND_AST_INCLUDE_OR_EVAL, ZEND_REQUIRE_ONCE, $2); }
1275 ;
1276 
1277 isset_variables:
1278 		isset_variable { $$ = $1; }
1279 	|	isset_variables ',' isset_variable
1280 			{ $$ = zend_ast_create(ZEND_AST_AND, $1, $3); }
1281 ;
1282 
1283 isset_variable:
1284 		expr { $$ = zend_ast_create(ZEND_AST_ISSET, $1); }
1285 ;
1286 
1287 %%
1288 
1289 /* Copy to YYRES the contents of YYSTR after stripping away unnecessary
1290    quotes and backslashes, so that it's suitable for yyerror.  The
1291    heuristic is that double-quoting is unnecessary unless the string
1292    contains an apostrophe, a comma, or backslash (other than
1293    backslash-backslash).  YYSTR is taken from yytname.  If YYRES is
1294    null, do not copy; instead, return the length of what the result
1295    would have been.  */
1296 static YYSIZE_T zend_yytnamerr(char *yyres, const char *yystr)
1297 {
1298 	/* CG(parse_error) states:
1299 	 * 0 => yyres = NULL, yystr is the unexpected token
1300 	 * 1 => yyres = NULL, yystr is one of the expected tokens
1301 	 * 2 => yyres != NULL, yystr is the unexpected token
1302 	 * 3 => yyres != NULL, yystr is one of the expected tokens
1303 	 */
1304 	if (yyres && CG(parse_error) < 2) {
1305 		CG(parse_error) = 2;
1306 	}
1307 
1308 	if (CG(parse_error) % 2 == 0) {
1309 		/* The unexpected token */
1310 		char buffer[120];
1311 		const unsigned char *end, *str, *tok1 = NULL, *tok2 = NULL;
1312 		unsigned int len = 0, toklen = 0, yystr_len;
1313 
1314 		CG(parse_error)++;
1315 
1316 		if (LANG_SCNG(yy_text)[0] == 0 &&
1317 			LANG_SCNG(yy_leng) == 1 &&
1318 			strcmp(yystr, "\"end of file\"") == 0) {
1319 			if (yyres) {
1320 				yystpcpy(yyres, "end of file");
1321 			}
1322 			return sizeof("end of file")-1;
1323 		}
1324 
1325 		str = LANG_SCNG(yy_text);
1326 		end = memchr(str, '\n', LANG_SCNG(yy_leng));
1327 		yystr_len = (unsigned int)yystrlen(yystr);
1328 
1329 		if ((tok1 = memchr(yystr, '(', yystr_len)) != NULL
1330 			&& (tok2 = zend_memrchr(yystr, ')', yystr_len)) != NULL) {
1331 			toklen = (tok2 - tok1) + 1;
1332 		} else {
1333 			tok1 = tok2 = NULL;
1334 			toklen = 0;
1335 		}
1336 
1337 		if (end == NULL) {
1338 			len = LANG_SCNG(yy_leng) > 30 ? 30 : LANG_SCNG(yy_leng);
1339 		} else {
1340 			len = (end - str) > 30 ? 30 : (end - str);
1341 		}
1342 		if (yyres) {
1343 			if (toklen) {
1344 				snprintf(buffer, sizeof(buffer), "'%.*s' %.*s", len, str, toklen, tok1);
1345 			} else {
1346 				snprintf(buffer, sizeof(buffer), "'%.*s'", len, str);
1347 			}
1348 			yystpcpy(yyres, buffer);
1349 		}
1350 		return len + (toklen ? toklen + 1 : 0) + 2;
1351 	}
1352 
1353 	/* One of the expected tokens */
1354 	if (!yyres) {
1355 		return yystrlen(yystr) - (*yystr == '"' ? 2 : 0);
1356 	}
1357 
1358 	if (*yystr == '"') {
1359 		YYSIZE_T yyn = 0;
1360 		const char *yyp = yystr;
1361 
1362 		for (; *++yyp != '"'; ++yyn) {
1363 			yyres[yyn] = *yyp;
1364 		}
1365 		yyres[yyn] = '\0';
1366 		return yyn;
1367 	}
1368 	yystpcpy(yyres, yystr);
1369 	return strlen(yystr);
1370 }
1371 
1372 /*
1373  * Local variables:
1374  * tab-width: 4
1375  * c-basic-offset: 4
1376  * indent-tabs-mode: t
1377  * End:
1378  * vim600: sw=4 ts=4 fdm=marker
1379  * vim<600: sw=4 ts=4
1380  */
1381