summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2006-04-12 09:51:54 +0000
committerDmitry Stogov <dmitry@php.net>2006-04-12 09:51:54 +0000
commit6e762e648cf4d731048b3398baf7974277ab02e0 (patch)
treeedafb3a3e5385dff9abe929a5bf1d86ed91e5c46
parent6a4faee367b446166420473235e7521496048493 (diff)
downloadphp-git-6e762e648cf4d731048b3398baf7974277ab02e0.tar.gz
Fixed bug #37002 (Have to quote literals in INI when concatenating with vars)
-rw-r--r--NEWS4
-rw-r--r--Zend/zend_ini_parser.y13
2 files changed, 11 insertions, 6 deletions
diff --git a/NEWS b/NEWS
index de969bd7cc..b3be54834a 100644
--- a/NEWS
+++ b/NEWS
@@ -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); }