X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Flocale_impl.h;h=9142f0c278133b44e91c19ee1a1852cc056db52b;hb=e98a54643ee95032baab883673628314e520012e;hp=f41c6f24513c9573a16546dfe6cd40d51058625c;hpb=9448b0513e2eec020fbca9c10412b83df5027a16;p=musl diff --git a/src/internal/locale_impl.h b/src/internal/locale_impl.h index f41c6f24..9142f0c2 100644 --- a/src/internal/locale_impl.h +++ b/src/internal/locale_impl.h @@ -1,5 +1,30 @@ #include +#include +#include "libc.h" +#include "pthread_impl.h" -struct __locale_struct { - int dummy; +#define LOCALE_NAME_MAX 15 + +struct __locale_map { + const void *map; + size_t map_size; + char name[LOCALE_NAME_MAX+1]; + struct __locale_map *next; }; + +int __setlocalecat(locale_t, 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 LCTRANS(msg, lc, loc) __lctrans(msg, (loc)->cat[(lc)-2]) +#define LCTRANS_CUR(msg) __lctrans_cur(msg) + +#define CURRENT_LOCALE \ + (libc.uselocale_cnt ? __pthread_self()->locale : &libc.global_locale) + +#define CURRENT_UTF8 \ + (libc.bytelocale_cnt_minus_1<0 || __pthread_self()->locale->ctype_utf8) + +#undef MB_CUR_MAX +#define MB_CUR_MAX (CURRENT_UTF8 ? 4 : 1)