From 49b4e12e54bdf915c81b9a6eae1d98b8f95d365d Mon Sep 17 00:00:00 2001 From: Nikita Popov Date: Tue, 26 Aug 2014 22:30:18 +0200 Subject: [PATCH] Add backup_doc_comment production Bison can't detect the type of a mid-rule action, even if it accesses $$, so need to create a separate rule for this. --- .../eval_parse_error_with_doc_comment.phpt | 15 ++++++ Zend/zend_language_parser.y | 47 +++++++++---------- 2 files changed, 36 insertions(+), 26 deletions(-) create mode 100644 Zend/tests/eval_parse_error_with_doc_comment.phpt diff --git a/Zend/tests/eval_parse_error_with_doc_comment.phpt b/Zend/tests/eval_parse_error_with_doc_comment.phpt new file mode 100644 index 0000000000..62561aaa79 --- /dev/null +++ b/Zend/tests/eval_parse_error_with_doc_comment.phpt @@ -0,0 +1,15 @@ +--TEST-- +eval() parse error on function with doc comment +--FILE-- + +--EXPECTF-- +Parse error: syntax error, unexpected end of file in %s(%d) : eval()'d code on line %d diff --git a/Zend/zend_language_parser.y b/Zend/zend_language_parser.y index 727cc034c7..df444f1db6 100644 --- a/Zend/zend_language_parser.y +++ b/Zend/zend_language_parser.y @@ -57,7 +57,7 @@ static YYSIZE_T zend_yytnamerr(char*, const char*); %destructor { zend_ast_destroy($$); } %destructor { zend_ast_destroy((zend_ast *) $$); } -%destructor { if ($$) STR_RELEASE($$); } +%destructor { if ($$) zend_string_release($$); } %left T_INCLUDE T_INCLUDE_ONCE T_EVAL T_REQUIRE T_REQUIRE_ONCE %left ',' @@ -254,6 +254,7 @@ static YYSIZE_T zend_yytnamerr(char*, const char*); %type returns_ref function is_reference is_variadic class_type variable_modifiers %type method_modifiers trait_modifiers non_empty_member_modifiers member_modifier +%type backup_doc_comment %% /* Rules */ @@ -411,10 +412,9 @@ unset_variable: ; function_declaration_statement: - function returns_ref T_STRING '(' parameter_list ')' - { $$ = CG(doc_comment); CG(doc_comment) = NULL; } + function returns_ref T_STRING '(' parameter_list ')' backup_doc_comment '{' inner_statement_list '}' - { $$ = zend_ast_create_decl(ZEND_AST_FUNC_DECL, $2, $1, $7, + { $$ = zend_ast_create_decl(ZEND_AST_FUNC_DECL, $2, $1, $7, zend_ast_get_str($3), $5, NULL, $9); } ; @@ -429,19 +429,13 @@ is_variadic: ; class_declaration_statement: - class_type - { $$ = CG(zend_lineno); } - T_STRING extends_from implements_list - { $$ = CG(doc_comment); CG(doc_comment) = NULL; } - '{' class_statement_list '}' - { $$ = zend_ast_create_decl(ZEND_AST_CLASS, $1, $2, $6, + class_type { $$ = CG(zend_lineno); } + T_STRING extends_from implements_list backup_doc_comment '{' class_statement_list '}' + { $$ = zend_ast_create_decl(ZEND_AST_CLASS, $1, $2, $6, zend_ast_get_str($3), $4, $5, $8); } - | T_INTERFACE - { $$ = CG(zend_lineno); } - T_STRING interface_extends_list - { $$ = CG(doc_comment); CG(doc_comment) = NULL; } - '{' class_statement_list '}' - { $$ = zend_ast_create_decl(ZEND_AST_CLASS, ZEND_ACC_INTERFACE, $2, $5, + | T_INTERFACE { $$ = CG(zend_lineno); } + T_STRING interface_extends_list backup_doc_comment '{' class_statement_list '}' + { $$ = zend_ast_create_decl(ZEND_AST_CLASS, ZEND_ACC_INTERFACE, $2, $5, zend_ast_get_str($3), NULL, $4, $7); } ; @@ -630,10 +624,9 @@ class_statement: { $$ = $2; RESET_DOC_COMMENT(); } | T_USE name_list trait_adaptations { $$ = zend_ast_create(ZEND_AST_USE_TRAIT, $2, $3); } - | method_modifiers function returns_ref T_STRING '(' parameter_list ')' - { $$ = CG(doc_comment); CG(doc_comment) = NULL; } + | method_modifiers function returns_ref T_STRING '(' parameter_list ')' backup_doc_comment method_body - { $$ = zend_ast_create_decl(ZEND_AST_METHOD, $3 | $1, $2, $8, + { $$ = zend_ast_create_decl(ZEND_AST_METHOD, $3 | $1, $2, $8, zend_ast_get_str($4), $6, NULL, $9); } ; @@ -876,17 +869,15 @@ expr_without_variable: | T_YIELD expr { $$ = zend_ast_create(ZEND_AST_YIELD, $2, NULL); } | T_YIELD expr T_DOUBLE_ARROW expr { $$ = zend_ast_create(ZEND_AST_YIELD, $4, $2); } - | function returns_ref '(' parameter_list ')' lexical_vars - { $$ = CG(doc_comment); CG(doc_comment) = NULL; } + | function returns_ref '(' parameter_list ')' lexical_vars backup_doc_comment '{' inner_statement_list '}' - { $$ = zend_ast_create_decl(ZEND_AST_CLOSURE, $2, $1, $7, + { $$ = zend_ast_create_decl(ZEND_AST_CLOSURE, $2, $1, $7, zend_string_init("{closure}", sizeof("{closure}") - 1, 0), $4, $6, $9); } - | T_STATIC function returns_ref '(' parameter_list ')' lexical_vars - { $$ = CG(doc_comment); CG(doc_comment) = NULL; } + | T_STATIC function returns_ref '(' parameter_list ')' lexical_vars backup_doc_comment '{' inner_statement_list '}' - { $$ = zend_ast_create_decl(ZEND_AST_CLOSURE, $3 | ZEND_ACC_STATIC, $2, - $8, zend_string_init("{closure}", sizeof("{closure}") - 1, 0), + { $$ = zend_ast_create_decl(ZEND_AST_CLOSURE, $3 | ZEND_ACC_STATIC, $2, $8, + zend_string_init("{closure}", sizeof("{closure}") - 1, 0), $5, $7, $10); } ; @@ -894,6 +885,10 @@ function: T_FUNCTION { $$ = CG(zend_lineno); } ; +backup_doc_comment: + /* empty */ { $$ = CG(doc_comment); CG(doc_comment) = NULL; } +; + returns_ref: /* empty */ { $$ = 0; } | '&' { $$ = ZEND_ACC_RETURN_REFERENCE; } -- 2.40.0