X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Flocale%2Flanginfo.c;h=b16caf44e6bf298b9f145fac9456d2b69f180ab7;hb=a223dbd27ae36fe53f9f67f86caf685b729593fc;hp=7bb56eede9f56d92320ae79a553c095a828e22a2;hpb=1ae4bc42808111d6b3f50c063de102f162051986;p=oweals%2Fmusl.git diff --git a/src/locale/langinfo.c b/src/locale/langinfo.c index 7bb56eed..b16caf44 100644 --- a/src/locale/langinfo.c +++ b/src/locale/langinfo.c @@ -1,5 +1,6 @@ #include #include +#include "locale_impl.h" #include "libc.h" static const char c_time[] = @@ -17,12 +18,13 @@ static const char c_time[] = "%H:%M:%S\0" "%I:%M:%S %p\0" "\0" + "\0" "%m/%d/%y\0" - "0123456789" + "0123456789\0" "%a %b %e %T %Y\0" "%H:%M:%S"; -static const char c_messages[] = "^[yY]\0" "^[nN]"; +static const char c_messages[] = "^[yY]\0" "^[nN]\0" "yes\0" "no"; static const char c_numeric[] = ".\0" ""; char *__nl_langinfo_l(nl_item item, locale_t loc) @@ -31,36 +33,41 @@ char *__nl_langinfo_l(nl_item item, locale_t loc) int idx = item & 65535; const char *str; - if (item == CODESET) return "UTF-8"; + if (item == CODESET) return MB_CUR_MAX==1 ? "ASCII" : "UTF-8"; + + /* _NL_LOCALE_NAME extension */ + if (idx == 65535 && cat < LC_ALL) + return loc->cat[cat] ? (char *)loc->cat[cat]->name : "C"; switch (cat) { case LC_NUMERIC: - if (idx > 1) return NULL; + if (idx > 1) return ""; str = c_numeric; break; case LC_TIME: - if (idx > 0x31) return NULL; + if (idx > 0x31) return ""; str = c_time; break; case LC_MONETARY: - if (idx > 0) return NULL; + if (idx > 0) return ""; str = ""; break; case LC_MESSAGES: - if (idx > 1) return NULL; + if (idx > 3) return ""; str = c_messages; break; default: - return NULL; + return ""; } for (; idx; idx--, str++) for (; *str; str++); + if (cat != LC_NUMERIC && *str) str = LCTRANS(str, cat, loc); return (char *)str; } char *__nl_langinfo(nl_item item) { - return __nl_langinfo_l(item, 0); + return __nl_langinfo_l(item, CURRENT_LOCALE); } weak_alias(__nl_langinfo, nl_langinfo);