]> git.saurik.com Git - apple/libc.git/blobdiff - string/FreeBSD/strcoll.c
Libc-1439.100.3.tar.gz
[apple/libc.git] / string / FreeBSD / strcoll.c
index 65448df47b3fbe8187cff400262247486b97deb8..31282895fdcdf435bf794b0c6d0b2a0b014ae893 100644 (file)
 #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());
+}