diff options
| author | Nikita Popov <nikic@php.net> | 2015-08-20 11:47:43 +0200 | 
|---|---|---|
| committer | Nikita Popov <nikic@php.net> | 2015-08-20 11:47:43 +0200 | 
| commit | 186b0f3770e9831cf9e416b51afd29830b56c1e1 (patch) | |
| tree | 4d0b3f1e40bacf38a408bf75daf3e61159e7a163 | |
| parent | 4d7a8f119e7f52737605acab797bcb5d6ef1fc58 (diff) | |
| download | php-git-186b0f3770e9831cf9e416b51afd29830b56c1e1.tar.gz | |
Don't allow leading \ in group use decl list
We recently added support for "use \Foo\{Bar}". This commit drops
support for the reverse "use Foo\{\Bar}". Those two got mixed up
in the initial implementation.
| -rw-r--r-- | Zend/tests/ns_094.phpt | 3 | ||||
| -rw-r--r-- | Zend/tests/ns_096.phpt | 10 | ||||
| -rw-r--r-- | Zend/zend_language_parser.y | 31 | 
3 files changed, 31 insertions, 13 deletions
| diff --git a/Zend/tests/ns_094.phpt b/Zend/tests/ns_094.phpt index ef9ca75bb3..16001da67e 100644 --- a/Zend/tests/ns_094.phpt +++ b/Zend/tests/ns_094.phpt @@ -12,5 +12,4 @@ use const Foo\Bar\{  };  --EXPECTF-- - -Parse error: syntax error, unexpected 'const' (T_CONST), expecting identifier (T_STRING) or \\ (T_NS_SEPARATOR) in %s on line 7 +Parse error: syntax error, unexpected 'const' (T_CONST), expecting identifier (T_STRING) in %s on line 7 diff --git a/Zend/tests/ns_096.phpt b/Zend/tests/ns_096.phpt new file mode 100644 index 0000000000..31eb1d1a19 --- /dev/null +++ b/Zend/tests/ns_096.phpt @@ -0,0 +1,10 @@ +--TEST-- +Group use declaration list should not contain leading separator +--FILE-- +<?php + +use Foo\Bar\{\Baz}; + +?> +--EXPECTF-- +Parse error: syntax error, unexpected '\' (T_NS_SEPARATOR), expecting identifier (T_STRING) or function (T_FUNCTION) or const (T_CONST) in /home/nikic/php-src/Zend/tests/ns_096.php on line 3 diff --git a/Zend/zend_language_parser.y b/Zend/zend_language_parser.y index 8d09650036..87365a145e 100644 --- a/Zend/zend_language_parser.y +++ b/Zend/zend_language_parser.y @@ -229,7 +229,8 @@ static YYSIZE_T zend_yytnamerr(char*, const char*);  %type <ast> class_declaration_statement trait_declaration_statement  %type <ast> interface_declaration_statement interface_extends_list  %type <ast> group_use_declaration inline_use_declarations inline_use_declaration -%type <ast> mixed_group_use_declaration use_declaration const_decl inner_statement +%type <ast> mixed_group_use_declaration use_declaration unprefixed_use_declaration +%type <ast> unprefixed_use_declarations const_decl inner_statement  %type <ast> expr optional_expr while_statement for_statement foreach_variable  %type <ast> foreach_statement declare_statement finally_statement unset_variable variable  %type <ast> extends_from parameter optional_type argument expr_without_variable global_var @@ -335,9 +336,9 @@ use_type:  ;  group_use_declaration: -		namespace_name T_NS_SEPARATOR '{' use_declarations '}' +		namespace_name T_NS_SEPARATOR '{' unprefixed_use_declarations '}'  			{ $$ = zend_ast_create(ZEND_AST_GROUP_USE, $1, $4); } -	|	T_NS_SEPARATOR namespace_name T_NS_SEPARATOR '{' use_declarations '}' +	|	T_NS_SEPARATOR namespace_name T_NS_SEPARATOR '{' unprefixed_use_declarations '}'  			{ $$ = zend_ast_create(ZEND_AST_GROUP_USE, $2, $5); }  ; @@ -355,9 +356,11 @@ inline_use_declarations:  			{ $$ = zend_ast_create_list(1, ZEND_AST_USE, $1); }  ; -inline_use_declaration: -		use_declaration { $$ = $1; $$->attr = T_CLASS; } -	|	use_type use_declaration { $$ = $2; $$->attr = $1; } +unprefixed_use_declarations: +		unprefixed_use_declarations ',' unprefixed_use_declaration +			{ $$ = zend_ast_list_add($1, $3); } +	|	unprefixed_use_declaration +			{ $$ = zend_ast_create_list(1, ZEND_AST_USE, $1); }  ;  use_declarations: @@ -367,15 +370,21 @@ use_declarations:  			{ $$ = zend_ast_create_list(1, ZEND_AST_USE, $1); }  ; -use_declaration: +inline_use_declaration: +		unprefixed_use_declaration { $$ = $1; $$->attr = T_CLASS; } +	|	use_type unprefixed_use_declaration { $$ = $2; $$->attr = $1; } +; + +unprefixed_use_declaration:  		namespace_name  			{ $$ = zend_ast_create(ZEND_AST_USE_ELEM, $1, NULL); }  	|	namespace_name T_AS T_STRING  			{ $$ = zend_ast_create(ZEND_AST_USE_ELEM, $1, $3); } -	|	T_NS_SEPARATOR namespace_name -			{ $$ = zend_ast_create(ZEND_AST_USE_ELEM, $2, NULL); } -	|	T_NS_SEPARATOR namespace_name T_AS T_STRING -			{ $$ = zend_ast_create(ZEND_AST_USE_ELEM, $2, $4); } +; + +use_declaration: +		unprefixed_use_declaration                { $$ = $1; } +	|	T_NS_SEPARATOR unprefixed_use_declaration { $$ = $2; }  ;  const_list: | 
