From 866908ca97d554cee91964695e4bc0be1f36d824 Mon Sep 17 00:00:00 2001 From: Dmitry Stogov Date: Tue, 11 Oct 2005 06:46:18 +0000 Subject: Fixed bug #34790 (preg_match_all(), named capturing groups, variable assignment/return => crash) --- ext/pcre/php_pcre.c | 1 + ext/pcre/tests/bug34790.phpt | 23 +++++++++++++++++++++++ 2 files changed, 24 insertions(+) create mode 100755 ext/pcre/tests/bug34790.phpt (limited to 'ext/pcre') diff --git a/ext/pcre/php_pcre.c b/ext/pcre/php_pcre.c index a0846214ba..e10b6f4988 100644 --- a/ext/pcre/php_pcre.c +++ b/ext/pcre/php_pcre.c @@ -620,6 +620,7 @@ static void php_pcre_match(INTERNAL_FUNCTION_PARAMETERS, int global) if (subpat_names[i]) { zend_hash_update(Z_ARRVAL_P(subpats), subpat_names[i], strlen(subpat_names[i])+1, &match_sets[i], sizeof(zval *), NULL); + ZVAL_ADDREF(match_sets[i]); } zend_hash_next_index_insert(Z_ARRVAL_P(subpats), &match_sets[i], sizeof(zval *), NULL); } diff --git a/ext/pcre/tests/bug34790.phpt b/ext/pcre/tests/bug34790.phpt new file mode 100755 index 0000000000..c375ae5ac8 --- /dev/null +++ b/ext/pcre/tests/bug34790.phpt @@ -0,0 +1,23 @@ +--TEST-- +Bug #34790 (preg_match_all(), named capturing groups, variable assignment/return => crash) +--FILE-- +the)/', $string, $matches); + return $matches['word']; +} +$words = func1(); +var_dump($words); +?> +--EXPECT-- +array(4) { + [0]=> + string(3) "the" + [1]=> + string(3) "the" + [2]=> + string(3) "the" + [3]=> + string(3) "the" +} -- cgit v1.2.1