From: Xinchen Hui Date: Mon, 13 Jun 2016 16:21:14 +0000 (-0700) Subject: Fixed bug #72395 (list() regression) X-Git-Tag: php-7.1.0alpha3~42^2~19 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=dcd1c29f793e36c4595257644857809d2250ec49;p=php Fixed bug #72395 (list() regression) --- diff --git a/NEWS b/NEWS index e67720a5a8..88dac1ee04 100644 --- a/NEWS +++ b/NEWS @@ -3,6 +3,7 @@ PHP NEWS ?? ??? 2016, PHP 7.1.0alpha2 - Core: + . Fixed bug #72395 (list() regression). (Laruence) . Fixed bug #72373 (TypeError after Generator function w/declared return type finishes). (Nikita) diff --git a/Zend/tests/bug72395.phpt b/Zend/tests/bug72395.phpt new file mode 100644 index 0000000000..e89ecdd5ad --- /dev/null +++ b/Zend/tests/bug72395.phpt @@ -0,0 +1,10 @@ +--TEST-- +Bug #72395 (list() regression) +--FILE-- + +--EXPECT-- +int(3) +int(5) diff --git a/Zend/zend_language_parser.y b/Zend/zend_language_parser.y index 44c5cfb12b..c37bd7f20c 100644 --- a/Zend/zend_language_parser.y +++ b/Zend/zend_language_parser.y @@ -250,7 +250,7 @@ static YYSIZE_T zend_yytnamerr(char*, const char*); %type class_const_list class_const_decl name_list trait_adaptations method_body non_empty_for_exprs %type ctor_arguments alt_if_stmt_without_else trait_adaptation_list lexical_vars %type lexical_var_list encaps_list -%type array_pair non_empty_array_pair_list array_pair_list +%type array_pair non_empty_array_pair_list array_pair_list possible_array_pair %type isset_variable type return_type type_expr %type identifier @@ -1183,21 +1183,19 @@ property_name: ; array_pair_list: - /* empty */ { $$ = zend_ast_create_list(0, ZEND_AST_ARRAY); } - | non_empty_array_pair_list { /* allow single trailing comma */ zend_ast_list *list = zend_ast_get_list($$ = $1); if (list->child[list->children - 1] == NULL) { list->children--; } } + non_empty_array_pair_list { /* allow single trailing comma */ zend_ast_list *list = zend_ast_get_list($$ = $1); if (list->child[list->children - 1] == NULL) { list->children--; } } +; + +possible_array_pair: + /* empty */ { $$ = NULL; } + | array_pair { $$ = $1; } ; non_empty_array_pair_list: - non_empty_array_pair_list ',' array_pair + non_empty_array_pair_list ',' possible_array_pair { $$ = zend_ast_list_add($1, $3); } - | array_pair + | possible_array_pair { $$ = zend_ast_create_list(1, ZEND_AST_ARRAY, $1); } - | non_empty_array_pair_list ',' /* empty, for LHS array lists */ - { $$ = zend_ast_list_add($1, NULL); } - | ',' - { $$ = zend_ast_create_list(1, ZEND_AST_ARRAY, NULL); } - | ',' array_pair - { $$ = zend_ast_create_list(2, ZEND_AST_ARRAY, NULL, $2); } ; array_pair: