]> granicus.if.org Git - php/commitdiff
do not search for empty strings with strpos() and strrpos()
authorAntony Dovgal <tony2001@php.net>
Wed, 6 Sep 2006 12:07:27 +0000 (12:07 +0000)
committerAntony Dovgal <tony2001@php.net>
Wed, 6 Sep 2006 12:07:27 +0000 (12:07 +0000)
ext/iconv/iconv.c
ext/iconv/tests/iconv_strpos.phpt
ext/iconv/tests/iconv_strrpos.phpt

index 152bbe25a0a0170ca2ab71af58e826fef09d23bc..433979f6ed1c6b0410217fe97338384d6ade9f78 100644 (file)
@@ -1949,6 +1949,10 @@ PHP_FUNCTION(iconv_strpos)
                RETURN_FALSE;
        }
 
+       if (ndl_len < 1) {
+               RETURN_FALSE;
+       }
+
        err = _php_iconv_strpos(&retval, haystk, haystk_len, ndl, ndl_len,
                                offset, charset); 
        _php_iconv_show_error(err, GENERIC_SUPERSET_NAME, charset TSRMLS_CC);
@@ -1984,6 +1988,10 @@ PHP_FUNCTION(iconv_strrpos)
                RETURN_FALSE;
        }
 
+       if (ndl_len < 1) {
+               RETURN_FALSE;
+       }
+
        err = _php_iconv_strpos(&retval, haystk, haystk_len, ndl, ndl_len,
                                -1, charset); 
        _php_iconv_show_error(err, GENERIC_SUPERSET_NAME, charset TSRMLS_CC);
index 5820b150ce09c85de05030aa537f8ad659418890..8cbed8d2aaf0d70b53efb2bfe6b77dbf8dc02c14 100644 (file)
@@ -33,6 +33,9 @@ foo(str_repeat("abcab", 60)."abcdb".str_repeat("adabc", 60), "abcd", 0);
 foo(str_repeat("¤¢¤¤¤¦¤¨¤ª", 30)."¤¤¤¦¤ª¤¨¤¢".str_repeat("¤¢¤¤¤¨¤ª¤¦", 30), "¤¦¤ª", 0, "EUC-JP");
 $str = str_repeat("¤¢¤¤¤¦¤¨¤ª", 60).'$'.str_repeat("¤¢¤¤¤¨¤ª¤¦", 60);
 foo($str, '$', 0, "ISO-2022-JP", "EUC-JP");
+
+var_dump(iconv_strpos("string", ""));
+var_dump(iconv_strpos("", "string"));
 ?>
 --EXPECTF--
 2: %s
@@ -52,3 +55,5 @@ int(302)
 int(151)
 int(1)
 int(300)
+bool(false)
+bool(false)
index c395834e5560356726fe0e5d9173f98a475b780e..37e62b136e0a88a2197fc2f8c21859e31f92db4d 100644 (file)
@@ -34,6 +34,9 @@ for ($i = 0; $i <=6; ++$i) {
        $str = str_repeat("¤¢¤¤¤¦¤¨¤ª", 60).str_repeat('$', $i).str_repeat("¤¢¤¤¤¨¤ª¤¦", 60);
        foo($str, '$', "ISO-2022-JP", "EUC-JP");
 }
+
+var_dump(iconv_strrpos("string", ""));
+var_dump(iconv_strrpos("", "string"));
 ?>
 --EXPECT--
 int(14)
@@ -56,3 +59,5 @@ int(605)
 int(304)
 int(606)
 int(305)
+bool(false)
+bool(false)