summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph M. Becker <cmb@php.net>2016-07-28 13:59:13 +0200
committerChristoph M. Becker <cmb@php.net>2016-07-28 14:03:40 +0200
commita621023168ee00104dac20c996df3c9e8ad8edcf (patch)
tree5ccc11d08a7631f8a32fc7faa3aeff02a1a6acbe
parent18a37eeeece3c8ff88a5c9fff0bc3871cbe37c17 (diff)
parent56cdaecb284b2b292ce1ecb076c1f8b041e47a02 (diff)
downloadphp-git-a621023168ee00104dac20c996df3c9e8ad8edcf.tar.gz
Merge branch 'PHP-5.6' into PHP-7.0
-rw-r--r--NEWS2
-rw-r--r--ext/mbstring/php_mbregex.c2
-rw-r--r--ext/mbstring/tests/bug72691.phpt8
-rw-r--r--ext/mbstring/tests/bug72693.phpt41
4 files changed, 48 insertions, 5 deletions
diff --git a/NEWS b/NEWS
index d7a956990f..3fe60ff8ea 100644
--- a/NEWS
+++ b/NEWS
@@ -61,6 +61,8 @@ PHP NEWS
- mbstring:
. Fixed bug #72691 (mb_ereg_search raises a warning if a match zero-width).
(cmb)
+ . Fixed Bug #72693 (mb_ereg_search increments search position when a match
+ zero-width). (cmb)
- Opcache:
. Fixed bug #72590 (Opcache restart with kill_all_lockers does not work).
diff --git a/ext/mbstring/php_mbregex.c b/ext/mbstring/php_mbregex.c
index 95932e31ae..c86ea53ea1 100644
--- a/ext/mbstring/php_mbregex.c
+++ b/ext/mbstring/php_mbregex.c
@@ -1272,7 +1272,7 @@ _php_mb_regex_ereg_search_exec(INTERNAL_FUNCTION_PARAMETERS, int mode)
break;
}
end = MBREX(search_regs)->end[0];
- if (pos < end) {
+ if (pos <= end) {
MBREX(search_pos) = end;
} else {
MBREX(search_pos) = pos + 1;
diff --git a/ext/mbstring/tests/bug72691.phpt b/ext/mbstring/tests/bug72691.phpt
index d914a508e0..08f6b153da 100644
--- a/ext/mbstring/tests/bug72691.phpt
+++ b/ext/mbstring/tests/bug72691.phpt
@@ -26,12 +26,12 @@ var_dump(mb_ereg_search_getpos());
var_dump(mb_ereg_search_getregs());
?>
--EXPECT--
-int(1)
+int(0)
array(1) {
[0]=>
string(0) ""
}
-int(2)
+int(0)
array(1) {
[0]=>
string(0) ""
@@ -39,9 +39,9 @@ array(1) {
int(3)
array(1) {
[0]=>
- string(1) "o"
+ string(3) "foo"
}
-int(4)
+int(3)
array(1) {
[0]=>
string(0) ""
diff --git a/ext/mbstring/tests/bug72693.phpt b/ext/mbstring/tests/bug72693.phpt
new file mode 100644
index 0000000000..f269e57f0f
--- /dev/null
+++ b/ext/mbstring/tests/bug72693.phpt
@@ -0,0 +1,41 @@
+--TEST--
+Bug #72693 (mb_ereg_search increments search position when a match zero-width)
+--SKIPIF--
+<?php
+if (!extension_loaded('mbstring')) die('skip ext/mbstring required');
+?>
+--FILE--
+<?php
+mb_ereg_search_init('foo');
+
+var_dump(mb_ereg_search('\A'));
+var_dump(mb_ereg_search_getpos());
+
+var_dump(mb_ereg_search('\s*'));
+var_dump(mb_ereg_search_getpos());
+
+var_dump(mb_ereg_search('\w+'));
+var_dump(mb_ereg_search_getpos());
+var_dump(mb_ereg_search_getregs());
+
+var_dump(mb_ereg_search('\s*'));
+var_dump(mb_ereg_search_getpos());
+
+var_dump(mb_ereg_search('\Z'));
+var_dump(mb_ereg_search_getpos());
+?>
+--EXPECT--
+bool(true)
+int(0)
+bool(true)
+int(0)
+bool(true)
+int(3)
+array(1) {
+ [0]=>
+ string(3) "foo"
+}
+bool(true)
+int(3)
+bool(true)
+int(3)