39 _GLIBCXX_BEGIN_NAMESPACE(
std)
42 template<typename _CharT>
44 : facet(__refs), _M_c_locale_messages(_S_get_c_locale()),
45 _M_name_messages(_S_get_c_name())
48 template<
typename _CharT>
51 : facet(__refs), _M_c_locale_messages(NULL), _M_name_messages(NULL)
53 if (__builtin_strcmp(__s, _S_get_c_name()) != 0)
55 const size_t __len = __builtin_strlen(__s) + 1;
56 char* __tmp =
new char[__len];
57 __builtin_memcpy(__tmp, __s, __len);
58 _M_name_messages = __tmp;
61 _M_name_messages = _S_get_c_name();
64 _M_c_locale_messages = _S_clone_c_locale(__cloc);
67 template<
typename _CharT>
68 typename messages<_CharT>::catalog
70 const char* __dir)
const
72 bindtextdomain(__s.
c_str(), __dir);
73 return this->do_open(__s, __loc);
77 template<
typename _CharT>
80 if (_M_name_messages != _S_get_c_name())
81 delete [] _M_name_messages;
82 _S_destroy_c_locale(_M_c_locale_messages);
85 template<
typename _CharT>
86 typename messages<_CharT>::catalog
92 textdomain(__s.
c_str());
96 template<
typename _CharT>
98 messages<_CharT>::do_close(catalog)
const
102 template<
typename _CharT>
103 messages_byname<_CharT>::messages_byname(
const char* __s,
size_t __refs)
104 : messages<_CharT>(__refs)
106 if (this->_M_name_messages != locale::facet::_S_get_c_name())
108 delete [] this->_M_name_messages;
109 if (__builtin_strcmp(__s, locale::facet::_S_get_c_name()) != 0)
111 const size_t __len = __builtin_strlen(__s) + 1;
112 char* __tmp =
new char[__len];
113 __builtin_memcpy(__tmp, __s, __len);
114 this->_M_name_messages = __tmp;
117 this->_M_name_messages = locale::facet::_S_get_c_name();
120 if (__builtin_strcmp(__s,
"C") != 0
121 && __builtin_strcmp(__s,
"POSIX") != 0)
123 this->_S_destroy_c_locale(this->_M_c_locale_messages);
124 this->_S_create_c_locale(this->_M_c_locale_messages, __s);
128 _GLIBCXX_END_NAMESPACE
virtual ~messages()
Destructor.
const _CharT * c_str() const
Return const pointer to null-terminated contents.
ISO C++ entities toplevel namespace is std.
Facet for handling message catalogs.
Container class for localization functionality.