diff options
author | Dmitry Stogov <dmitry@php.net> | 2006-04-12 09:51:54 +0000 |
---|---|---|
committer | Dmitry Stogov <dmitry@php.net> | 2006-04-12 09:51:54 +0000 |
commit | 6e762e648cf4d731048b3398baf7974277ab02e0 (patch) | |
tree | edafb3a3e5385dff9abe929a5bf1d86ed91e5c46 | |
parent | 6a4faee367b446166420473235e7521496048493 (diff) | |
download | php-git-6e762e648cf4d731048b3398baf7974277ab02e0.tar.gz |
Fixed bug #37002 (Have to quote literals in INI when concatenating with vars)
-rw-r--r-- | NEWS | 4 | ||||
-rw-r--r-- | Zend/zend_ini_parser.y | 13 |
2 files changed, 11 insertions, 6 deletions
@@ -1,5 +1,9 @@ PHP NEWS ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| +?? Apr 2006, PHP 5.1.3 +- Fixed bug #37002 (Have to quote literals in INI when concatenating with + vars). (Dmitry) + 06 Apr 2006, PHP 5.1.3RC3 - Eliminated run-time constant fetching for TRUE, FALSE and NULL. (Dmitry) - Changed SOAP extension to cache WSDL structure in memory and thus speed up diff --git a/Zend/zend_ini_parser.y b/Zend/zend_ini_parser.y index 8c1976ac88..244673dba6 100644 --- a/Zend/zend_ini_parser.y +++ b/Zend/zend_ini_parser.y @@ -249,25 +249,26 @@ string_or_value: expr { $$ = $1; } | CFG_TRUE { $$ = $1; } | CFG_FALSE { $$ = $1; } - | var_string_list { $$ = $1; } | '\n' { zend_ini_init_string(&$$); } | /* empty */ { zend_ini_init_string(&$$); } ; var_string_list: - var_string_list cfg_var_ref { zend_ini_add_string(&$$, &$1, &$2); free($2.value.str.val); } + cfg_var_ref { $$ = $1; } + | TC_ENCAPSULATED_STRING { $$ = $1; } + | constant_string { $$ = $1; } + | var_string_list cfg_var_ref { zend_ini_add_string(&$$, &$1, &$2); free($2.value.str.val); } | var_string_list TC_ENCAPSULATED_STRING { zend_ini_add_string(&$$, &$1, &$2); free($2.value.str.val); } - | var_string_list constant_string { zend_ini_add_string(&$$, &$1, &$2); } - | /* empty */ { zend_ini_init_string(&$$); } + | var_string_list constant_string { zend_ini_add_string(&$$, &$1, &$2); free($2.value.str.val); } ; cfg_var_ref: - TC_DOLLAR_CURLY TC_STRING '}' { zend_ini_get_var(&$$, &$2); } + TC_DOLLAR_CURLY TC_STRING '}' { zend_ini_get_var(&$$, &$2); free($2.value.str.val); } ; expr: - constant_string { $$ = $1; } + var_string_list { $$ = $1; } | expr '|' expr { zend_ini_do_op('|', &$$, &$1, &$3); } | expr '&' expr { zend_ini_do_op('&', &$$, &$1, &$3); } | '~' expr { zend_ini_do_op('~', &$$, &$2, NULL); } |