overhaul locale internals to treat categories roughly uniformly
[musl] / src / internal / locale_impl.h
index 2747b85..9b8385e 100644 (file)
@@ -5,13 +5,24 @@
 
 #define LOCALE_NAME_MAX 15
 
-int __setlocalecat(locale_t, int, const char *);
+struct __locale_map {
+       const void *map;
+       size_t map_size;
+       char name[LOCALE_NAME_MAX+1];
+       const struct __locale_map *next;
+};
 
-#define CURRENT_LOCALE \
-       (libc.uselocale_cnt ? __pthread_self()->locale : &libc.global_locale)
+const struct __locale_map *__get_locale(int, const char *);
+const char *__mo_lookup(const void *, size_t, const char *);
+const char *__lctrans(const char *, const struct __locale_map *);
+const char *__lctrans_cur(const char *);
 
-#define CURRENT_UTF8 \
-       (libc.bytelocale_cnt_minus_1<0 || __pthread_self()->locale->ctype_utf8)
+#define LCTRANS(msg, lc, loc) __lctrans(msg, (loc)->cat[(lc)])
+#define LCTRANS_CUR(msg) __lctrans_cur(msg)
+
+#define CURRENT_LOCALE (__pthread_self()->locale)
+
+#define CURRENT_UTF8 (!!__pthread_self()->locale->cat[LC_CTYPE])
 
 #undef MB_CUR_MAX
 #define MB_CUR_MAX (CURRENT_UTF8 ? 4 : 1)