mirror of
https://github.com/php/php-src.git
synced 2026-03-26 01:02:25 +01:00
This patch adds missing newlines, trims multiple redundant final newlines into a single one, and trims redundant leading newlines in all *.phpt sections. According to POSIX, a line is a sequence of zero or more non-' <newline>' characters plus a terminating '<newline>' character. [1] Files should normally have at least one final newline character. C89 [2] and later standards [3] mention a final newline: "A source file that is not empty shall end in a new-line character, which shall not be immediately preceded by a backslash character." Although it is not mandatory for all files to have a final newline fixed, a more consistent and homogeneous approach brings less of commit differences issues and a better development experience in certain text editors and IDEs. [1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap03.html#tag_03_206 [2] https://port70.net/~nsz/c/c89/c89-draft.html#2.1.1.2 [3] https://port70.net/~nsz/c/c99/n1256.html#5.1.1.2
84 lines
2.0 KiB
PHP
84 lines
2.0 KiB
PHP
--TEST--
|
|
Test mb_strrpos() function : mb_strrpos offset is byte count for negative values
|
|
--SKIPIF--
|
|
<?php
|
|
extension_loaded('mbstring') or die('skip');
|
|
function_exists('mb_strrpos') or die("skip mb_strrpos() is not available in this build");
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
/* Prototype : int mb_strrpos(string $haystack, string $needle [, int $offset [, string $encoding]])
|
|
* Description: Find position of last occurrence of a string within another
|
|
* Source code: ext/mbstring/mbstring.c
|
|
*/
|
|
|
|
/*
|
|
* Test that mb_strrpos offset is byte count for negative values (should be character count)
|
|
*/
|
|
|
|
$offsets = array(-25, -24, -13, -12);
|
|
$string_mb =
|
|
base64_decode('5pel5pys6Kqe44OG44Kt44K544OI44Gn44GZ44CCMDEyMzTvvJXvvJbvv
|
|
JfvvJjvvJnjgII=');
|
|
$needle = base64_decode('44CC');
|
|
|
|
foreach ($offsets as $i) {
|
|
echo "\n-- Offset is $i --\n";
|
|
echo "Multibyte String:\n";
|
|
var_dump( mb_strrpos($string_mb, $needle, $i, 'UTF-8') );
|
|
echo "ASCII String:\n";
|
|
echo "mb_strrpos:\n";
|
|
var_dump(mb_strrpos('This is na English ta', 'a', $i));
|
|
echo "strrpos:\n";
|
|
var_dump(strrpos('This is na English ta', 'a', $i));
|
|
}
|
|
?>
|
|
--EXPECTF--
|
|
-- Offset is -25 --
|
|
Multibyte String:
|
|
|
|
Warning: mb_strrpos(): Offset is greater than the length of haystack string in %s on line %d
|
|
bool(false)
|
|
ASCII String:
|
|
mb_strrpos:
|
|
|
|
Warning: mb_strrpos(): Offset is greater than the length of haystack string in %s on line %d
|
|
bool(false)
|
|
strrpos:
|
|
|
|
Warning: strrpos(): Offset is greater than the length of haystack string in %s on line %d
|
|
bool(false)
|
|
|
|
-- Offset is -24 --
|
|
Multibyte String:
|
|
|
|
Warning: mb_strrpos(): Offset is greater than the length of haystack string in %s on line %d
|
|
bool(false)
|
|
ASCII String:
|
|
mb_strrpos:
|
|
|
|
Warning: mb_strrpos(): Offset is greater than the length of haystack string in %s on line %d
|
|
bool(false)
|
|
strrpos:
|
|
|
|
Warning: strrpos(): Offset is greater than the length of haystack string in %s on line %d
|
|
bool(false)
|
|
|
|
-- Offset is -13 --
|
|
Multibyte String:
|
|
bool(false)
|
|
ASCII String:
|
|
mb_strrpos:
|
|
bool(false)
|
|
strrpos:
|
|
bool(false)
|
|
|
|
-- Offset is -12 --
|
|
Multibyte String:
|
|
int(9)
|
|
ASCII String:
|
|
mb_strrpos:
|
|
int(9)
|
|
strrpos:
|
|
int(9)
|