c_locale_glibc2.c

来自「stl的源码」· C语言 代码 · 共 706 行 · 第 1/2 页

C
706
字号
#include <locale.h>#include <langinfo.h>#include <stdio.h>#include <stdlib.h>#include <wctype.h>#include <string.h>#include <stdint.h>static const char *_empty_str = "";static const char *_C_name = "C";static wchar_t* _ToWChar(const char* buf, wchar_t *wbuf, size_t wbufSize) {  wchar_t *wcur = wbuf;  wchar_t *wend = wbuf + wbufSize - 1;  for (; wcur != wend && *buf != 0; ++buf, ++wcur)    *wcur = *buf;  *wcur = 0;  return wbuf;}#if 0struct _Locale_ctype{  locale_t __cloc;};struct _Locale_numeric{  locale_t __cloc;};struct _Locale_time{  locale_t __cloc;};struct _Locale_collate{  locale_t __cloc;};struct _Locale_monetary{  locale_t __cloc;};struct _Locale_messages{  locale_t __cloc;};#endifvoid _Locale_init(){}void _Locale_final(){}struct _Locale_ctype *_Locale_ctype_create(const char *nm, struct _Locale_name_hint* hint,                                           int *__err_code) {  *__err_code = _STLP_LOC_UNKNOWN_NAME;  return (struct _Locale_ctype*)newlocale(LC_CTYPE_MASK, nm, NULL);}struct _Locale_codecvt *_Locale_codecvt_create(const char *nm, struct _Locale_name_hint* hint,                                               int *__err_code) {  // Glibc do not support multibyte manipulation for the moment, it simply implements "C".  if (nm[0] == 'C' && nm[1] == 0)  { return (struct _Locale_codecvt*)0x01; }  *__err_code = _STLP_LOC_NO_PLATFORM_SUPPORT; return 0;}struct _Locale_numeric *_Locale_numeric_create(const char *nm, struct _Locale_name_hint* hint,                                               int *__err_code) {  *__err_code = _STLP_LOC_UNKNOWN_NAME;  return (struct _Locale_numeric*)newlocale(LC_NUMERIC_MASK, nm, NULL);}  struct _Locale_time *_Locale_time_create(const char *nm, struct _Locale_name_hint* hint,                                         int *__err_code) {  *__err_code = _STLP_LOC_UNKNOWN_NAME;  return (struct _Locale_time*)newlocale(LC_TIME_MASK, nm, NULL);}struct _Locale_collate *_Locale_collate_create(const char *nm, struct _Locale_name_hint* hint,                                               int *__err_code) {  *__err_code = _STLP_LOC_UNKNOWN_NAME;  return (struct _Locale_collate*)newlocale(LC_COLLATE_MASK, nm, NULL);}struct _Locale_monetary *_Locale_monetary_create(const char *nm, struct _Locale_name_hint* hint,                                                 int *__err_code) {  *__err_code = _STLP_LOC_UNKNOWN_NAME;  return (struct _Locale_monetary*)newlocale(LC_MONETARY_MASK, nm, NULL);}struct _Locale_messages *_Locale_messages_create(const char *nm, struct _Locale_name_hint* hint,                                                 int *__err_code) {  *__err_code = _STLP_LOC_UNKNOWN_NAME;  return (struct _Locale_messages*)newlocale(LC_MESSAGES_MASK, nm, NULL);}/*  try to see locale category LC should be used from environment;  according POSIX, the order is  1. LC_ALL  2. category (LC_CTYPE, LC_NUMERIC, ... )  3. LANG  If set nothing, return "C" (this really implementation-specific).*/static const char *_Locale_aux_default( const char *LC, char *nm ){  char *name = getenv( "LC_ALL" );  if ( name != NULL && *name != 0 ) {    return name;  }  name = getenv( LC );  if ( name != NULL && *name != 0 ) {    return name;  }  name = getenv( "LANG" );  if ( name != NULL && *name != 0 ) {    return name;  }  return _C_name;}const char *_Locale_ctype_default( char *nm ){  return _Locale_aux_default( "LC_CTYPE", nm );}const char *_Locale_numeric_default( char *nm ){  return _Locale_aux_default( "LC_NUMERIC", nm );}const char *_Locale_time_default( char *nm ){  return _Locale_aux_default( "LC_TIME", nm );}const char *_Locale_collate_default( char *nm ){  return _Locale_aux_default( "LC_COLLATE", nm );}const char *_Locale_monetary_default( char *nm ){  return _Locale_aux_default( "LC_MONETARY", nm );}const char *_Locale_messages_default( char *nm ){  return _Locale_aux_default( "LC_MESSAGES", nm );}char const*_Locale_ctype_name( const struct _Locale_ctype *__loc, char *buf ){  return ((locale_t)__loc)->__names[LC_CTYPE];}char const*_Locale_codecvt_name( const struct _Locale_codecvt *__loc, char *buf ){  return _C_name;}char const*_Locale_numeric_name( const struct _Locale_numeric *__loc, char *buf ){  return ((locale_t)__loc)->__names[LC_NUMERIC];}char const*_Locale_time_name( const struct _Locale_time *__loc, char *buf ){  return ((locale_t)__loc)->__names[LC_TIME];}char const*_Locale_collate_name( const struct _Locale_collate *__loc, char *buf ){  return ((locale_t)__loc)->__names[LC_COLLATE];}char const*_Locale_monetary_name( const struct _Locale_monetary *__loc, char *buf ){  return ((locale_t)__loc)->__names[LC_MONETARY];}char const*_Locale_messages_name( const struct _Locale_messages *__loc, char *buf ){  return ((locale_t)__loc)->__names[LC_MESSAGES];}void _Locale_ctype_destroy( struct _Locale_ctype *__loc ){ freelocale((locale_t)__loc); }void _Locale_codecvt_destroy( struct _Locale_codecvt *__loc ){}void _Locale_numeric_destroy( struct _Locale_numeric *__loc ){ freelocale((locale_t)__loc); }void _Locale_time_destroy( struct _Locale_time *__loc ){ freelocale((locale_t)__loc); }void _Locale_collate_destroy( struct _Locale_collate *__loc ){ freelocale((locale_t)__loc); }void _Locale_monetary_destroy( struct _Locale_monetary *__loc ){ freelocale((locale_t)__loc); }void _Locale_messages_destroy( struct _Locale_messages* __loc ){ freelocale((locale_t)__loc); }/* * locale loc expected either locale name indeed (platform-specific) * or string like "LC_CTYPE=LocaleNameForCType;LC_NUMERIC=LocaleNameForNum;" * */static char const*__Extract_locale_name( const char *loc, const char *category, char *buf ){  char *expr;  size_t len_name;  if( loc[0]=='L' && loc[1]=='C' && loc[2]=='_') {    expr = strstr( (char*)loc, category );    if ( expr == NULL )      return NULL; /* Category not found. */    ++expr;    len_name = strcspn( expr, ";" );    len_name = len_name >= _Locale_MAX_SIMPLE_NAME ? _Locale_MAX_SIMPLE_NAME - 1 : len_name;    strncpy( buf, expr, len_name );    buf[len_name] = 0;    return buf;  }  return loc;}char const*_Locale_extract_ctype_name(const char *loc, char *buf,                                      struct _Locale_name_hint* hint, int *__err_code){ return __Extract_locale_name( loc, "LC_CTYPE=", buf ); }char const*_Locale_extract_numeric_name(const char *loc, char *buf,                                        struct _Locale_name_hint* hint, int *__err_code){ return __Extract_locale_name( loc, "LC_NUMERIC=", buf ); }char const*_Locale_extract_time_name(const char *loc, char *buf,                                     struct _Locale_name_hint* hint, int *__err_code){ return __Extract_locale_name( loc, "LC_TIME=", buf ); }char const*_Locale_extract_collate_name(const char *loc, char *buf,                                        struct _Locale_name_hint* hint, int *__err_code){ return __Extract_locale_name( loc, "LC_COLLATE=", buf ); }char const*_Locale_extract_monetary_name(const char *loc, char *buf,                                         struct _Locale_name_hint* hint, int *__err_code){ return __Extract_locale_name( loc, "LC_MONETARY=", buf ); }char const*_Locale_extract_messages_name(const char *loc, char *buf,                                         struct _Locale_name_hint* hint, int *__err_code){ return __Extract_locale_name( loc, "LC_MESSAGES=", buf ); }struct _Locale_name_hint* _Locale_get_ctype_hint(struct _Locale_ctype* ctype){ return 0; }struct _Locale_name_hint* _Locale_get_numeric_hint(struct _Locale_numeric* numeric){ return 0; }struct _Locale_name_hint* _Locale_get_time_hint(struct _Locale_time* time){ return 0; }struct _Locale_name_hint* _Locale_get_collate_hint(struct _Locale_collate* collate){ return 0; }struct _Locale_name_hint* _Locale_get_monetary_hint(struct _Locale_monetary* monetary){ return 0; }struct _Locale_name_hint* _Locale_get_messages_hint(struct _Locale_messages* messages){ return 0; }/* ctype */const _Locale_mask_t *_Locale_ctype_table( struct _Locale_ctype *__loc ){  /* return table with masks (upper, lower, alpha, etc.) */  _STLP_STATIC_ASSERT( sizeof(_Locale_mask_t) == sizeof(((locale_t)__loc)->__ctype_b[0]) )  return ((locale_t)__loc)->__ctype_b;}int _Locale_toupper( struct _Locale_ctype *__loc, int c ){ return ((locale_t)__loc)->__ctype_toupper[c]; }int _Locale_tolower( struct _Locale_ctype *__loc, int c ){ return ((locale_t)__loc)->__ctype_tolower[c]; }#if !defined (_STLP_NO_WCHAR_T)_Locale_mask_t _WLocale_ctype( struct _Locale_ctype *__loc, wint_t wc, _Locale_mask_t __mask ){  _Locale_mask_t ret = 0;  if ((__mask & _Locale_ALPHA) != 0 && iswalpha_l(wc, (locale_t)__loc))    ret |= _Locale_ALPHA;    if ((__mask & _Locale_CNTRL) != 0 && iswcntrl_l(wc, (locale_t)__loc))    ret |= _Locale_CNTRL;  if ((__mask & _Locale_DIGIT) != 0 && iswdigit_l(wc, (locale_t)__loc))    ret |= _Locale_DIGIT;  if ((__mask & _Locale_PRINT) != 0 && iswprint_l(wc, (locale_t)__loc))     ret |= _Locale_PRINT;  if ((__mask & _Locale_PUNCT) != 0 && iswpunct_l(wc, (locale_t)__loc))    ret |= _Locale_PUNCT;  if ((__mask & _Locale_SPACE) != 0 && iswspace_l(wc, (locale_t)__loc))    ret |= _Locale_SPACE;  if ((__mask & _Locale_XDIGIT) != 0 && iswxdigit_l(wc, (locale_t)__loc))    ret |= _Locale_XDIGIT;  if ((__mask & _Locale_UPPER) != 0 && iswupper_l(wc, (locale_t)__loc))    ret |= _Locale_UPPER;  if ((__mask & _Locale_LOWER) != 0 && iswlower_l(wc, (locale_t)__loc))    ret |= _Locale_LOWER;  return ret;}wint_t _WLocale_tolower( struct _Locale_ctype *__loc, wint_t c ){  return towlower_l( c, ((locale_t)__loc) );}wint_t _WLocale_toupper( struct _Locale_ctype *__loc, wint_t c ){  return towupper_l( c, ((locale_t)__loc) );}#endifint _WLocale_mb_cur_max( struct _Locale_codecvt * lcodecvt) { return 1; }int _WLocale_mb_cur_min( struct _Locale_codecvt * lcodecvt) { return 1; }int _WLocale_is_stateless( struct _Locale_codecvt * lcodecvt) { return 1; }#if !defined (_STLP_NO_WCHAR_T)size_t _WLocale_mbtowc(struct _Locale_codecvt *lcodecvt,                       wchar_t *to,                       const char *from, size_t n,                       mbstate_t *st){ *to = *from; return 1; }size_t _WLocale_wctomb(struct _Locale_codecvt *lcodecvt,                       char *to, size_t n,                       const wchar_t c,                       mbstate_t *st){ *to = (char)c; return 1; }

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?