]> granicus.if.org Git - php/commitdiff
- Fixed bug #47481 (natcasesort() does not sort extended ASCII characters correctly)
authorJani Taskinen <jani@php.net>
Fri, 17 Jul 2009 11:13:51 +0000 (11:13 +0000)
committerJani Taskinen <jani@php.net>
Fri, 17 Jul 2009 11:13:51 +0000 (11:13 +0000)
NEWS
ext/standard/strnatcmp.c
ext/standard/tests/strings/bug47481.phpt [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index 999d14da9a45a3421fd11ad892b6d180bad27c2f..a56e067e710c99067bf0c60803742e9d4abe2972 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -26,6 +26,8 @@ PHP                                                                        NEWS
   errors when errors are logged). (Jani)
 - Fixed bug #48116 (Fixed build with Openssl 1.0). (Pierre, 
   Al dot Smith at aeschi dot ch dot eu dot org)
+- Fixed bug #47481 (natcasesort() does not sort extended ASCII characters
+  correctly). (Herman Radtke)
 - Fixed bug #47351 (Memory leak in DateTime). (Derick, Tobias John)
 - Fixed bug #46682 (touch() afield returns different values on windows).
   (Pierre)
index 2459e46e66d1ac29dfa422a60f2876f9a8f445a5..366c12449fd765521daf2d17060385628ab36a5d 100644 (file)
@@ -101,7 +101,7 @@ compare_left(char const **a, char const *aend, char const **b, char const *bend)
  */
 PHPAPI int strnatcmp_ex(char const *a, size_t a_len, char const *b, size_t b_len, int fold_case)
 {
-       char ca, cb;
+       unsigned char ca, cb;
        char const *ap, *bp;
        char const *aend = a + a_len,
                           *bend = b + b_len;
diff --git a/ext/standard/tests/strings/bug47481.phpt b/ext/standard/tests/strings/bug47481.phpt
new file mode 100644 (file)
index 0000000..4c59a7c
--- /dev/null
@@ -0,0 +1,57 @@
+--TEST--
+Bug #47481 (natcasesort() does not sort extended ASCII characters correctly)
+--FILE--
+<?php
+/* Prototype  : bool natcasesort(array &$array_arg)
+ * Description: Sort an array using case-insensitive natural sort
+ * Source code: ext/standard/array.c
+ */
+
+/*
+ * Test natcasesort() with extended ASCII characters
+ */
+
+$array = array ('Süden', 'spielen','Sonne','Wind','Regen','Meer');
+echo "\n-- Before sorting: --\n";
+var_dump($array);
+
+echo "\n-- After Sorting: --\n";
+var_dump(natcasesort($array));
+var_dump($array);
+
+echo "Done";
+?>
+--EXPECTF--
+-- Before sorting: --
+array(6) {
+  [0]=>
+  %string|unicode%(6) "Süden"
+  [1]=>
+  %string|unicode%(7) "spielen"
+  [2]=>
+  %string|unicode%(5) "Sonne"
+  [3]=>
+  %string|unicode%(4) "Wind"
+  [4]=>
+  %string|unicode%(5) "Regen"
+  [5]=>
+  %string|unicode%(4) "Meer"
+}
+
+-- After Sorting: --
+bool(true)
+array(6) {
+  [5]=>
+  %string|unicode%(4) "Meer"
+  [4]=>
+  %string|unicode%(5) "Regen"
+  [2]=>
+  %string|unicode%(5) "Sonne"
+  [1]=>
+  %string|unicode%(7) "spielen"
+  [0]=>
+  %string|unicode%(6) "Süden"
+  [3]=>
+  %string|unicode%(4) "Wind"
+}
+Done