📄 200-uclibc-locale.patch
字号:
+#endif+}diff -urN gcc-4.0.0-100/libstdc++-v3/config/locale/uclibc/messages_members.h gcc-4.0.0/libstdc++-v3/config/locale/uclibc/messages_members.h--- gcc-4.0.0-100/libstdc++-v3/config/locale/uclibc/messages_members.h 1969-12-31 18:00:00.000000000 -0600+++ gcc-4.0.0/libstdc++-v3/config/locale/uclibc/messages_members.h 2005-04-28 01:13:15.000000000 -0500@@ -0,0 +1,118 @@+// std::messages implementation details, GNU version -*- C++ -*-++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.+//+// This file is part of the GNU ISO C++ Library. This library is free+// software; you can redistribute it and/or modify it under the+// terms of the GNU General Public License as published by the+// Free Software Foundation; either version 2, or (at your option)+// any later version.++// This library is distributed in the hope that it will be useful,+// but WITHOUT ANY WARRANTY; without even the implied warranty of+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the+// GNU General Public License for more details.++// You should have received a copy of the GNU General Public License along+// with this library; see the file COPYING. If not, write to the Free+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,+// USA.++// As a special exception, you may use this file as part of a free software+// library without restriction. Specifically, if other files instantiate+// templates or use macros or inline functions from this file, or you compile+// this file and link it with other files to produce an executable, this+// file does not by itself cause the resulting executable to be covered by+// the GNU General Public License. This exception does not however+// invalidate any other reasons why the executable file might be covered by+// the GNU General Public License.++//+// ISO C++ 14882: 22.2.7.1.2 messages functions+//++// Written by Benjamin Kosnik <bkoz@redhat.com>++#ifdef __UCLIBC_MJN3_ONLY__+#warning fix prototypes for *textdomain funcs+#endif+#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__+extern "C" char *__textdomain(const char *domainname);+extern "C" char *__bindtextdomain(const char *domainname,+ const char *dirname);+#else+#undef __textdomain+#undef __bindtextdomain+#define __textdomain(D) ((void)0)+#define __bindtextdomain(D,P) ((void)0)+#endif++ // Non-virtual member functions.+ template<typename _CharT>+ messages<_CharT>::messages(size_t __refs)+ : facet(__refs), _M_c_locale_messages(_S_get_c_locale()), + _M_name_messages(_S_get_c_name())+ { }++ template<typename _CharT>+ messages<_CharT>::messages(__c_locale __cloc, const char* __s, + size_t __refs) + : facet(__refs), _M_c_locale_messages(_S_clone_c_locale(__cloc)),+ _M_name_messages(__s)+ {+ char* __tmp = new char[std::strlen(__s) + 1];+ std::strcpy(__tmp, __s);+ _M_name_messages = __tmp;+ }++ template<typename _CharT>+ typename messages<_CharT>::catalog + messages<_CharT>::open(const basic_string<char>& __s, const locale& __loc, + const char* __dir) const+ { + __bindtextdomain(__s.c_str(), __dir);+ return this->do_open(__s, __loc); + }++ // Virtual member functions.+ template<typename _CharT>+ messages<_CharT>::~messages()+ { + if (_M_name_messages != _S_get_c_name())+ delete [] _M_name_messages;+ _S_destroy_c_locale(_M_c_locale_messages); + }++ template<typename _CharT>+ typename messages<_CharT>::catalog + messages<_CharT>::do_open(const basic_string<char>& __s, + const locale&) const+ { + // No error checking is done, assume the catalog exists and can+ // be used.+ __textdomain(__s.c_str());+ return 0;+ }++ template<typename _CharT>+ void + messages<_CharT>::do_close(catalog) const + { }++ // messages_byname+ template<typename _CharT>+ messages_byname<_CharT>::messages_byname(const char* __s, size_t __refs)+ : messages<_CharT>(__refs) + { + if (this->_M_name_messages != locale::facet::_S_get_c_name())+ delete [] this->_M_name_messages;+ char* __tmp = new char[std::strlen(__s) + 1];+ std::strcpy(__tmp, __s);+ this->_M_name_messages = __tmp;++ if (std::strcmp(__s, "C") != 0 && std::strcmp(__s, "POSIX") != 0)+ {+ this->_S_destroy_c_locale(this->_M_c_locale_messages);+ this->_S_create_c_locale(this->_M_c_locale_messages, __s); + }+ }diff -urN gcc-4.0.0-100/libstdc++-v3/config/locale/uclibc/monetary_members.cc gcc-4.0.0/libstdc++-v3/config/locale/uclibc/monetary_members.cc--- gcc-4.0.0-100/libstdc++-v3/config/locale/uclibc/monetary_members.cc 1969-12-31 18:00:00.000000000 -0600+++ gcc-4.0.0/libstdc++-v3/config/locale/uclibc/monetary_members.cc 2005-04-28 01:23:02.000000000 -0500@@ -0,0 +1,692 @@+// std::moneypunct implementation details, GNU version -*- C++ -*-++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.+//+// This file is part of the GNU ISO C++ Library. This library is free+// software; you can redistribute it and/or modify it under the+// terms of the GNU General Public License as published by the+// Free Software Foundation; either version 2, or (at your option)+// any later version.++// This library is distributed in the hope that it will be useful,+// but WITHOUT ANY WARRANTY; without even the implied warranty of+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the+// GNU General Public License for more details.++// You should have received a copy of the GNU General Public License along+// with this library; see the file COPYING. If not, write to the Free+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,+// USA.++// As a special exception, you may use this file as part of a free software+// library without restriction. Specifically, if other files instantiate+// templates or use macros or inline functions from this file, or you compile+// this file and link it with other files to produce an executable, this+// file does not by itself cause the resulting executable to be covered by+// the GNU General Public License. This exception does not however+// invalidate any other reasons why the executable file might be covered by+// the GNU General Public License.++//+// ISO C++ 14882: 22.2.6.3.2 moneypunct virtual functions+//++// Written by Benjamin Kosnik <bkoz@redhat.com>++#define _LIBC+#include <locale>+#undef _LIBC+#include <bits/c++locale_internal.h>++#ifdef __UCLIBC_MJN3_ONLY__+#warning optimize this for uclibc+#warning tailor for stub locale support+#endif++#ifndef __UCLIBC_HAS_XLOCALE__+#define __nl_langinfo_l(N, L) nl_langinfo((N))+#endif++namespace std+{+ // Construct and return valid pattern consisting of some combination of:+ // space none symbol sign value+ money_base::pattern+ money_base::_S_construct_pattern(char __precedes, char __space, char __posn)+ { + pattern __ret;++ // This insanely complicated routine attempts to construct a valid+ // pattern for use with monyepunct. A couple of invariants:++ // if (__precedes) symbol -> value+ // else value -> symbol+ + // if (__space) space+ // else none++ // none == never first+ // space never first or last++ // Any elegant implementations of this are welcome.+ switch (__posn)+ {+ case 0:+ case 1:+ // 1 The sign precedes the value and symbol.+ __ret.field[0] = sign;+ if (__space)+ {+ // Pattern starts with sign.+ if (__precedes)+ {+ __ret.field[1] = symbol;+ __ret.field[3] = value;+ }+ else+ {+ __ret.field[1] = value;+ __ret.field[3] = symbol;+ }+ __ret.field[2] = space;+ }+ else+ {+ // Pattern starts with sign and ends with none.+ if (__precedes)+ {+ __ret.field[1] = symbol;+ __ret.field[2] = value;+ }+ else+ {+ __ret.field[1] = value;+ __ret.field[2] = symbol;+ }+ __ret.field[3] = none;+ }+ break;+ case 2:+ // 2 The sign follows the value and symbol.+ if (__space)+ {+ // Pattern either ends with sign.+ if (__precedes)+ {+ __ret.field[0] = symbol;+ __ret.field[2] = value;+ }+ else+ {+ __ret.field[0] = value;+ __ret.field[2] = symbol;+ }+ __ret.field[1] = space;+ __ret.field[3] = sign;+ }+ else+ {+ // Pattern ends with sign then none.+ if (__precedes)+ {+ __ret.field[0] = symbol;+ __ret.field[1] = value;+ }+ else+ {+ __ret.field[0] = value;+ __ret.field[1] = symbol;+ }+ __ret.field[2] = sign;+ __ret.field[3] = none;+ }+ break;+ case 3:+ // 3 The sign immediately precedes the symbol.+ if (__precedes)+ {+ __ret.field[0] = sign;+ __ret.field[1] = symbol; + if (__space)+ {+ __ret.field[2] = space;+ __ret.field[3] = value;+ }+ else+ {+ __ret.field[2] = value; + __ret.field[3] = none;+ }+ }+ else+ {+ __ret.field[0] = value;+ if (__space)+ {+ __ret.field[1] = space;+ __ret.field[2] = sign;+ __ret.field[3] = symbol;+ }+ else+ {+ __ret.field[1] = sign;+ __ret.field[2] = symbol;+ __ret.field[3] = none;+ }+ }+ break;+ case 4:+ // 4 The sign immediately follows the symbol.+ if (__precedes)+ {+ __ret.field[0] = symbol;+ __ret.field[1] = sign;+ if (__space)+ {+ __ret.field[2] = space;+ __ret.field[3] = value;+ }+ else+ {+ __ret.field[2] = value;+ __ret.field[3] = none;+ }+ }+ else+ {+ __ret.field[0] = value;+ if (__space)+ {+ __ret.field[1] = space;+ __ret.field[2] = symbol;+ __ret.field[3] = sign;+ }+ else+ {+ __ret.field[1] = symbol;+ __ret.field[2] = sign;+ __ret.field[3] = none;+ }+ }+ break;+ default:+ __ret = pattern();+ }+ return __ret;+ }++ template<> + void+ moneypunct<char, true>::_M_initialize_moneypunct(__c_locale __cloc, + const char*)+ {+ if (!_M_data)+ _M_data = new __moneypunct_cache<char, true>;++ if (!__cloc)+ {+ // "C" locale+ _M_data->_M_decimal_point = '.';+ _M_data->_M_thousands_sep = ',';+ _M_data->_M_grouping = "";+ _M_data->_M_grouping_size = 0;+ _M_data->_M_curr_symbol = "";+ _M_data->_M_curr_symbol_size = 0;+ _M_data->_M_positive_sign = "";+ _M_data->_M_positive_sign_size = 0;+ _M_data->_M_negative_sign = "";+ _M_data->_M_negative_sign_size = 0;+ _M_data->_M_frac_digits = 0;+ _M_data->_M_pos_format = money_base::_S_default_pattern;+ _M_data->_M_neg_format = money_base::_S_default_pattern;++ for (size_t __i = 0; __i < money_base::_S_end; ++__i)+ _M_data->_M_atoms[__i] = money_base::_S_atoms[__i];+ }+ else+ {+ // Named locale.+ _M_data->_M_decimal_point = *(__nl_langinfo_l(__MON_DECIMAL_POINT, + __cloc));+ _M_data->_M_thousands_sep = *(__nl_langinfo_l(__MON_THOUSANDS_SEP, + __cloc));+ _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);+ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);+ _M_data->_M_positive_sign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);+ _M_data->_M_positive_sign_size = strlen(_M_data->_M_positive_sign);++ char __nposn = *(__nl_langinfo_l(__INT_N_SIGN_POSN, __cloc));+ if (!__nposn)+ _M_data->_M_negative_sign = "()";+ else+ _M_data->_M_negative_sign = __nl_langinfo_l(__NEGATIVE_SIGN, + __cloc);+ _M_data->_M_negative_sign_size = strlen(_M_data->_M_negative_sign);++ // _Intl == true+ _M_data->_M_curr_symbol = __nl_langinfo_l(__INT_CURR_SYMBOL, __cloc);+ _M_data->_M_curr_symbol_size = strlen(_M_data->_M_curr_symbol);+ _M_data->_M_frac_digits = *(__nl_langinfo_l(__INT_FRAC_DIGITS, + __cloc));+ char __pprecedes = *(__nl_langinfo_l(__INT_P_CS_PRECEDES, __cloc));+ char __pspace = *(__nl_langinfo_l(__INT_P_SEP_BY_SPACE, __cloc));+ char __pposn = *(__nl_langinfo_l(__INT_P_SIGN_POSN, __cloc));+ _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace, + __pposn);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -