X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Flocale_impl.h;h=f5e4d9b4ae00313c0057414baaa270bbc4554a20;hb=8735a921d0242be0d7e6dbe0f76f79e09d4f06dd;hp=f41c6f24513c9573a16546dfe6cd40d51058625c;hpb=9448b0513e2eec020fbca9c10412b83df5027a16;p=musl diff --git a/src/internal/locale_impl.h b/src/internal/locale_impl.h index f41c6f24..f5e4d9b4 100644 --- a/src/internal/locale_impl.h +++ b/src/internal/locale_impl.h @@ -1,5 +1,40 @@ +#ifndef _LOCALE_IMPL_H +#define _LOCALE_IMPL_H + #include +#include +#include "libc.h" +#include "pthread_impl.h" + +#define LOCALE_NAME_MAX 15 -struct __locale_struct { - int dummy; +struct __locale_map { + const void *map; + size_t map_size; + char name[LOCALE_NAME_MAX+1]; + const struct __locale_map *next; }; + +extern const struct __locale_map __c_dot_utf8; +extern const struct __locale_struct __c_locale; +extern const struct __locale_struct __c_dot_utf8_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 LCTRANS(msg, lc, loc) __lctrans(msg, (loc)->cat[(lc)]) +#define LCTRANS_CUR(msg) __lctrans_cur(msg) + +#define C_LOCALE ((locale_t)&__c_locale) +#define UTF8_LOCALE ((locale_t)&__c_dot_utf8_locale) + +#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) + +#endif