]> git.saurik.com Git - apple/libc.git/blobdiff - string/FreeBSD/strcoll.c.patch
Libc-825.24.tar.gz
[apple/libc.git] / string / FreeBSD / strcoll.c.patch
diff --git a/string/FreeBSD/strcoll.c.patch b/string/FreeBSD/strcoll.c.patch
deleted file mode 100644 (file)
index 58fc3c0..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
---- strcoll.c.bsdnew   2009-11-18 18:24:34.000000000 -0800
-+++ strcoll.c  2009-11-18 18:26:43.000000000 -0800
-@@ -28,58 +28,41 @@
- #include <sys/cdefs.h>
- __FBSDID("$FreeBSD: src/lib/libc/string/strcoll.c,v 1.14 2009/02/03 17:58:20 danger Exp $");
-+#include "xlocale_private.h"
-+
- #include <stdlib.h>
- #include <string.h>
-+#include <wchar.h>
-+#include <errno.h>
- #include "collate.h"
- int
--strcoll(const char *s, const char *s2)
-+strcoll_l(const char *s, const char *s2, locale_t loc)
- {
--      int len, len2, prim, prim2, sec, sec2, ret, ret2;
--      const char *t, *t2;
--      char *tt, *tt2;
-+      int ret;
-+      const wchar_t *t = NULL, *t2 = NULL;
-+      int sverrno;
--      if (__collate_load_error)
-+      NORMALIZE_LOCALE(loc);
-+      if (loc->__collate_load_error || (t = __collate_mbstowcs(s, loc)) == NULL || (t2 = __collate_mbstowcs(s2, loc)) == NULL) {
-+              sverrno = errno;
-+              free((void *)t);
-+              free((void *)t2);
-+              errno = sverrno;
-               return strcmp(s, s2);
--
--      len = len2 = 1;
--      ret = ret2 = 0;
--      if (__collate_substitute_nontrivial) {
--              t = tt = __collate_substitute(s);
--              t2 = tt2 = __collate_substitute(s2);
--      } else {
--              tt = tt2 = NULL;
--              t = s;
--              t2 = s2;
-       }
--      while(*t && *t2) {
--              prim = prim2 = 0;
--              while(*t && !prim) {
--                      __collate_lookup(t, &len, &prim, &sec);
--                      t += len;
--              }
--              while(*t2 && !prim2) {
--                      __collate_lookup(t2, &len2, &prim2, &sec2);
--                      t2 += len2;
--              }
--              if(!prim || !prim2)
--                      break;
--              if(prim != prim2) {
--                      ret = prim - prim2;
--                      goto end;
--              }
--              if(!ret2)
--                      ret2 = sec - sec2;
--      }
--      if(!*t && *t2)
--              ret = -(int)((u_char)*t2);
--      else if(*t && !*t2)
--              ret = (u_char)*t;
--      else if(!*t && !*t2)
--              ret = ret2;
--  end:
--      free(tt);
--      free(tt2);
-+
-+      ret = wcscoll_l(t, t2, loc);
-+      sverrno = errno;
-+      free((void *)t);
-+      free((void *)t2);
-+      errno = sverrno;
-       return ret;
- }
-+
-+int
-+strcoll(const char *s, const char *s2)
-+{
-+      return strcoll_l(s, s2, __current_locale());
-+}