1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
--TEST--
Test array_multisort() function : natural sorting case-insensitive
--FILE--
<?php
/* Prototype : bool array_multisort(array ar1 [, SORT_ASC|SORT_DESC [, SORT_REGULAR|SORT_NUMERIC|SORT_STRING|SORT_NATURAL|SORT_FLAG_CASE]] [, array ar2 [, SORT_ASC|SORT_DESC [, SORT_REGULAR|SORT_NUMERIC|SORT_STRING|SORT_NATURAL|SORT_FLAG_CASE], ...])
* Description: Sort multiple arrays at once similar to how ORDER BY clause works in SQL
* Source code: ext/standard/array.c
* Alias to functions:
*/
echo "*** Testing array_multisort() : natural sorting case-insensitive\n";
$a = array(
'Second',
'First.1',
'First.2',
'First.3',
'Twentieth',
'Tenth',
'Third',
);
$b = array(
'2 a',
'1 bb 1',
'1 bB 2',
'1 BB 3',
'20 c',
'10 d',
'3 e',
);
array_multisort($b, SORT_NATURAL | SORT_FLAG_CASE, $a);
var_dump($a, $b);
?>
===DONE===
--EXPECT--
*** Testing array_multisort() : natural sorting case-insensitive
array(7) {
[0]=>
string(7) "First.1"
[1]=>
string(7) "First.2"
[2]=>
string(7) "First.3"
[3]=>
string(6) "Second"
[4]=>
string(5) "Third"
[5]=>
string(5) "Tenth"
[6]=>
string(9) "Twentieth"
}
array(7) {
[0]=>
string(6) "1 bb 1"
[1]=>
string(6) "1 bB 2"
[2]=>
string(6) "1 BB 3"
[3]=>
string(3) "2 a"
[4]=>
string(3) "3 e"
[5]=>
string(4) "10 d"
[6]=>
string(4) "20 c"
}
===DONE===
|