1
0
mirror of https://github.com/php/php-src.git synced 2026-03-30 12:13:02 +02:00
Files
archived-php-src/ext/standard/tests/array/usort_variation5.phpt
Peter Kokot d679f02295 Sync leading and final newlines in *.phpt sections
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
2018-10-15 04:33:09 +02:00

144 lines
2.7 KiB
PHP

--TEST--
Test usort() function : usage variations - string data
--FILE--
<?php
/* Prototype : bool usort(array $array_arg, string $cmp_function)
* Description: Sort an array by values using a user-defined comparison function
* Source code: ext/standard/array.c
*/
/*
* Pass arrays of string data to usort() to test how it is re-ordered
*/
echo "*** Testing usort() : usage variation ***\n";
function cmp_function($value1, $value2)
{
if($value1 == $value2) {
return 0;
}
else if($value1 > $value2) {
return 1;
}
else {
return -1;
}
}
// Different heredoc strings to be sorted
$empty_heredoc =<<<EOT
EOT;
$simple_heredoc1 =<<<EOT
Heredoc
EOT;
$simple_heredoc2 =<<<EOT
HEREDOC
EOT;
$multiline_heredoc =<<<EOT
heredoc string\twith!@# and 123
Test this!!!
EOT;
// Single quoted strings
$single_quoted_values = array(
0 => ' ', 1 => 'test', 3 => 'Hello', 4 => 'HELLO',
5 => '', 6 => '\t', 7 => '0', 8 => '123Hello',
9 => '\'', 10 => '@#$%'
);
echo "\n-- Sorting Single Quoted String values --\n";
var_dump( usort($single_quoted_values, 'cmp_function') );
var_dump($single_quoted_values);
// Double quoted strings
$double_quoted_values = array(
0 => " ", 1 => "test", 3 => "Hello", 4 => "HELLO",
5 => "", 6 => "\t", 7 => "0", 8 => "123Hello",
9 => "\"", 10 => "@#$%"
);
echo "\n-- Sorting Double Quoted String values --\n";
var_dump( usort($double_quoted_values, 'cmp_function') );
var_dump($double_quoted_values);
// Heredoc strings
$heredoc_values = array(0 => $empty_heredoc, 1 => $simple_heredoc1,
2 => $simple_heredoc2, 3 => $multiline_heredoc);
echo "\n-- Sorting Heredoc String values --\n";
var_dump( usort($heredoc_values, 'cmp_function') );
var_dump($heredoc_values);
?>
===DONE===
--EXPECTF--
*** Testing usort() : usage variation ***
-- Sorting Single Quoted String values --
bool(true)
array(10) {
[0]=>
string(0) ""
[1]=>
string(1) " "
[2]=>
string(1) "'"
[3]=>
string(1) "0"
[4]=>
string(8) "123Hello"
[5]=>
string(4) "@#$%"
[6]=>
string(5) "HELLO"
[7]=>
string(5) "Hello"
[8]=>
string(2) "\t"
[9]=>
string(4) "test"
}
-- Sorting Double Quoted String values --
bool(true)
array(10) {
[0]=>
string(0) ""
[1]=>
string(1) " "
[2]=>
string(1) " "
[3]=>
string(1) """
[4]=>
string(1) "0"
[5]=>
string(8) "123Hello"
[6]=>
string(4) "@#$%"
[7]=>
string(5) "HELLO"
[8]=>
string(5) "Hello"
[9]=>
string(4) "test"
}
-- Sorting Heredoc String values --
bool(true)
array(4) {
[0]=>
string(0) ""
[1]=>
string(7) "HEREDOC"
[2]=>
string(7) "Heredoc"
[3]=>
string(%d) "heredoc string with!@# and 123
Test this!!!"
}
===DONE===