1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/patches/gcc/4.2.0/120-uclibc-locale.patch Sun Jul 17 18:01:28 2011 +0200
1.3 @@ -0,0 +1,2790 @@
1.4 +--- gcc/libstdc++-v3/acinclude.m4
1.5 ++++ gcc/libstdc++-v3/acinclude.m4
1.6 +@@ -1369,7 +1369,7 @@
1.7 + AC_MSG_CHECKING([for C locale to use])
1.8 + GLIBCXX_ENABLE(clocale,auto,[@<:@=MODEL@:>@],
1.9 + [use MODEL for target locale package],
1.10 +- [permit generic|gnu|ieee_1003.1-2001|yes|no|auto])
1.11 ++ [permit generic|gnu|ieee_1003.1-2001|uclibc|yes|no|auto])
1.12 +
1.13 + # If they didn't use this option switch, or if they specified --enable
1.14 + # with no specific model, we'll have to look for one. If they
1.15 +@@ -1385,6 +1385,9 @@
1.16 + # Default to "generic".
1.17 + if test $enable_clocale_flag = auto; then
1.18 + case ${target_os} in
1.19 ++ *-uclibc*)
1.20 ++ enable_clocale_flag=uclibc
1.21 ++ ;;
1.22 + linux* | gnu* | kfreebsd*-gnu | knetbsd*-gnu)
1.23 + AC_EGREP_CPP([_GLIBCXX_ok], [
1.24 + #include <features.h>
1.25 +@@ -1528,6 +1531,40 @@
1.26 + CTIME_CC=config/locale/generic/time_members.cc
1.27 + CLOCALE_INTERNAL_H=config/locale/generic/c++locale_internal.h
1.28 + ;;
1.29 ++ uclibc)
1.30 ++ AC_MSG_RESULT(uclibc)
1.31 ++
1.32 ++ # Declare intention to use gettext, and add support for specific
1.33 ++ # languages.
1.34 ++ # For some reason, ALL_LINGUAS has to be before AM-GNU-GETTEXT
1.35 ++ ALL_LINGUAS="de fr"
1.36 ++
1.37 ++ # Don't call AM-GNU-GETTEXT here. Instead, assume glibc.
1.38 ++ AC_CHECK_PROG(check_msgfmt, msgfmt, yes, no)
1.39 ++ if test x"$check_msgfmt" = x"yes" && test x"$enable_nls" = x"yes"; then
1.40 ++ USE_NLS=yes
1.41 ++ fi
1.42 ++ # Export the build objects.
1.43 ++ for ling in $ALL_LINGUAS; do \
1.44 ++ glibcxx_MOFILES="$glibcxx_MOFILES $ling.mo"; \
1.45 ++ glibcxx_POFILES="$glibcxx_POFILES $ling.po"; \
1.46 ++ done
1.47 ++ AC_SUBST(glibcxx_MOFILES)
1.48 ++ AC_SUBST(glibcxx_POFILES)
1.49 ++
1.50 ++ CLOCALE_H=config/locale/uclibc/c_locale.h
1.51 ++ CLOCALE_CC=config/locale/uclibc/c_locale.cc
1.52 ++ CCODECVT_CC=config/locale/uclibc/codecvt_members.cc
1.53 ++ CCOLLATE_CC=config/locale/uclibc/collate_members.cc
1.54 ++ CCTYPE_CC=config/locale/uclibc/ctype_members.cc
1.55 ++ CMESSAGES_H=config/locale/uclibc/messages_members.h
1.56 ++ CMESSAGES_CC=config/locale/uclibc/messages_members.cc
1.57 ++ CMONEY_CC=config/locale/uclibc/monetary_members.cc
1.58 ++ CNUMERIC_CC=config/locale/uclibc/numeric_members.cc
1.59 ++ CTIME_H=config/locale/uclibc/time_members.h
1.60 ++ CTIME_CC=config/locale/uclibc/time_members.cc
1.61 ++ CLOCALE_INTERNAL_H=config/locale/uclibc/c++locale_internal.h
1.62 ++ ;;
1.63 + esac
1.64 +
1.65 + # This is where the testsuite looks for locale catalogs, using the
1.66 +--- gcc/libstdc++-v3/config/locale/uclibc/c++locale_internal.h
1.67 ++++ gcc/libstdc++-v3/config/locale/uclibc/c++locale_internal.h
1.68 +@@ -0,0 +1,63 @@
1.69 ++// Prototypes for GLIBC thread locale __-prefixed functions -*- C++ -*-
1.70 ++
1.71 ++// Copyright (C) 2002, 2004, 2005 Free Software Foundation, Inc.
1.72 ++//
1.73 ++// This file is part of the GNU ISO C++ Library. This library is free
1.74 ++// software; you can redistribute it and/or modify it under the
1.75 ++// terms of the GNU General Public License as published by the
1.76 ++// Free Software Foundation; either version 2, or (at your option)
1.77 ++// any later version.
1.78 ++
1.79 ++// This library is distributed in the hope that it will be useful,
1.80 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.81 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.82 ++// GNU General Public License for more details.
1.83 ++
1.84 ++// You should have received a copy of the GNU General Public License along
1.85 ++// with this library; see the file COPYING. If not, write to the Free
1.86 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.87 ++// USA.
1.88 ++
1.89 ++// As a special exception, you may use this file as part of a free software
1.90 ++// library without restriction. Specifically, if other files instantiate
1.91 ++// templates or use macros or inline functions from this file, or you compile
1.92 ++// this file and link it with other files to produce an executable, this
1.93 ++// file does not by itself cause the resulting executable to be covered by
1.94 ++// the GNU General Public License. This exception does not however
1.95 ++// invalidate any other reasons why the executable file might be covered by
1.96 ++// the GNU General Public License.
1.97 ++
1.98 ++// Written by Jakub Jelinek <jakub@redhat.com>
1.99 ++
1.100 ++#include <bits/c++config.h>
1.101 ++#include <clocale>
1.102 ++
1.103 ++#ifdef __UCLIBC_MJN3_ONLY__
1.104 ++#warning clean this up
1.105 ++#endif
1.106 ++
1.107 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.108 ++
1.109 ++extern "C" __typeof(nl_langinfo_l) __nl_langinfo_l;
1.110 ++extern "C" __typeof(strcoll_l) __strcoll_l;
1.111 ++extern "C" __typeof(strftime_l) __strftime_l;
1.112 ++extern "C" __typeof(strtod_l) __strtod_l;
1.113 ++extern "C" __typeof(strtof_l) __strtof_l;
1.114 ++extern "C" __typeof(strtold_l) __strtold_l;
1.115 ++extern "C" __typeof(strxfrm_l) __strxfrm_l;
1.116 ++extern "C" __typeof(newlocale) __newlocale;
1.117 ++extern "C" __typeof(freelocale) __freelocale;
1.118 ++extern "C" __typeof(duplocale) __duplocale;
1.119 ++extern "C" __typeof(uselocale) __uselocale;
1.120 ++
1.121 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.122 ++extern "C" __typeof(iswctype_l) __iswctype_l;
1.123 ++extern "C" __typeof(towlower_l) __towlower_l;
1.124 ++extern "C" __typeof(towupper_l) __towupper_l;
1.125 ++extern "C" __typeof(wcscoll_l) __wcscoll_l;
1.126 ++extern "C" __typeof(wcsftime_l) __wcsftime_l;
1.127 ++extern "C" __typeof(wcsxfrm_l) __wcsxfrm_l;
1.128 ++extern "C" __typeof(wctype_l) __wctype_l;
1.129 ++#endif
1.130 ++
1.131 ++#endif // GLIBC 2.3 and later
1.132 +--- gcc/libstdc++-v3/config/locale/uclibc/c_locale.cc
1.133 ++++ gcc/libstdc++-v3/config/locale/uclibc/c_locale.cc
1.134 +@@ -0,0 +1,160 @@
1.135 ++// Wrapper for underlying C-language localization -*- C++ -*-
1.136 ++
1.137 ++// Copyright (C) 2001, 2002, 2003 Free Software Foundation, Inc.
1.138 ++//
1.139 ++// This file is part of the GNU ISO C++ Library. This library is free
1.140 ++// software; you can redistribute it and/or modify it under the
1.141 ++// terms of the GNU General Public License as published by the
1.142 ++// Free Software Foundation; either version 2, or (at your option)
1.143 ++// any later version.
1.144 ++
1.145 ++// This library is distributed in the hope that it will be useful,
1.146 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.147 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.148 ++// GNU General Public License for more details.
1.149 ++
1.150 ++// You should have received a copy of the GNU General Public License along
1.151 ++// with this library; see the file COPYING. If not, write to the Free
1.152 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.153 ++// USA.
1.154 ++
1.155 ++// As a special exception, you may use this file as part of a free software
1.156 ++// library without restriction. Specifically, if other files instantiate
1.157 ++// templates or use macros or inline functions from this file, or you compile
1.158 ++// this file and link it with other files to produce an executable, this
1.159 ++// file does not by itself cause the resulting executable to be covered by
1.160 ++// the GNU General Public License. This exception does not however
1.161 ++// invalidate any other reasons why the executable file might be covered by
1.162 ++// the GNU General Public License.
1.163 ++
1.164 ++//
1.165 ++// ISO C++ 14882: 22.8 Standard locale categories.
1.166 ++//
1.167 ++
1.168 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.169 ++
1.170 ++#include <cerrno> // For errno
1.171 ++#include <locale>
1.172 ++#include <stdexcept>
1.173 ++#include <langinfo.h>
1.174 ++#include <bits/c++locale_internal.h>
1.175 ++
1.176 ++#ifndef __UCLIBC_HAS_XLOCALE__
1.177 ++#define __strtol_l(S, E, B, L) strtol((S), (E), (B))
1.178 ++#define __strtoul_l(S, E, B, L) strtoul((S), (E), (B))
1.179 ++#define __strtoll_l(S, E, B, L) strtoll((S), (E), (B))
1.180 ++#define __strtoull_l(S, E, B, L) strtoull((S), (E), (B))
1.181 ++#define __strtof_l(S, E, L) strtof((S), (E))
1.182 ++#define __strtod_l(S, E, L) strtod((S), (E))
1.183 ++#define __strtold_l(S, E, L) strtold((S), (E))
1.184 ++#warning should dummy __newlocale check for C|POSIX ?
1.185 ++#define __newlocale(a, b, c) NULL
1.186 ++#define __freelocale(a) ((void)0)
1.187 ++#define __duplocale(a) __c_locale()
1.188 ++#endif
1.189 ++
1.190 ++namespace std
1.191 ++{
1.192 ++ template<>
1.193 ++ void
1.194 ++ __convert_to_v(const char* __s, float& __v, ios_base::iostate& __err,
1.195 ++ const __c_locale& __cloc)
1.196 ++ {
1.197 ++ if (!(__err & ios_base::failbit))
1.198 ++ {
1.199 ++ char* __sanity;
1.200 ++ errno = 0;
1.201 ++ float __f = __strtof_l(__s, &__sanity, __cloc);
1.202 ++ if (__sanity != __s && errno != ERANGE)
1.203 ++ __v = __f;
1.204 ++ else
1.205 ++ __err |= ios_base::failbit;
1.206 ++ }
1.207 ++ }
1.208 ++
1.209 ++ template<>
1.210 ++ void
1.211 ++ __convert_to_v(const char* __s, double& __v, ios_base::iostate& __err,
1.212 ++ const __c_locale& __cloc)
1.213 ++ {
1.214 ++ if (!(__err & ios_base::failbit))
1.215 ++ {
1.216 ++ char* __sanity;
1.217 ++ errno = 0;
1.218 ++ double __d = __strtod_l(__s, &__sanity, __cloc);
1.219 ++ if (__sanity != __s && errno != ERANGE)
1.220 ++ __v = __d;
1.221 ++ else
1.222 ++ __err |= ios_base::failbit;
1.223 ++ }
1.224 ++ }
1.225 ++
1.226 ++ template<>
1.227 ++ void
1.228 ++ __convert_to_v(const char* __s, long double& __v, ios_base::iostate& __err,
1.229 ++ const __c_locale& __cloc)
1.230 ++ {
1.231 ++ if (!(__err & ios_base::failbit))
1.232 ++ {
1.233 ++ char* __sanity;
1.234 ++ errno = 0;
1.235 ++ long double __ld = __strtold_l(__s, &__sanity, __cloc);
1.236 ++ if (__sanity != __s && errno != ERANGE)
1.237 ++ __v = __ld;
1.238 ++ else
1.239 ++ __err |= ios_base::failbit;
1.240 ++ }
1.241 ++ }
1.242 ++
1.243 ++ void
1.244 ++ locale::facet::_S_create_c_locale(__c_locale& __cloc, const char* __s,
1.245 ++ __c_locale __old)
1.246 ++ {
1.247 ++ __cloc = __newlocale(1 << LC_ALL, __s, __old);
1.248 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.249 ++ if (!__cloc)
1.250 ++ {
1.251 ++ // This named locale is not supported by the underlying OS.
1.252 ++ __throw_runtime_error(__N("locale::facet::_S_create_c_locale "
1.253 ++ "name not valid"));
1.254 ++ }
1.255 ++#endif
1.256 ++ }
1.257 ++
1.258 ++ void
1.259 ++ locale::facet::_S_destroy_c_locale(__c_locale& __cloc)
1.260 ++ {
1.261 ++ if (_S_get_c_locale() != __cloc)
1.262 ++ __freelocale(__cloc);
1.263 ++ }
1.264 ++
1.265 ++ __c_locale
1.266 ++ locale::facet::_S_clone_c_locale(__c_locale& __cloc)
1.267 ++ { return __duplocale(__cloc); }
1.268 ++} // namespace std
1.269 ++
1.270 ++namespace __gnu_cxx
1.271 ++{
1.272 ++ const char* const category_names[6 + _GLIBCXX_NUM_CATEGORIES] =
1.273 ++ {
1.274 ++ "LC_CTYPE",
1.275 ++ "LC_NUMERIC",
1.276 ++ "LC_TIME",
1.277 ++ "LC_COLLATE",
1.278 ++ "LC_MONETARY",
1.279 ++ "LC_MESSAGES",
1.280 ++#if _GLIBCXX_NUM_CATEGORIES != 0
1.281 ++ "LC_PAPER",
1.282 ++ "LC_NAME",
1.283 ++ "LC_ADDRESS",
1.284 ++ "LC_TELEPHONE",
1.285 ++ "LC_MEASUREMENT",
1.286 ++ "LC_IDENTIFICATION"
1.287 ++#endif
1.288 ++ };
1.289 ++}
1.290 ++
1.291 ++namespace std
1.292 ++{
1.293 ++ const char* const* const locale::_S_categories = __gnu_cxx::category_names;
1.294 ++} // namespace std
1.295 +--- gcc/libstdc++-v3/config/locale/uclibc/c_locale.h
1.296 ++++ gcc/libstdc++-v3/config/locale/uclibc/c_locale.h
1.297 +@@ -0,0 +1,117 @@
1.298 ++// Wrapper for underlying C-language localization -*- C++ -*-
1.299 ++
1.300 ++// Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
1.301 ++//
1.302 ++// This file is part of the GNU ISO C++ Library. This library is free
1.303 ++// software; you can redistribute it and/or modify it under the
1.304 ++// terms of the GNU General Public License as published by the
1.305 ++// Free Software Foundation; either version 2, or (at your option)
1.306 ++// any later version.
1.307 ++
1.308 ++// This library is distributed in the hope that it will be useful,
1.309 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.310 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.311 ++// GNU General Public License for more details.
1.312 ++
1.313 ++// You should have received a copy of the GNU General Public License along
1.314 ++// with this library; see the file COPYING. If not, write to the Free
1.315 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.316 ++// USA.
1.317 ++
1.318 ++// As a special exception, you may use this file as part of a free software
1.319 ++// library without restriction. Specifically, if other files instantiate
1.320 ++// templates or use macros or inline functions from this file, or you compile
1.321 ++// this file and link it with other files to produce an executable, this
1.322 ++// file does not by itself cause the resulting executable to be covered by
1.323 ++// the GNU General Public License. This exception does not however
1.324 ++// invalidate any other reasons why the executable file might be covered by
1.325 ++// the GNU General Public License.
1.326 ++
1.327 ++//
1.328 ++// ISO C++ 14882: 22.8 Standard locale categories.
1.329 ++//
1.330 ++
1.331 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.332 ++
1.333 ++#ifndef _C_LOCALE_H
1.334 ++#define _C_LOCALE_H 1
1.335 ++
1.336 ++#pragma GCC system_header
1.337 ++
1.338 ++#include <cstring> // get std::strlen
1.339 ++#include <cstdio> // get std::snprintf or std::sprintf
1.340 ++#include <clocale>
1.341 ++#include <langinfo.h> // For codecvt
1.342 ++#ifdef __UCLIBC_MJN3_ONLY__
1.343 ++#warning fix this
1.344 ++#endif
1.345 ++#ifdef __UCLIBC_HAS_LOCALE__
1.346 ++#include <iconv.h> // For codecvt using iconv, iconv_t
1.347 ++#endif
1.348 ++#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__
1.349 ++#include <libintl.h> // For messages
1.350 ++#endif
1.351 ++
1.352 ++#ifdef __UCLIBC_MJN3_ONLY__
1.353 ++#warning what is _GLIBCXX_C_LOCALE_GNU for
1.354 ++#endif
1.355 ++#define _GLIBCXX_C_LOCALE_GNU 1
1.356 ++
1.357 ++#ifdef __UCLIBC_MJN3_ONLY__
1.358 ++#warning fix categories
1.359 ++#endif
1.360 ++// #define _GLIBCXX_NUM_CATEGORIES 6
1.361 ++#define _GLIBCXX_NUM_CATEGORIES 0
1.362 ++
1.363 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.364 ++namespace __gnu_cxx
1.365 ++{
1.366 ++ extern "C" __typeof(uselocale) __uselocale;
1.367 ++}
1.368 ++#endif
1.369 ++
1.370 ++namespace std
1.371 ++{
1.372 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.373 ++ typedef __locale_t __c_locale;
1.374 ++#else
1.375 ++ typedef int* __c_locale;
1.376 ++#endif
1.377 ++
1.378 ++ // Convert numeric value of type _Tv to string and return length of
1.379 ++ // string. If snprintf is available use it, otherwise fall back to
1.380 ++ // the unsafe sprintf which, in general, can be dangerous and should
1.381 ++ // be avoided.
1.382 ++ template<typename _Tv>
1.383 ++ int
1.384 ++ __convert_from_v(char* __out,
1.385 ++ const int __size __attribute__ ((__unused__)),
1.386 ++ const char* __fmt,
1.387 ++#ifdef __UCLIBC_HAS_XCLOCALE__
1.388 ++ _Tv __v, const __c_locale& __cloc, int __prec)
1.389 ++ {
1.390 ++ __c_locale __old = __gnu_cxx::__uselocale(__cloc);
1.391 ++#else
1.392 ++ _Tv __v, const __c_locale&, int __prec)
1.393 ++ {
1.394 ++# ifdef __UCLIBC_HAS_LOCALE__
1.395 ++ char* __old = std::setlocale(LC_ALL, NULL);
1.396 ++ char* __sav = new char[std::strlen(__old) + 1];
1.397 ++ std::strcpy(__sav, __old);
1.398 ++ std::setlocale(LC_ALL, "C");
1.399 ++# endif
1.400 ++#endif
1.401 ++
1.402 ++ const int __ret = std::snprintf(__out, __size, __fmt, __prec, __v);
1.403 ++
1.404 ++#ifdef __UCLIBC_HAS_XCLOCALE__
1.405 ++ __gnu_cxx::__uselocale(__old);
1.406 ++#elif defined __UCLIBC_HAS_LOCALE__
1.407 ++ std::setlocale(LC_ALL, __sav);
1.408 ++ delete [] __sav;
1.409 ++#endif
1.410 ++ return __ret;
1.411 ++ }
1.412 ++}
1.413 ++
1.414 ++#endif
1.415 +--- gcc/libstdc++-v3/config/locale/uclibc/codecvt_members.cc
1.416 ++++ gcc/libstdc++-v3/config/locale/uclibc/codecvt_members.cc
1.417 +@@ -0,0 +1,306 @@
1.418 ++// std::codecvt implementation details, GNU version -*- C++ -*-
1.419 ++
1.420 ++// Copyright (C) 2002, 2003 Free Software Foundation, Inc.
1.421 ++//
1.422 ++// This file is part of the GNU ISO C++ Library. This library is free
1.423 ++// software; you can redistribute it and/or modify it under the
1.424 ++// terms of the GNU General Public License as published by the
1.425 ++// Free Software Foundation; either version 2, or (at your option)
1.426 ++// any later version.
1.427 ++
1.428 ++// This library is distributed in the hope that it will be useful,
1.429 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.430 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.431 ++// GNU General Public License for more details.
1.432 ++
1.433 ++// You should have received a copy of the GNU General Public License along
1.434 ++// with this library; see the file COPYING. If not, write to the Free
1.435 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.436 ++// USA.
1.437 ++
1.438 ++// As a special exception, you may use this file as part of a free software
1.439 ++// library without restriction. Specifically, if other files instantiate
1.440 ++// templates or use macros or inline functions from this file, or you compile
1.441 ++// this file and link it with other files to produce an executable, this
1.442 ++// file does not by itself cause the resulting executable to be covered by
1.443 ++// the GNU General Public License. This exception does not however
1.444 ++// invalidate any other reasons why the executable file might be covered by
1.445 ++// the GNU General Public License.
1.446 ++
1.447 ++//
1.448 ++// ISO C++ 14882: 22.2.1.5 - Template class codecvt
1.449 ++//
1.450 ++
1.451 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.452 ++
1.453 ++#include <locale>
1.454 ++#include <bits/c++locale_internal.h>
1.455 ++
1.456 ++namespace std
1.457 ++{
1.458 ++ // Specializations.
1.459 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.460 ++ codecvt_base::result
1.461 ++ codecvt<wchar_t, char, mbstate_t>::
1.462 ++ do_out(state_type& __state, const intern_type* __from,
1.463 ++ const intern_type* __from_end, const intern_type*& __from_next,
1.464 ++ extern_type* __to, extern_type* __to_end,
1.465 ++ extern_type*& __to_next) const
1.466 ++ {
1.467 ++ result __ret = ok;
1.468 ++ state_type __tmp_state(__state);
1.469 ++
1.470 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.471 ++ __c_locale __old = __uselocale(_M_c_locale_codecvt);
1.472 ++#endif
1.473 ++
1.474 ++ // wcsnrtombs is *very* fast but stops if encounters NUL characters:
1.475 ++ // in case we fall back to wcrtomb and then continue, in a loop.
1.476 ++ // NB: wcsnrtombs is a GNU extension
1.477 ++ for (__from_next = __from, __to_next = __to;
1.478 ++ __from_next < __from_end && __to_next < __to_end
1.479 ++ && __ret == ok;)
1.480 ++ {
1.481 ++ const intern_type* __from_chunk_end = wmemchr(__from_next, L'\0',
1.482 ++ __from_end - __from_next);
1.483 ++ if (!__from_chunk_end)
1.484 ++ __from_chunk_end = __from_end;
1.485 ++
1.486 ++ __from = __from_next;
1.487 ++ const size_t __conv = wcsnrtombs(__to_next, &__from_next,
1.488 ++ __from_chunk_end - __from_next,
1.489 ++ __to_end - __to_next, &__state);
1.490 ++ if (__conv == static_cast<size_t>(-1))
1.491 ++ {
1.492 ++ // In case of error, in order to stop at the exact place we
1.493 ++ // have to start again from the beginning with a series of
1.494 ++ // wcrtomb.
1.495 ++ for (; __from < __from_next; ++__from)
1.496 ++ __to_next += wcrtomb(__to_next, *__from, &__tmp_state);
1.497 ++ __state = __tmp_state;
1.498 ++ __ret = error;
1.499 ++ }
1.500 ++ else if (__from_next && __from_next < __from_chunk_end)
1.501 ++ {
1.502 ++ __to_next += __conv;
1.503 ++ __ret = partial;
1.504 ++ }
1.505 ++ else
1.506 ++ {
1.507 ++ __from_next = __from_chunk_end;
1.508 ++ __to_next += __conv;
1.509 ++ }
1.510 ++
1.511 ++ if (__from_next < __from_end && __ret == ok)
1.512 ++ {
1.513 ++ extern_type __buf[MB_LEN_MAX];
1.514 ++ __tmp_state = __state;
1.515 ++ const size_t __conv = wcrtomb(__buf, *__from_next, &__tmp_state);
1.516 ++ if (__conv > static_cast<size_t>(__to_end - __to_next))
1.517 ++ __ret = partial;
1.518 ++ else
1.519 ++ {
1.520 ++ memcpy(__to_next, __buf, __conv);
1.521 ++ __state = __tmp_state;
1.522 ++ __to_next += __conv;
1.523 ++ ++__from_next;
1.524 ++ }
1.525 ++ }
1.526 ++ }
1.527 ++
1.528 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.529 ++ __uselocale(__old);
1.530 ++#endif
1.531 ++
1.532 ++ return __ret;
1.533 ++ }
1.534 ++
1.535 ++ codecvt_base::result
1.536 ++ codecvt<wchar_t, char, mbstate_t>::
1.537 ++ do_in(state_type& __state, const extern_type* __from,
1.538 ++ const extern_type* __from_end, const extern_type*& __from_next,
1.539 ++ intern_type* __to, intern_type* __to_end,
1.540 ++ intern_type*& __to_next) const
1.541 ++ {
1.542 ++ result __ret = ok;
1.543 ++ state_type __tmp_state(__state);
1.544 ++
1.545 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.546 ++ __c_locale __old = __uselocale(_M_c_locale_codecvt);
1.547 ++#endif
1.548 ++
1.549 ++ // mbsnrtowcs is *very* fast but stops if encounters NUL characters:
1.550 ++ // in case we store a L'\0' and then continue, in a loop.
1.551 ++ // NB: mbsnrtowcs is a GNU extension
1.552 ++ for (__from_next = __from, __to_next = __to;
1.553 ++ __from_next < __from_end && __to_next < __to_end
1.554 ++ && __ret == ok;)
1.555 ++ {
1.556 ++ const extern_type* __from_chunk_end;
1.557 ++ __from_chunk_end = static_cast<const extern_type*>(memchr(__from_next, '\0',
1.558 ++ __from_end
1.559 ++ - __from_next));
1.560 ++ if (!__from_chunk_end)
1.561 ++ __from_chunk_end = __from_end;
1.562 ++
1.563 ++ __from = __from_next;
1.564 ++ size_t __conv = mbsnrtowcs(__to_next, &__from_next,
1.565 ++ __from_chunk_end - __from_next,
1.566 ++ __to_end - __to_next, &__state);
1.567 ++ if (__conv == static_cast<size_t>(-1))
1.568 ++ {
1.569 ++ // In case of error, in order to stop at the exact place we
1.570 ++ // have to start again from the beginning with a series of
1.571 ++ // mbrtowc.
1.572 ++ for (;; ++__to_next, __from += __conv)
1.573 ++ {
1.574 ++ __conv = mbrtowc(__to_next, __from, __from_end - __from,
1.575 ++ &__tmp_state);
1.576 ++ if (__conv == static_cast<size_t>(-1)
1.577 ++ || __conv == static_cast<size_t>(-2))
1.578 ++ break;
1.579 ++ }
1.580 ++ __from_next = __from;
1.581 ++ __state = __tmp_state;
1.582 ++ __ret = error;
1.583 ++ }
1.584 ++ else if (__from_next && __from_next < __from_chunk_end)
1.585 ++ {
1.586 ++ // It is unclear what to return in this case (see DR 382).
1.587 ++ __to_next += __conv;
1.588 ++ __ret = partial;
1.589 ++ }
1.590 ++ else
1.591 ++ {
1.592 ++ __from_next = __from_chunk_end;
1.593 ++ __to_next += __conv;
1.594 ++ }
1.595 ++
1.596 ++ if (__from_next < __from_end && __ret == ok)
1.597 ++ {
1.598 ++ if (__to_next < __to_end)
1.599 ++ {
1.600 ++ // XXX Probably wrong for stateful encodings
1.601 ++ __tmp_state = __state;
1.602 ++ ++__from_next;
1.603 ++ *__to_next++ = L'\0';
1.604 ++ }
1.605 ++ else
1.606 ++ __ret = partial;
1.607 ++ }
1.608 ++ }
1.609 ++
1.610 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.611 ++ __uselocale(__old);
1.612 ++#endif
1.613 ++
1.614 ++ return __ret;
1.615 ++ }
1.616 ++
1.617 ++ int
1.618 ++ codecvt<wchar_t, char, mbstate_t>::
1.619 ++ do_encoding() const throw()
1.620 ++ {
1.621 ++ // XXX This implementation assumes that the encoding is
1.622 ++ // stateless and is either single-byte or variable-width.
1.623 ++ int __ret = 0;
1.624 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.625 ++ __c_locale __old = __uselocale(_M_c_locale_codecvt);
1.626 ++#endif
1.627 ++ if (MB_CUR_MAX == 1)
1.628 ++ __ret = 1;
1.629 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.630 ++ __uselocale(__old);
1.631 ++#endif
1.632 ++ return __ret;
1.633 ++ }
1.634 ++
1.635 ++ int
1.636 ++ codecvt<wchar_t, char, mbstate_t>::
1.637 ++ do_max_length() const throw()
1.638 ++ {
1.639 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.640 ++ __c_locale __old = __uselocale(_M_c_locale_codecvt);
1.641 ++#endif
1.642 ++ // XXX Probably wrong for stateful encodings.
1.643 ++ int __ret = MB_CUR_MAX;
1.644 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.645 ++ __uselocale(__old);
1.646 ++#endif
1.647 ++ return __ret;
1.648 ++ }
1.649 ++
1.650 ++ int
1.651 ++ codecvt<wchar_t, char, mbstate_t>::
1.652 ++ do_length(state_type& __state, const extern_type* __from,
1.653 ++ const extern_type* __end, size_t __max) const
1.654 ++ {
1.655 ++ int __ret = 0;
1.656 ++ state_type __tmp_state(__state);
1.657 ++
1.658 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.659 ++ __c_locale __old = __uselocale(_M_c_locale_codecvt);
1.660 ++#endif
1.661 ++
1.662 ++ // mbsnrtowcs is *very* fast but stops if encounters NUL characters:
1.663 ++ // in case we advance past it and then continue, in a loop.
1.664 ++ // NB: mbsnrtowcs is a GNU extension
1.665 ++
1.666 ++ // A dummy internal buffer is needed in order for mbsnrtocws to consider
1.667 ++ // its fourth parameter (it wouldn't with NULL as first parameter).
1.668 ++ wchar_t* __to = static_cast<wchar_t*>(__builtin_alloca(sizeof(wchar_t)
1.669 ++ * __max));
1.670 ++ while (__from < __end && __max)
1.671 ++ {
1.672 ++ const extern_type* __from_chunk_end;
1.673 ++ __from_chunk_end = static_cast<const extern_type*>(memchr(__from, '\0',
1.674 ++ __end
1.675 ++ - __from));
1.676 ++ if (!__from_chunk_end)
1.677 ++ __from_chunk_end = __end;
1.678 ++
1.679 ++ const extern_type* __tmp_from = __from;
1.680 ++ size_t __conv = mbsnrtowcs(__to, &__from,
1.681 ++ __from_chunk_end - __from,
1.682 ++ __max, &__state);
1.683 ++ if (__conv == static_cast<size_t>(-1))
1.684 ++ {
1.685 ++ // In case of error, in order to stop at the exact place we
1.686 ++ // have to start again from the beginning with a series of
1.687 ++ // mbrtowc.
1.688 ++ for (__from = __tmp_from;; __from += __conv)
1.689 ++ {
1.690 ++ __conv = mbrtowc(NULL, __from, __end - __from,
1.691 ++ &__tmp_state);
1.692 ++ if (__conv == static_cast<size_t>(-1)
1.693 ++ || __conv == static_cast<size_t>(-2))
1.694 ++ break;
1.695 ++ }
1.696 ++ __state = __tmp_state;
1.697 ++ __ret += __from - __tmp_from;
1.698 ++ break;
1.699 ++ }
1.700 ++ if (!__from)
1.701 ++ __from = __from_chunk_end;
1.702 ++
1.703 ++ __ret += __from - __tmp_from;
1.704 ++ __max -= __conv;
1.705 ++
1.706 ++ if (__from < __end && __max)
1.707 ++ {
1.708 ++ // XXX Probably wrong for stateful encodings
1.709 ++ __tmp_state = __state;
1.710 ++ ++__from;
1.711 ++ ++__ret;
1.712 ++ --__max;
1.713 ++ }
1.714 ++ }
1.715 ++
1.716 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.717 ++ __uselocale(__old);
1.718 ++#endif
1.719 ++
1.720 ++ return __ret;
1.721 ++ }
1.722 ++#endif
1.723 ++}
1.724 +--- gcc/libstdc++-v3/config/locale/uclibc/collate_members.cc
1.725 ++++ gcc/libstdc++-v3/config/locale/uclibc/collate_members.cc
1.726 +@@ -0,0 +1,80 @@
1.727 ++// std::collate implementation details, GNU version -*- C++ -*-
1.728 ++
1.729 ++// Copyright (C) 2001, 2002 Free Software Foundation, Inc.
1.730 ++//
1.731 ++// This file is part of the GNU ISO C++ Library. This library is free
1.732 ++// software; you can redistribute it and/or modify it under the
1.733 ++// terms of the GNU General Public License as published by the
1.734 ++// Free Software Foundation; either version 2, or (at your option)
1.735 ++// any later version.
1.736 ++
1.737 ++// This library is distributed in the hope that it will be useful,
1.738 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.739 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.740 ++// GNU General Public License for more details.
1.741 ++
1.742 ++// You should have received a copy of the GNU General Public License along
1.743 ++// with this library; see the file COPYING. If not, write to the Free
1.744 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.745 ++// USA.
1.746 ++
1.747 ++// As a special exception, you may use this file as part of a free software
1.748 ++// library without restriction. Specifically, if other files instantiate
1.749 ++// templates or use macros or inline functions from this file, or you compile
1.750 ++// this file and link it with other files to produce an executable, this
1.751 ++// file does not by itself cause the resulting executable to be covered by
1.752 ++// the GNU General Public License. This exception does not however
1.753 ++// invalidate any other reasons why the executable file might be covered by
1.754 ++// the GNU General Public License.
1.755 ++
1.756 ++//
1.757 ++// ISO C++ 14882: 22.2.4.1.2 collate virtual functions
1.758 ++//
1.759 ++
1.760 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.761 ++
1.762 ++#include <locale>
1.763 ++#include <bits/c++locale_internal.h>
1.764 ++
1.765 ++#ifndef __UCLIBC_HAS_XLOCALE__
1.766 ++#define __strcoll_l(S1, S2, L) strcoll((S1), (S2))
1.767 ++#define __strxfrm_l(S1, S2, N, L) strxfrm((S1), (S2), (N))
1.768 ++#define __wcscoll_l(S1, S2, L) wcscoll((S1), (S2))
1.769 ++#define __wcsxfrm_l(S1, S2, N, L) wcsxfrm((S1), (S2), (N))
1.770 ++#endif
1.771 ++
1.772 ++namespace std
1.773 ++{
1.774 ++ // These are basically extensions to char_traits, and perhaps should
1.775 ++ // be put there instead of here.
1.776 ++ template<>
1.777 ++ int
1.778 ++ collate<char>::_M_compare(const char* __one, const char* __two) const
1.779 ++ {
1.780 ++ int __cmp = __strcoll_l(__one, __two, _M_c_locale_collate);
1.781 ++ return (__cmp >> (8 * sizeof (int) - 2)) | (__cmp != 0);
1.782 ++ }
1.783 ++
1.784 ++ template<>
1.785 ++ size_t
1.786 ++ collate<char>::_M_transform(char* __to, const char* __from,
1.787 ++ size_t __n) const
1.788 ++ { return __strxfrm_l(__to, __from, __n, _M_c_locale_collate); }
1.789 ++
1.790 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.791 ++ template<>
1.792 ++ int
1.793 ++ collate<wchar_t>::_M_compare(const wchar_t* __one,
1.794 ++ const wchar_t* __two) const
1.795 ++ {
1.796 ++ int __cmp = __wcscoll_l(__one, __two, _M_c_locale_collate);
1.797 ++ return (__cmp >> (8 * sizeof (int) - 2)) | (__cmp != 0);
1.798 ++ }
1.799 ++
1.800 ++ template<>
1.801 ++ size_t
1.802 ++ collate<wchar_t>::_M_transform(wchar_t* __to, const wchar_t* __from,
1.803 ++ size_t __n) const
1.804 ++ { return __wcsxfrm_l(__to, __from, __n, _M_c_locale_collate); }
1.805 ++#endif
1.806 ++}
1.807 +--- gcc/libstdc++-v3/config/locale/uclibc/ctype_members.cc
1.808 ++++ gcc/libstdc++-v3/config/locale/uclibc/ctype_members.cc
1.809 +@@ -0,0 +1,300 @@
1.810 ++// std::ctype implementation details, GNU version -*- C++ -*-
1.811 ++
1.812 ++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.813 ++//
1.814 ++// This file is part of the GNU ISO C++ Library. This library is free
1.815 ++// software; you can redistribute it and/or modify it under the
1.816 ++// terms of the GNU General Public License as published by the
1.817 ++// Free Software Foundation; either version 2, or (at your option)
1.818 ++// any later version.
1.819 ++
1.820 ++// This library is distributed in the hope that it will be useful,
1.821 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.822 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.823 ++// GNU General Public License for more details.
1.824 ++
1.825 ++// You should have received a copy of the GNU General Public License along
1.826 ++// with this library; see the file COPYING. If not, write to the Free
1.827 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.828 ++// USA.
1.829 ++
1.830 ++// As a special exception, you may use this file as part of a free software
1.831 ++// library without restriction. Specifically, if other files instantiate
1.832 ++// templates or use macros or inline functions from this file, or you compile
1.833 ++// this file and link it with other files to produce an executable, this
1.834 ++// file does not by itself cause the resulting executable to be covered by
1.835 ++// the GNU General Public License. This exception does not however
1.836 ++// invalidate any other reasons why the executable file might be covered by
1.837 ++// the GNU General Public License.
1.838 ++
1.839 ++//
1.840 ++// ISO C++ 14882: 22.2.1.1.2 ctype virtual functions.
1.841 ++//
1.842 ++
1.843 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.844 ++
1.845 ++#define _LIBC
1.846 ++#include <locale>
1.847 ++#undef _LIBC
1.848 ++#include <bits/c++locale_internal.h>
1.849 ++
1.850 ++#ifndef __UCLIBC_HAS_XLOCALE__
1.851 ++#define __wctype_l(S, L) wctype((S))
1.852 ++#define __towupper_l(C, L) towupper((C))
1.853 ++#define __towlower_l(C, L) towlower((C))
1.854 ++#define __iswctype_l(C, M, L) iswctype((C), (M))
1.855 ++#endif
1.856 ++
1.857 ++namespace std
1.858 ++{
1.859 ++ // NB: The other ctype<char> specializations are in src/locale.cc and
1.860 ++ // various /config/os/* files.
1.861 ++ template<>
1.862 ++ ctype_byname<char>::ctype_byname(const char* __s, size_t __refs)
1.863 ++ : ctype<char>(0, false, __refs)
1.864 ++ {
1.865 ++ if (std::strcmp(__s, "C") != 0 && std::strcmp(__s, "POSIX") != 0)
1.866 ++ {
1.867 ++ this->_S_destroy_c_locale(this->_M_c_locale_ctype);
1.868 ++ this->_S_create_c_locale(this->_M_c_locale_ctype, __s);
1.869 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.870 ++ this->_M_toupper = this->_M_c_locale_ctype->__ctype_toupper;
1.871 ++ this->_M_tolower = this->_M_c_locale_ctype->__ctype_tolower;
1.872 ++ this->_M_table = this->_M_c_locale_ctype->__ctype_b;
1.873 ++#endif
1.874 ++ }
1.875 ++ }
1.876 ++
1.877 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.878 ++ ctype<wchar_t>::__wmask_type
1.879 ++ ctype<wchar_t>::_M_convert_to_wmask(const mask __m) const
1.880 ++ {
1.881 ++ __wmask_type __ret;
1.882 ++ switch (__m)
1.883 ++ {
1.884 ++ case space:
1.885 ++ __ret = __wctype_l("space", _M_c_locale_ctype);
1.886 ++ break;
1.887 ++ case print:
1.888 ++ __ret = __wctype_l("print", _M_c_locale_ctype);
1.889 ++ break;
1.890 ++ case cntrl:
1.891 ++ __ret = __wctype_l("cntrl", _M_c_locale_ctype);
1.892 ++ break;
1.893 ++ case upper:
1.894 ++ __ret = __wctype_l("upper", _M_c_locale_ctype);
1.895 ++ break;
1.896 ++ case lower:
1.897 ++ __ret = __wctype_l("lower", _M_c_locale_ctype);
1.898 ++ break;
1.899 ++ case alpha:
1.900 ++ __ret = __wctype_l("alpha", _M_c_locale_ctype);
1.901 ++ break;
1.902 ++ case digit:
1.903 ++ __ret = __wctype_l("digit", _M_c_locale_ctype);
1.904 ++ break;
1.905 ++ case punct:
1.906 ++ __ret = __wctype_l("punct", _M_c_locale_ctype);
1.907 ++ break;
1.908 ++ case xdigit:
1.909 ++ __ret = __wctype_l("xdigit", _M_c_locale_ctype);
1.910 ++ break;
1.911 ++ case alnum:
1.912 ++ __ret = __wctype_l("alnum", _M_c_locale_ctype);
1.913 ++ break;
1.914 ++ case graph:
1.915 ++ __ret = __wctype_l("graph", _M_c_locale_ctype);
1.916 ++ break;
1.917 ++ default:
1.918 ++ __ret = __wmask_type();
1.919 ++ }
1.920 ++ return __ret;
1.921 ++ }
1.922 ++
1.923 ++ wchar_t
1.924 ++ ctype<wchar_t>::do_toupper(wchar_t __c) const
1.925 ++ { return __towupper_l(__c, _M_c_locale_ctype); }
1.926 ++
1.927 ++ const wchar_t*
1.928 ++ ctype<wchar_t>::do_toupper(wchar_t* __lo, const wchar_t* __hi) const
1.929 ++ {
1.930 ++ while (__lo < __hi)
1.931 ++ {
1.932 ++ *__lo = __towupper_l(*__lo, _M_c_locale_ctype);
1.933 ++ ++__lo;
1.934 ++ }
1.935 ++ return __hi;
1.936 ++ }
1.937 ++
1.938 ++ wchar_t
1.939 ++ ctype<wchar_t>::do_tolower(wchar_t __c) const
1.940 ++ { return __towlower_l(__c, _M_c_locale_ctype); }
1.941 ++
1.942 ++ const wchar_t*
1.943 ++ ctype<wchar_t>::do_tolower(wchar_t* __lo, const wchar_t* __hi) const
1.944 ++ {
1.945 ++ while (__lo < __hi)
1.946 ++ {
1.947 ++ *__lo = __towlower_l(*__lo, _M_c_locale_ctype);
1.948 ++ ++__lo;
1.949 ++ }
1.950 ++ return __hi;
1.951 ++ }
1.952 ++
1.953 ++ bool
1.954 ++ ctype<wchar_t>::
1.955 ++ do_is(mask __m, wchar_t __c) const
1.956 ++ {
1.957 ++ // Highest bitmask in ctype_base == 10, but extra in "C"
1.958 ++ // library for blank.
1.959 ++ bool __ret = false;
1.960 ++ const size_t __bitmasksize = 11;
1.961 ++ for (size_t __bitcur = 0; __bitcur <= __bitmasksize; ++__bitcur)
1.962 ++ if (__m & _M_bit[__bitcur]
1.963 ++ && __iswctype_l(__c, _M_wmask[__bitcur], _M_c_locale_ctype))
1.964 ++ {
1.965 ++ __ret = true;
1.966 ++ break;
1.967 ++ }
1.968 ++ return __ret;
1.969 ++ }
1.970 ++
1.971 ++ const wchar_t*
1.972 ++ ctype<wchar_t>::
1.973 ++ do_is(const wchar_t* __lo, const wchar_t* __hi, mask* __vec) const
1.974 ++ {
1.975 ++ for (; __lo < __hi; ++__vec, ++__lo)
1.976 ++ {
1.977 ++ // Highest bitmask in ctype_base == 10, but extra in "C"
1.978 ++ // library for blank.
1.979 ++ const size_t __bitmasksize = 11;
1.980 ++ mask __m = 0;
1.981 ++ for (size_t __bitcur = 0; __bitcur <= __bitmasksize; ++__bitcur)
1.982 ++ if (__iswctype_l(*__lo, _M_wmask[__bitcur], _M_c_locale_ctype))
1.983 ++ __m |= _M_bit[__bitcur];
1.984 ++ *__vec = __m;
1.985 ++ }
1.986 ++ return __hi;
1.987 ++ }
1.988 ++
1.989 ++ const wchar_t*
1.990 ++ ctype<wchar_t>::
1.991 ++ do_scan_is(mask __m, const wchar_t* __lo, const wchar_t* __hi) const
1.992 ++ {
1.993 ++ while (__lo < __hi && !this->do_is(__m, *__lo))
1.994 ++ ++__lo;
1.995 ++ return __lo;
1.996 ++ }
1.997 ++
1.998 ++ const wchar_t*
1.999 ++ ctype<wchar_t>::
1.1000 ++ do_scan_not(mask __m, const char_type* __lo, const char_type* __hi) const
1.1001 ++ {
1.1002 ++ while (__lo < __hi && this->do_is(__m, *__lo) != 0)
1.1003 ++ ++__lo;
1.1004 ++ return __lo;
1.1005 ++ }
1.1006 ++
1.1007 ++ wchar_t
1.1008 ++ ctype<wchar_t>::
1.1009 ++ do_widen(char __c) const
1.1010 ++ { return _M_widen[static_cast<unsigned char>(__c)]; }
1.1011 ++
1.1012 ++ const char*
1.1013 ++ ctype<wchar_t>::
1.1014 ++ do_widen(const char* __lo, const char* __hi, wchar_t* __dest) const
1.1015 ++ {
1.1016 ++ while (__lo < __hi)
1.1017 ++ {
1.1018 ++ *__dest = _M_widen[static_cast<unsigned char>(*__lo)];
1.1019 ++ ++__lo;
1.1020 ++ ++__dest;
1.1021 ++ }
1.1022 ++ return __hi;
1.1023 ++ }
1.1024 ++
1.1025 ++ char
1.1026 ++ ctype<wchar_t>::
1.1027 ++ do_narrow(wchar_t __wc, char __dfault) const
1.1028 ++ {
1.1029 ++ if (__wc >= 0 && __wc < 128 && _M_narrow_ok)
1.1030 ++ return _M_narrow[__wc];
1.1031 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1032 ++ __c_locale __old = __uselocale(_M_c_locale_ctype);
1.1033 ++#endif
1.1034 ++ const int __c = wctob(__wc);
1.1035 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1036 ++ __uselocale(__old);
1.1037 ++#endif
1.1038 ++ return (__c == EOF ? __dfault : static_cast<char>(__c));
1.1039 ++ }
1.1040 ++
1.1041 ++ const wchar_t*
1.1042 ++ ctype<wchar_t>::
1.1043 ++ do_narrow(const wchar_t* __lo, const wchar_t* __hi, char __dfault,
1.1044 ++ char* __dest) const
1.1045 ++ {
1.1046 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1047 ++ __c_locale __old = __uselocale(_M_c_locale_ctype);
1.1048 ++#endif
1.1049 ++ if (_M_narrow_ok)
1.1050 ++ while (__lo < __hi)
1.1051 ++ {
1.1052 ++ if (*__lo >= 0 && *__lo < 128)
1.1053 ++ *__dest = _M_narrow[*__lo];
1.1054 ++ else
1.1055 ++ {
1.1056 ++ const int __c = wctob(*__lo);
1.1057 ++ *__dest = (__c == EOF ? __dfault : static_cast<char>(__c));
1.1058 ++ }
1.1059 ++ ++__lo;
1.1060 ++ ++__dest;
1.1061 ++ }
1.1062 ++ else
1.1063 ++ while (__lo < __hi)
1.1064 ++ {
1.1065 ++ const int __c = wctob(*__lo);
1.1066 ++ *__dest = (__c == EOF ? __dfault : static_cast<char>(__c));
1.1067 ++ ++__lo;
1.1068 ++ ++__dest;
1.1069 ++ }
1.1070 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1071 ++ __uselocale(__old);
1.1072 ++#endif
1.1073 ++ return __hi;
1.1074 ++ }
1.1075 ++
1.1076 ++ void
1.1077 ++ ctype<wchar_t>::_M_initialize_ctype()
1.1078 ++ {
1.1079 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1080 ++ __c_locale __old = __uselocale(_M_c_locale_ctype);
1.1081 ++#endif
1.1082 ++ wint_t __i;
1.1083 ++ for (__i = 0; __i < 128; ++__i)
1.1084 ++ {
1.1085 ++ const int __c = wctob(__i);
1.1086 ++ if (__c == EOF)
1.1087 ++ break;
1.1088 ++ else
1.1089 ++ _M_narrow[__i] = static_cast<char>(__c);
1.1090 ++ }
1.1091 ++ if (__i == 128)
1.1092 ++ _M_narrow_ok = true;
1.1093 ++ else
1.1094 ++ _M_narrow_ok = false;
1.1095 ++ for (size_t __j = 0;
1.1096 ++ __j < sizeof(_M_widen) / sizeof(wint_t); ++__j)
1.1097 ++ _M_widen[__j] = btowc(__j);
1.1098 ++
1.1099 ++ for (size_t __k = 0; __k <= 11; ++__k)
1.1100 ++ {
1.1101 ++ _M_bit[__k] = static_cast<mask>(_ISbit(__k));
1.1102 ++ _M_wmask[__k] = _M_convert_to_wmask(_M_bit[__k]);
1.1103 ++ }
1.1104 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1105 ++ __uselocale(__old);
1.1106 ++#endif
1.1107 ++ }
1.1108 ++#endif // _GLIBCXX_USE_WCHAR_T
1.1109 ++}
1.1110 +--- gcc/libstdc++-v3/config/locale/uclibc/messages_members.cc
1.1111 ++++ gcc/libstdc++-v3/config/locale/uclibc/messages_members.cc
1.1112 +@@ -0,0 +1,100 @@
1.1113 ++// std::messages implementation details, GNU version -*- C++ -*-
1.1114 ++
1.1115 ++// Copyright (C) 2001, 2002 Free Software Foundation, Inc.
1.1116 ++//
1.1117 ++// This file is part of the GNU ISO C++ Library. This library is free
1.1118 ++// software; you can redistribute it and/or modify it under the
1.1119 ++// terms of the GNU General Public License as published by the
1.1120 ++// Free Software Foundation; either version 2, or (at your option)
1.1121 ++// any later version.
1.1122 ++
1.1123 ++// This library is distributed in the hope that it will be useful,
1.1124 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.1125 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.1126 ++// GNU General Public License for more details.
1.1127 ++
1.1128 ++// You should have received a copy of the GNU General Public License along
1.1129 ++// with this library; see the file COPYING. If not, write to the Free
1.1130 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.1131 ++// USA.
1.1132 ++
1.1133 ++// As a special exception, you may use this file as part of a free software
1.1134 ++// library without restriction. Specifically, if other files instantiate
1.1135 ++// templates or use macros or inline functions from this file, or you compile
1.1136 ++// this file and link it with other files to produce an executable, this
1.1137 ++// file does not by itself cause the resulting executable to be covered by
1.1138 ++// the GNU General Public License. This exception does not however
1.1139 ++// invalidate any other reasons why the executable file might be covered by
1.1140 ++// the GNU General Public License.
1.1141 ++
1.1142 ++//
1.1143 ++// ISO C++ 14882: 22.2.7.1.2 messages virtual functions
1.1144 ++//
1.1145 ++
1.1146 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.1147 ++
1.1148 ++#include <locale>
1.1149 ++#include <bits/c++locale_internal.h>
1.1150 ++
1.1151 ++#ifdef __UCLIBC_MJN3_ONLY__
1.1152 ++#warning fix gettext stuff
1.1153 ++#endif
1.1154 ++#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__
1.1155 ++extern "C" char *__dcgettext(const char *domainname,
1.1156 ++ const char *msgid, int category);
1.1157 ++#undef gettext
1.1158 ++#define gettext(msgid) __dcgettext(NULL, msgid, LC_MESSAGES)
1.1159 ++#else
1.1160 ++#undef gettext
1.1161 ++#define gettext(msgid) (msgid)
1.1162 ++#endif
1.1163 ++
1.1164 ++namespace std
1.1165 ++{
1.1166 ++ // Specializations.
1.1167 ++ template<>
1.1168 ++ string
1.1169 ++ messages<char>::do_get(catalog, int, int, const string& __dfault) const
1.1170 ++ {
1.1171 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1172 ++ __c_locale __old = __uselocale(_M_c_locale_messages);
1.1173 ++ const char* __msg = const_cast<const char*>(gettext(__dfault.c_str()));
1.1174 ++ __uselocale(__old);
1.1175 ++ return string(__msg);
1.1176 ++#elif defined __UCLIBC_HAS_LOCALE__
1.1177 ++ char* __old = strdup(setlocale(LC_ALL, NULL));
1.1178 ++ setlocale(LC_ALL, _M_name_messages);
1.1179 ++ const char* __msg = gettext(__dfault.c_str());
1.1180 ++ setlocale(LC_ALL, __old);
1.1181 ++ free(__old);
1.1182 ++ return string(__msg);
1.1183 ++#else
1.1184 ++ const char* __msg = gettext(__dfault.c_str());
1.1185 ++ return string(__msg);
1.1186 ++#endif
1.1187 ++ }
1.1188 ++
1.1189 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.1190 ++ template<>
1.1191 ++ wstring
1.1192 ++ messages<wchar_t>::do_get(catalog, int, int, const wstring& __dfault) const
1.1193 ++ {
1.1194 ++# ifdef __UCLIBC_HAS_XLOCALE__
1.1195 ++ __c_locale __old = __uselocale(_M_c_locale_messages);
1.1196 ++ char* __msg = gettext(_M_convert_to_char(__dfault));
1.1197 ++ __uselocale(__old);
1.1198 ++ return _M_convert_from_char(__msg);
1.1199 ++# elif defined __UCLIBC_HAS_LOCALE__
1.1200 ++ char* __old = strdup(setlocale(LC_ALL, NULL));
1.1201 ++ setlocale(LC_ALL, _M_name_messages);
1.1202 ++ char* __msg = gettext(_M_convert_to_char(__dfault));
1.1203 ++ setlocale(LC_ALL, __old);
1.1204 ++ free(__old);
1.1205 ++ return _M_convert_from_char(__msg);
1.1206 ++# else
1.1207 ++ char* __msg = gettext(_M_convert_to_char(__dfault));
1.1208 ++ return _M_convert_from_char(__msg);
1.1209 ++# endif
1.1210 ++ }
1.1211 ++#endif
1.1212 ++}
1.1213 +--- gcc/libstdc++-v3/config/locale/uclibc/messages_members.h
1.1214 ++++ gcc/libstdc++-v3/config/locale/uclibc/messages_members.h
1.1215 +@@ -0,0 +1,118 @@
1.1216 ++// std::messages implementation details, GNU version -*- C++ -*-
1.1217 ++
1.1218 ++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.1219 ++//
1.1220 ++// This file is part of the GNU ISO C++ Library. This library is free
1.1221 ++// software; you can redistribute it and/or modify it under the
1.1222 ++// terms of the GNU General Public License as published by the
1.1223 ++// Free Software Foundation; either version 2, or (at your option)
1.1224 ++// any later version.
1.1225 ++
1.1226 ++// This library is distributed in the hope that it will be useful,
1.1227 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.1228 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.1229 ++// GNU General Public License for more details.
1.1230 ++
1.1231 ++// You should have received a copy of the GNU General Public License along
1.1232 ++// with this library; see the file COPYING. If not, write to the Free
1.1233 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.1234 ++// USA.
1.1235 ++
1.1236 ++// As a special exception, you may use this file as part of a free software
1.1237 ++// library without restriction. Specifically, if other files instantiate
1.1238 ++// templates or use macros or inline functions from this file, or you compile
1.1239 ++// this file and link it with other files to produce an executable, this
1.1240 ++// file does not by itself cause the resulting executable to be covered by
1.1241 ++// the GNU General Public License. This exception does not however
1.1242 ++// invalidate any other reasons why the executable file might be covered by
1.1243 ++// the GNU General Public License.
1.1244 ++
1.1245 ++//
1.1246 ++// ISO C++ 14882: 22.2.7.1.2 messages functions
1.1247 ++//
1.1248 ++
1.1249 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.1250 ++
1.1251 ++#ifdef __UCLIBC_MJN3_ONLY__
1.1252 ++#warning fix prototypes for *textdomain funcs
1.1253 ++#endif
1.1254 ++#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__
1.1255 ++extern "C" char *__textdomain(const char *domainname);
1.1256 ++extern "C" char *__bindtextdomain(const char *domainname,
1.1257 ++ const char *dirname);
1.1258 ++#else
1.1259 ++#undef __textdomain
1.1260 ++#undef __bindtextdomain
1.1261 ++#define __textdomain(D) ((void)0)
1.1262 ++#define __bindtextdomain(D,P) ((void)0)
1.1263 ++#endif
1.1264 ++
1.1265 ++ // Non-virtual member functions.
1.1266 ++ template<typename _CharT>
1.1267 ++ messages<_CharT>::messages(size_t __refs)
1.1268 ++ : facet(__refs), _M_c_locale_messages(_S_get_c_locale()),
1.1269 ++ _M_name_messages(_S_get_c_name())
1.1270 ++ { }
1.1271 ++
1.1272 ++ template<typename _CharT>
1.1273 ++ messages<_CharT>::messages(__c_locale __cloc, const char* __s,
1.1274 ++ size_t __refs)
1.1275 ++ : facet(__refs), _M_c_locale_messages(_S_clone_c_locale(__cloc)),
1.1276 ++ _M_name_messages(__s)
1.1277 ++ {
1.1278 ++ char* __tmp = new char[std::strlen(__s) + 1];
1.1279 ++ std::strcpy(__tmp, __s);
1.1280 ++ _M_name_messages = __tmp;
1.1281 ++ }
1.1282 ++
1.1283 ++ template<typename _CharT>
1.1284 ++ typename messages<_CharT>::catalog
1.1285 ++ messages<_CharT>::open(const basic_string<char>& __s, const locale& __loc,
1.1286 ++ const char* __dir) const
1.1287 ++ {
1.1288 ++ __bindtextdomain(__s.c_str(), __dir);
1.1289 ++ return this->do_open(__s, __loc);
1.1290 ++ }
1.1291 ++
1.1292 ++ // Virtual member functions.
1.1293 ++ template<typename _CharT>
1.1294 ++ messages<_CharT>::~messages()
1.1295 ++ {
1.1296 ++ if (_M_name_messages != _S_get_c_name())
1.1297 ++ delete [] _M_name_messages;
1.1298 ++ _S_destroy_c_locale(_M_c_locale_messages);
1.1299 ++ }
1.1300 ++
1.1301 ++ template<typename _CharT>
1.1302 ++ typename messages<_CharT>::catalog
1.1303 ++ messages<_CharT>::do_open(const basic_string<char>& __s,
1.1304 ++ const locale&) const
1.1305 ++ {
1.1306 ++ // No error checking is done, assume the catalog exists and can
1.1307 ++ // be used.
1.1308 ++ __textdomain(__s.c_str());
1.1309 ++ return 0;
1.1310 ++ }
1.1311 ++
1.1312 ++ template<typename _CharT>
1.1313 ++ void
1.1314 ++ messages<_CharT>::do_close(catalog) const
1.1315 ++ { }
1.1316 ++
1.1317 ++ // messages_byname
1.1318 ++ template<typename _CharT>
1.1319 ++ messages_byname<_CharT>::messages_byname(const char* __s, size_t __refs)
1.1320 ++ : messages<_CharT>(__refs)
1.1321 ++ {
1.1322 ++ if (this->_M_name_messages != locale::facet::_S_get_c_name())
1.1323 ++ delete [] this->_M_name_messages;
1.1324 ++ char* __tmp = new char[std::strlen(__s) + 1];
1.1325 ++ std::strcpy(__tmp, __s);
1.1326 ++ this->_M_name_messages = __tmp;
1.1327 ++
1.1328 ++ if (std::strcmp(__s, "C") != 0 && std::strcmp(__s, "POSIX") != 0)
1.1329 ++ {
1.1330 ++ this->_S_destroy_c_locale(this->_M_c_locale_messages);
1.1331 ++ this->_S_create_c_locale(this->_M_c_locale_messages, __s);
1.1332 ++ }
1.1333 ++ }
1.1334 +--- gcc/libstdc++-v3/config/locale/uclibc/monetary_members.cc
1.1335 ++++ gcc/libstdc++-v3/config/locale/uclibc/monetary_members.cc
1.1336 +@@ -0,0 +1,692 @@
1.1337 ++// std::moneypunct implementation details, GNU version -*- C++ -*-
1.1338 ++
1.1339 ++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.1340 ++//
1.1341 ++// This file is part of the GNU ISO C++ Library. This library is free
1.1342 ++// software; you can redistribute it and/or modify it under the
1.1343 ++// terms of the GNU General Public License as published by the
1.1344 ++// Free Software Foundation; either version 2, or (at your option)
1.1345 ++// any later version.
1.1346 ++
1.1347 ++// This library is distributed in the hope that it will be useful,
1.1348 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.1349 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.1350 ++// GNU General Public License for more details.
1.1351 ++
1.1352 ++// You should have received a copy of the GNU General Public License along
1.1353 ++// with this library; see the file COPYING. If not, write to the Free
1.1354 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.1355 ++// USA.
1.1356 ++
1.1357 ++// As a special exception, you may use this file as part of a free software
1.1358 ++// library without restriction. Specifically, if other files instantiate
1.1359 ++// templates or use macros or inline functions from this file, or you compile
1.1360 ++// this file and link it with other files to produce an executable, this
1.1361 ++// file does not by itself cause the resulting executable to be covered by
1.1362 ++// the GNU General Public License. This exception does not however
1.1363 ++// invalidate any other reasons why the executable file might be covered by
1.1364 ++// the GNU General Public License.
1.1365 ++
1.1366 ++//
1.1367 ++// ISO C++ 14882: 22.2.6.3.2 moneypunct virtual functions
1.1368 ++//
1.1369 ++
1.1370 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.1371 ++
1.1372 ++#define _LIBC
1.1373 ++#include <locale>
1.1374 ++#undef _LIBC
1.1375 ++#include <bits/c++locale_internal.h>
1.1376 ++
1.1377 ++#ifdef __UCLIBC_MJN3_ONLY__
1.1378 ++#warning optimize this for uclibc
1.1379 ++#warning tailor for stub locale support
1.1380 ++#endif
1.1381 ++
1.1382 ++#ifndef __UCLIBC_HAS_XLOCALE__
1.1383 ++#define __nl_langinfo_l(N, L) nl_langinfo((N))
1.1384 ++#endif
1.1385 ++
1.1386 ++namespace std
1.1387 ++{
1.1388 ++ // Construct and return valid pattern consisting of some combination of:
1.1389 ++ // space none symbol sign value
1.1390 ++ money_base::pattern
1.1391 ++ money_base::_S_construct_pattern(char __precedes, char __space, char __posn)
1.1392 ++ {
1.1393 ++ pattern __ret;
1.1394 ++
1.1395 ++ // This insanely complicated routine attempts to construct a valid
1.1396 ++ // pattern for use with monyepunct. A couple of invariants:
1.1397 ++
1.1398 ++ // if (__precedes) symbol -> value
1.1399 ++ // else value -> symbol
1.1400 ++
1.1401 ++ // if (__space) space
1.1402 ++ // else none
1.1403 ++
1.1404 ++ // none == never first
1.1405 ++ // space never first or last
1.1406 ++
1.1407 ++ // Any elegant implementations of this are welcome.
1.1408 ++ switch (__posn)
1.1409 ++ {
1.1410 ++ case 0:
1.1411 ++ case 1:
1.1412 ++ // 1 The sign precedes the value and symbol.
1.1413 ++ __ret.field[0] = sign;
1.1414 ++ if (__space)
1.1415 ++ {
1.1416 ++ // Pattern starts with sign.
1.1417 ++ if (__precedes)
1.1418 ++ {
1.1419 ++ __ret.field[1] = symbol;
1.1420 ++ __ret.field[3] = value;
1.1421 ++ }
1.1422 ++ else
1.1423 ++ {
1.1424 ++ __ret.field[1] = value;
1.1425 ++ __ret.field[3] = symbol;
1.1426 ++ }
1.1427 ++ __ret.field[2] = space;
1.1428 ++ }
1.1429 ++ else
1.1430 ++ {
1.1431 ++ // Pattern starts with sign and ends with none.
1.1432 ++ if (__precedes)
1.1433 ++ {
1.1434 ++ __ret.field[1] = symbol;
1.1435 ++ __ret.field[2] = value;
1.1436 ++ }
1.1437 ++ else
1.1438 ++ {
1.1439 ++ __ret.field[1] = value;
1.1440 ++ __ret.field[2] = symbol;
1.1441 ++ }
1.1442 ++ __ret.field[3] = none;
1.1443 ++ }
1.1444 ++ break;
1.1445 ++ case 2:
1.1446 ++ // 2 The sign follows the value and symbol.
1.1447 ++ if (__space)
1.1448 ++ {
1.1449 ++ // Pattern either ends with sign.
1.1450 ++ if (__precedes)
1.1451 ++ {
1.1452 ++ __ret.field[0] = symbol;
1.1453 ++ __ret.field[2] = value;
1.1454 ++ }
1.1455 ++ else
1.1456 ++ {
1.1457 ++ __ret.field[0] = value;
1.1458 ++ __ret.field[2] = symbol;
1.1459 ++ }
1.1460 ++ __ret.field[1] = space;
1.1461 ++ __ret.field[3] = sign;
1.1462 ++ }
1.1463 ++ else
1.1464 ++ {
1.1465 ++ // Pattern ends with sign then none.
1.1466 ++ if (__precedes)
1.1467 ++ {
1.1468 ++ __ret.field[0] = symbol;
1.1469 ++ __ret.field[1] = value;
1.1470 ++ }
1.1471 ++ else
1.1472 ++ {
1.1473 ++ __ret.field[0] = value;
1.1474 ++ __ret.field[1] = symbol;
1.1475 ++ }
1.1476 ++ __ret.field[2] = sign;
1.1477 ++ __ret.field[3] = none;
1.1478 ++ }
1.1479 ++ break;
1.1480 ++ case 3:
1.1481 ++ // 3 The sign immediately precedes the symbol.
1.1482 ++ if (__precedes)
1.1483 ++ {
1.1484 ++ __ret.field[0] = sign;
1.1485 ++ __ret.field[1] = symbol;
1.1486 ++ if (__space)
1.1487 ++ {
1.1488 ++ __ret.field[2] = space;
1.1489 ++ __ret.field[3] = value;
1.1490 ++ }
1.1491 ++ else
1.1492 ++ {
1.1493 ++ __ret.field[2] = value;
1.1494 ++ __ret.field[3] = none;
1.1495 ++ }
1.1496 ++ }
1.1497 ++ else
1.1498 ++ {
1.1499 ++ __ret.field[0] = value;
1.1500 ++ if (__space)
1.1501 ++ {
1.1502 ++ __ret.field[1] = space;
1.1503 ++ __ret.field[2] = sign;
1.1504 ++ __ret.field[3] = symbol;
1.1505 ++ }
1.1506 ++ else
1.1507 ++ {
1.1508 ++ __ret.field[1] = sign;
1.1509 ++ __ret.field[2] = symbol;
1.1510 ++ __ret.field[3] = none;
1.1511 ++ }
1.1512 ++ }
1.1513 ++ break;
1.1514 ++ case 4:
1.1515 ++ // 4 The sign immediately follows the symbol.
1.1516 ++ if (__precedes)
1.1517 ++ {
1.1518 ++ __ret.field[0] = symbol;
1.1519 ++ __ret.field[1] = sign;
1.1520 ++ if (__space)
1.1521 ++ {
1.1522 ++ __ret.field[2] = space;
1.1523 ++ __ret.field[3] = value;
1.1524 ++ }
1.1525 ++ else
1.1526 ++ {
1.1527 ++ __ret.field[2] = value;
1.1528 ++ __ret.field[3] = none;
1.1529 ++ }
1.1530 ++ }
1.1531 ++ else
1.1532 ++ {
1.1533 ++ __ret.field[0] = value;
1.1534 ++ if (__space)
1.1535 ++ {
1.1536 ++ __ret.field[1] = space;
1.1537 ++ __ret.field[2] = symbol;
1.1538 ++ __ret.field[3] = sign;
1.1539 ++ }
1.1540 ++ else
1.1541 ++ {
1.1542 ++ __ret.field[1] = symbol;
1.1543 ++ __ret.field[2] = sign;
1.1544 ++ __ret.field[3] = none;
1.1545 ++ }
1.1546 ++ }
1.1547 ++ break;
1.1548 ++ default:
1.1549 ++ ;
1.1550 ++ }
1.1551 ++ return __ret;
1.1552 ++ }
1.1553 ++
1.1554 ++ template<>
1.1555 ++ void
1.1556 ++ moneypunct<char, true>::_M_initialize_moneypunct(__c_locale __cloc,
1.1557 ++ const char*)
1.1558 ++ {
1.1559 ++ if (!_M_data)
1.1560 ++ _M_data = new __moneypunct_cache<char, true>;
1.1561 ++
1.1562 ++ if (!__cloc)
1.1563 ++ {
1.1564 ++ // "C" locale
1.1565 ++ _M_data->_M_decimal_point = '.';
1.1566 ++ _M_data->_M_thousands_sep = ',';
1.1567 ++ _M_data->_M_grouping = "";
1.1568 ++ _M_data->_M_grouping_size = 0;
1.1569 ++ _M_data->_M_curr_symbol = "";
1.1570 ++ _M_data->_M_curr_symbol_size = 0;
1.1571 ++ _M_data->_M_positive_sign = "";
1.1572 ++ _M_data->_M_positive_sign_size = 0;
1.1573 ++ _M_data->_M_negative_sign = "";
1.1574 ++ _M_data->_M_negative_sign_size = 0;
1.1575 ++ _M_data->_M_frac_digits = 0;
1.1576 ++ _M_data->_M_pos_format = money_base::_S_default_pattern;
1.1577 ++ _M_data->_M_neg_format = money_base::_S_default_pattern;
1.1578 ++
1.1579 ++ for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1.1580 ++ _M_data->_M_atoms[__i] = money_base::_S_atoms[__i];
1.1581 ++ }
1.1582 ++ else
1.1583 ++ {
1.1584 ++ // Named locale.
1.1585 ++ _M_data->_M_decimal_point = *(__nl_langinfo_l(__MON_DECIMAL_POINT,
1.1586 ++ __cloc));
1.1587 ++ _M_data->_M_thousands_sep = *(__nl_langinfo_l(__MON_THOUSANDS_SEP,
1.1588 ++ __cloc));
1.1589 ++ _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1.1590 ++ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1.1591 ++ _M_data->_M_positive_sign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1.1592 ++ _M_data->_M_positive_sign_size = strlen(_M_data->_M_positive_sign);
1.1593 ++
1.1594 ++ char __nposn = *(__nl_langinfo_l(__INT_N_SIGN_POSN, __cloc));
1.1595 ++ if (!__nposn)
1.1596 ++ _M_data->_M_negative_sign = "()";
1.1597 ++ else
1.1598 ++ _M_data->_M_negative_sign = __nl_langinfo_l(__NEGATIVE_SIGN,
1.1599 ++ __cloc);
1.1600 ++ _M_data->_M_negative_sign_size = strlen(_M_data->_M_negative_sign);
1.1601 ++
1.1602 ++ // _Intl == true
1.1603 ++ _M_data->_M_curr_symbol = __nl_langinfo_l(__INT_CURR_SYMBOL, __cloc);
1.1604 ++ _M_data->_M_curr_symbol_size = strlen(_M_data->_M_curr_symbol);
1.1605 ++ _M_data->_M_frac_digits = *(__nl_langinfo_l(__INT_FRAC_DIGITS,
1.1606 ++ __cloc));
1.1607 ++ char __pprecedes = *(__nl_langinfo_l(__INT_P_CS_PRECEDES, __cloc));
1.1608 ++ char __pspace = *(__nl_langinfo_l(__INT_P_SEP_BY_SPACE, __cloc));
1.1609 ++ char __pposn = *(__nl_langinfo_l(__INT_P_SIGN_POSN, __cloc));
1.1610 ++ _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace,
1.1611 ++ __pposn);
1.1612 ++ char __nprecedes = *(__nl_langinfo_l(__INT_N_CS_PRECEDES, __cloc));
1.1613 ++ char __nspace = *(__nl_langinfo_l(__INT_N_SEP_BY_SPACE, __cloc));
1.1614 ++ _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace,
1.1615 ++ __nposn);
1.1616 ++ }
1.1617 ++ }
1.1618 ++
1.1619 ++ template<>
1.1620 ++ void
1.1621 ++ moneypunct<char, false>::_M_initialize_moneypunct(__c_locale __cloc,
1.1622 ++ const char*)
1.1623 ++ {
1.1624 ++ if (!_M_data)
1.1625 ++ _M_data = new __moneypunct_cache<char, false>;
1.1626 ++
1.1627 ++ if (!__cloc)
1.1628 ++ {
1.1629 ++ // "C" locale
1.1630 ++ _M_data->_M_decimal_point = '.';
1.1631 ++ _M_data->_M_thousands_sep = ',';
1.1632 ++ _M_data->_M_grouping = "";
1.1633 ++ _M_data->_M_grouping_size = 0;
1.1634 ++ _M_data->_M_curr_symbol = "";
1.1635 ++ _M_data->_M_curr_symbol_size = 0;
1.1636 ++ _M_data->_M_positive_sign = "";
1.1637 ++ _M_data->_M_positive_sign_size = 0;
1.1638 ++ _M_data->_M_negative_sign = "";
1.1639 ++ _M_data->_M_negative_sign_size = 0;
1.1640 ++ _M_data->_M_frac_digits = 0;
1.1641 ++ _M_data->_M_pos_format = money_base::_S_default_pattern;
1.1642 ++ _M_data->_M_neg_format = money_base::_S_default_pattern;
1.1643 ++
1.1644 ++ for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1.1645 ++ _M_data->_M_atoms[__i] = money_base::_S_atoms[__i];
1.1646 ++ }
1.1647 ++ else
1.1648 ++ {
1.1649 ++ // Named locale.
1.1650 ++ _M_data->_M_decimal_point = *(__nl_langinfo_l(__MON_DECIMAL_POINT,
1.1651 ++ __cloc));
1.1652 ++ _M_data->_M_thousands_sep = *(__nl_langinfo_l(__MON_THOUSANDS_SEP,
1.1653 ++ __cloc));
1.1654 ++ _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1.1655 ++ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1.1656 ++ _M_data->_M_positive_sign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1.1657 ++ _M_data->_M_positive_sign_size = strlen(_M_data->_M_positive_sign);
1.1658 ++
1.1659 ++ char __nposn = *(__nl_langinfo_l(__N_SIGN_POSN, __cloc));
1.1660 ++ if (!__nposn)
1.1661 ++ _M_data->_M_negative_sign = "()";
1.1662 ++ else
1.1663 ++ _M_data->_M_negative_sign = __nl_langinfo_l(__NEGATIVE_SIGN,
1.1664 ++ __cloc);
1.1665 ++ _M_data->_M_negative_sign_size = strlen(_M_data->_M_negative_sign);
1.1666 ++
1.1667 ++ // _Intl == false
1.1668 ++ _M_data->_M_curr_symbol = __nl_langinfo_l(__CURRENCY_SYMBOL, __cloc);
1.1669 ++ _M_data->_M_curr_symbol_size = strlen(_M_data->_M_curr_symbol);
1.1670 ++ _M_data->_M_frac_digits = *(__nl_langinfo_l(__FRAC_DIGITS, __cloc));
1.1671 ++ char __pprecedes = *(__nl_langinfo_l(__P_CS_PRECEDES, __cloc));
1.1672 ++ char __pspace = *(__nl_langinfo_l(__P_SEP_BY_SPACE, __cloc));
1.1673 ++ char __pposn = *(__nl_langinfo_l(__P_SIGN_POSN, __cloc));
1.1674 ++ _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace,
1.1675 ++ __pposn);
1.1676 ++ char __nprecedes = *(__nl_langinfo_l(__N_CS_PRECEDES, __cloc));
1.1677 ++ char __nspace = *(__nl_langinfo_l(__N_SEP_BY_SPACE, __cloc));
1.1678 ++ _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace,
1.1679 ++ __nposn);
1.1680 ++ }
1.1681 ++ }
1.1682 ++
1.1683 ++ template<>
1.1684 ++ moneypunct<char, true>::~moneypunct()
1.1685 ++ { delete _M_data; }
1.1686 ++
1.1687 ++ template<>
1.1688 ++ moneypunct<char, false>::~moneypunct()
1.1689 ++ { delete _M_data; }
1.1690 ++
1.1691 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.1692 ++ template<>
1.1693 ++ void
1.1694 ++ moneypunct<wchar_t, true>::_M_initialize_moneypunct(__c_locale __cloc,
1.1695 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1696 ++ const char*)
1.1697 ++#else
1.1698 ++ const char* __name)
1.1699 ++#endif
1.1700 ++ {
1.1701 ++ if (!_M_data)
1.1702 ++ _M_data = new __moneypunct_cache<wchar_t, true>;
1.1703 ++
1.1704 ++ if (!__cloc)
1.1705 ++ {
1.1706 ++ // "C" locale
1.1707 ++ _M_data->_M_decimal_point = L'.';
1.1708 ++ _M_data->_M_thousands_sep = L',';
1.1709 ++ _M_data->_M_grouping = "";
1.1710 ++ _M_data->_M_grouping_size = 0;
1.1711 ++ _M_data->_M_curr_symbol = L"";
1.1712 ++ _M_data->_M_curr_symbol_size = 0;
1.1713 ++ _M_data->_M_positive_sign = L"";
1.1714 ++ _M_data->_M_positive_sign_size = 0;
1.1715 ++ _M_data->_M_negative_sign = L"";
1.1716 ++ _M_data->_M_negative_sign_size = 0;
1.1717 ++ _M_data->_M_frac_digits = 0;
1.1718 ++ _M_data->_M_pos_format = money_base::_S_default_pattern;
1.1719 ++ _M_data->_M_neg_format = money_base::_S_default_pattern;
1.1720 ++
1.1721 ++ // Use ctype::widen code without the facet...
1.1722 ++ for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1.1723 ++ _M_data->_M_atoms[__i] =
1.1724 ++ static_cast<wchar_t>(money_base::_S_atoms[__i]);
1.1725 ++ }
1.1726 ++ else
1.1727 ++ {
1.1728 ++ // Named locale.
1.1729 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1730 ++ __c_locale __old = __uselocale(__cloc);
1.1731 ++#else
1.1732 ++ // Switch to named locale so that mbsrtowcs will work.
1.1733 ++ char* __old = strdup(setlocale(LC_ALL, NULL));
1.1734 ++ setlocale(LC_ALL, __name);
1.1735 ++#endif
1.1736 ++
1.1737 ++#ifdef __UCLIBC_MJN3_ONLY__
1.1738 ++#warning fix this... should be monetary
1.1739 ++#endif
1.1740 ++#ifdef __UCLIBC__
1.1741 ++# ifdef __UCLIBC_HAS_XLOCALE__
1.1742 ++ _M_data->_M_decimal_point = __cloc->decimal_point_wc;
1.1743 ++ _M_data->_M_thousands_sep = __cloc->thousands_sep_wc;
1.1744 ++# else
1.1745 ++ _M_data->_M_decimal_point = __global_locale->decimal_point_wc;
1.1746 ++ _M_data->_M_thousands_sep = __global_locale->thousands_sep_wc;
1.1747 ++# endif
1.1748 ++#else
1.1749 ++ union { char *__s; wchar_t __w; } __u;
1.1750 ++ __u.__s = __nl_langinfo_l(_NL_MONETARY_DECIMAL_POINT_WC, __cloc);
1.1751 ++ _M_data->_M_decimal_point = __u.__w;
1.1752 ++
1.1753 ++ __u.__s = __nl_langinfo_l(_NL_MONETARY_THOUSANDS_SEP_WC, __cloc);
1.1754 ++ _M_data->_M_thousands_sep = __u.__w;
1.1755 ++#endif
1.1756 ++ _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1.1757 ++ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1.1758 ++
1.1759 ++ const char* __cpossign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1.1760 ++ const char* __cnegsign = __nl_langinfo_l(__NEGATIVE_SIGN, __cloc);
1.1761 ++ const char* __ccurr = __nl_langinfo_l(__INT_CURR_SYMBOL, __cloc);
1.1762 ++
1.1763 ++ wchar_t* __wcs_ps = 0;
1.1764 ++ wchar_t* __wcs_ns = 0;
1.1765 ++ const char __nposn = *(__nl_langinfo_l(__INT_N_SIGN_POSN, __cloc));
1.1766 ++ try
1.1767 ++ {
1.1768 ++ mbstate_t __state;
1.1769 ++ size_t __len = strlen(__cpossign);
1.1770 ++ if (__len)
1.1771 ++ {
1.1772 ++ ++__len;
1.1773 ++ memset(&__state, 0, sizeof(mbstate_t));
1.1774 ++ __wcs_ps = new wchar_t[__len];
1.1775 ++ mbsrtowcs(__wcs_ps, &__cpossign, __len, &__state);
1.1776 ++ _M_data->_M_positive_sign = __wcs_ps;
1.1777 ++ }
1.1778 ++ else
1.1779 ++ _M_data->_M_positive_sign = L"";
1.1780 ++ _M_data->_M_positive_sign_size = wcslen(_M_data->_M_positive_sign);
1.1781 ++
1.1782 ++ __len = strlen(__cnegsign);
1.1783 ++ if (!__nposn)
1.1784 ++ _M_data->_M_negative_sign = L"()";
1.1785 ++ else if (__len)
1.1786 ++ {
1.1787 ++ ++__len;
1.1788 ++ memset(&__state, 0, sizeof(mbstate_t));
1.1789 ++ __wcs_ns = new wchar_t[__len];
1.1790 ++ mbsrtowcs(__wcs_ns, &__cnegsign, __len, &__state);
1.1791 ++ _M_data->_M_negative_sign = __wcs_ns;
1.1792 ++ }
1.1793 ++ else
1.1794 ++ _M_data->_M_negative_sign = L"";
1.1795 ++ _M_data->_M_negative_sign_size = wcslen(_M_data->_M_negative_sign);
1.1796 ++
1.1797 ++ // _Intl == true.
1.1798 ++ __len = strlen(__ccurr);
1.1799 ++ if (__len)
1.1800 ++ {
1.1801 ++ ++__len;
1.1802 ++ memset(&__state, 0, sizeof(mbstate_t));
1.1803 ++ wchar_t* __wcs = new wchar_t[__len];
1.1804 ++ mbsrtowcs(__wcs, &__ccurr, __len, &__state);
1.1805 ++ _M_data->_M_curr_symbol = __wcs;
1.1806 ++ }
1.1807 ++ else
1.1808 ++ _M_data->_M_curr_symbol = L"";
1.1809 ++ _M_data->_M_curr_symbol_size = wcslen(_M_data->_M_curr_symbol);
1.1810 ++ }
1.1811 ++ catch (...)
1.1812 ++ {
1.1813 ++ delete _M_data;
1.1814 ++ _M_data = 0;
1.1815 ++ delete __wcs_ps;
1.1816 ++ delete __wcs_ns;
1.1817 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1818 ++ __uselocale(__old);
1.1819 ++#else
1.1820 ++ setlocale(LC_ALL, __old);
1.1821 ++ free(__old);
1.1822 ++#endif
1.1823 ++ __throw_exception_again;
1.1824 ++ }
1.1825 ++
1.1826 ++ _M_data->_M_frac_digits = *(__nl_langinfo_l(__INT_FRAC_DIGITS,
1.1827 ++ __cloc));
1.1828 ++ char __pprecedes = *(__nl_langinfo_l(__INT_P_CS_PRECEDES, __cloc));
1.1829 ++ char __pspace = *(__nl_langinfo_l(__INT_P_SEP_BY_SPACE, __cloc));
1.1830 ++ char __pposn = *(__nl_langinfo_l(__INT_P_SIGN_POSN, __cloc));
1.1831 ++ _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace,
1.1832 ++ __pposn);
1.1833 ++ char __nprecedes = *(__nl_langinfo_l(__INT_N_CS_PRECEDES, __cloc));
1.1834 ++ char __nspace = *(__nl_langinfo_l(__INT_N_SEP_BY_SPACE, __cloc));
1.1835 ++ _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace,
1.1836 ++ __nposn);
1.1837 ++
1.1838 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1839 ++ __uselocale(__old);
1.1840 ++#else
1.1841 ++ setlocale(LC_ALL, __old);
1.1842 ++ free(__old);
1.1843 ++#endif
1.1844 ++ }
1.1845 ++ }
1.1846 ++
1.1847 ++ template<>
1.1848 ++ void
1.1849 ++ moneypunct<wchar_t, false>::_M_initialize_moneypunct(__c_locale __cloc,
1.1850 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1851 ++ const char*)
1.1852 ++#else
1.1853 ++ const char* __name)
1.1854 ++#endif
1.1855 ++ {
1.1856 ++ if (!_M_data)
1.1857 ++ _M_data = new __moneypunct_cache<wchar_t, false>;
1.1858 ++
1.1859 ++ if (!__cloc)
1.1860 ++ {
1.1861 ++ // "C" locale
1.1862 ++ _M_data->_M_decimal_point = L'.';
1.1863 ++ _M_data->_M_thousands_sep = L',';
1.1864 ++ _M_data->_M_grouping = "";
1.1865 ++ _M_data->_M_grouping_size = 0;
1.1866 ++ _M_data->_M_curr_symbol = L"";
1.1867 ++ _M_data->_M_curr_symbol_size = 0;
1.1868 ++ _M_data->_M_positive_sign = L"";
1.1869 ++ _M_data->_M_positive_sign_size = 0;
1.1870 ++ _M_data->_M_negative_sign = L"";
1.1871 ++ _M_data->_M_negative_sign_size = 0;
1.1872 ++ _M_data->_M_frac_digits = 0;
1.1873 ++ _M_data->_M_pos_format = money_base::_S_default_pattern;
1.1874 ++ _M_data->_M_neg_format = money_base::_S_default_pattern;
1.1875 ++
1.1876 ++ // Use ctype::widen code without the facet...
1.1877 ++ for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1.1878 ++ _M_data->_M_atoms[__i] =
1.1879 ++ static_cast<wchar_t>(money_base::_S_atoms[__i]);
1.1880 ++ }
1.1881 ++ else
1.1882 ++ {
1.1883 ++ // Named locale.
1.1884 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1885 ++ __c_locale __old = __uselocale(__cloc);
1.1886 ++#else
1.1887 ++ // Switch to named locale so that mbsrtowcs will work.
1.1888 ++ char* __old = strdup(setlocale(LC_ALL, NULL));
1.1889 ++ setlocale(LC_ALL, __name);
1.1890 ++#endif
1.1891 ++
1.1892 ++#ifdef __UCLIBC_MJN3_ONLY__
1.1893 ++#warning fix this... should be monetary
1.1894 ++#endif
1.1895 ++#ifdef __UCLIBC__
1.1896 ++# ifdef __UCLIBC_HAS_XLOCALE__
1.1897 ++ _M_data->_M_decimal_point = __cloc->decimal_point_wc;
1.1898 ++ _M_data->_M_thousands_sep = __cloc->thousands_sep_wc;
1.1899 ++# else
1.1900 ++ _M_data->_M_decimal_point = __global_locale->decimal_point_wc;
1.1901 ++ _M_data->_M_thousands_sep = __global_locale->thousands_sep_wc;
1.1902 ++# endif
1.1903 ++#else
1.1904 ++ union { char *__s; wchar_t __w; } __u;
1.1905 ++ __u.__s = __nl_langinfo_l(_NL_MONETARY_DECIMAL_POINT_WC, __cloc);
1.1906 ++ _M_data->_M_decimal_point = __u.__w;
1.1907 ++
1.1908 ++ __u.__s = __nl_langinfo_l(_NL_MONETARY_THOUSANDS_SEP_WC, __cloc);
1.1909 ++ _M_data->_M_thousands_sep = __u.__w;
1.1910 ++#endif
1.1911 ++ _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1.1912 ++ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1.1913 ++
1.1914 ++ const char* __cpossign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1.1915 ++ const char* __cnegsign = __nl_langinfo_l(__NEGATIVE_SIGN, __cloc);
1.1916 ++ const char* __ccurr = __nl_langinfo_l(__CURRENCY_SYMBOL, __cloc);
1.1917 ++
1.1918 ++ wchar_t* __wcs_ps = 0;
1.1919 ++ wchar_t* __wcs_ns = 0;
1.1920 ++ const char __nposn = *(__nl_langinfo_l(__N_SIGN_POSN, __cloc));
1.1921 ++ try
1.1922 ++ {
1.1923 ++ mbstate_t __state;
1.1924 ++ size_t __len;
1.1925 ++ __len = strlen(__cpossign);
1.1926 ++ if (__len)
1.1927 ++ {
1.1928 ++ ++__len;
1.1929 ++ memset(&__state, 0, sizeof(mbstate_t));
1.1930 ++ __wcs_ps = new wchar_t[__len];
1.1931 ++ mbsrtowcs(__wcs_ps, &__cpossign, __len, &__state);
1.1932 ++ _M_data->_M_positive_sign = __wcs_ps;
1.1933 ++ }
1.1934 ++ else
1.1935 ++ _M_data->_M_positive_sign = L"";
1.1936 ++ _M_data->_M_positive_sign_size = wcslen(_M_data->_M_positive_sign);
1.1937 ++
1.1938 ++ __len = strlen(__cnegsign);
1.1939 ++ if (!__nposn)
1.1940 ++ _M_data->_M_negative_sign = L"()";
1.1941 ++ else if (__len)
1.1942 ++ {
1.1943 ++ ++__len;
1.1944 ++ memset(&__state, 0, sizeof(mbstate_t));
1.1945 ++ __wcs_ns = new wchar_t[__len];
1.1946 ++ mbsrtowcs(__wcs_ns, &__cnegsign, __len, &__state);
1.1947 ++ _M_data->_M_negative_sign = __wcs_ns;
1.1948 ++ }
1.1949 ++ else
1.1950 ++ _M_data->_M_negative_sign = L"";
1.1951 ++ _M_data->_M_negative_sign_size = wcslen(_M_data->_M_negative_sign);
1.1952 ++
1.1953 ++ // _Intl == true.
1.1954 ++ __len = strlen(__ccurr);
1.1955 ++ if (__len)
1.1956 ++ {
1.1957 ++ ++__len;
1.1958 ++ memset(&__state, 0, sizeof(mbstate_t));
1.1959 ++ wchar_t* __wcs = new wchar_t[__len];
1.1960 ++ mbsrtowcs(__wcs, &__ccurr, __len, &__state);
1.1961 ++ _M_data->_M_curr_symbol = __wcs;
1.1962 ++ }
1.1963 ++ else
1.1964 ++ _M_data->_M_curr_symbol = L"";
1.1965 ++ _M_data->_M_curr_symbol_size = wcslen(_M_data->_M_curr_symbol);
1.1966 ++ }
1.1967 ++ catch (...)
1.1968 ++ {
1.1969 ++ delete _M_data;
1.1970 ++ _M_data = 0;
1.1971 ++ delete __wcs_ps;
1.1972 ++ delete __wcs_ns;
1.1973 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1974 ++ __uselocale(__old);
1.1975 ++#else
1.1976 ++ setlocale(LC_ALL, __old);
1.1977 ++ free(__old);
1.1978 ++#endif
1.1979 ++ __throw_exception_again;
1.1980 ++ }
1.1981 ++
1.1982 ++ _M_data->_M_frac_digits = *(__nl_langinfo_l(__FRAC_DIGITS, __cloc));
1.1983 ++ char __pprecedes = *(__nl_langinfo_l(__P_CS_PRECEDES, __cloc));
1.1984 ++ char __pspace = *(__nl_langinfo_l(__P_SEP_BY_SPACE, __cloc));
1.1985 ++ char __pposn = *(__nl_langinfo_l(__P_SIGN_POSN, __cloc));
1.1986 ++ _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace,
1.1987 ++ __pposn);
1.1988 ++ char __nprecedes = *(__nl_langinfo_l(__N_CS_PRECEDES, __cloc));
1.1989 ++ char __nspace = *(__nl_langinfo_l(__N_SEP_BY_SPACE, __cloc));
1.1990 ++ _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace,
1.1991 ++ __nposn);
1.1992 ++
1.1993 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.1994 ++ __uselocale(__old);
1.1995 ++#else
1.1996 ++ setlocale(LC_ALL, __old);
1.1997 ++ free(__old);
1.1998 ++#endif
1.1999 ++ }
1.2000 ++ }
1.2001 ++
1.2002 ++ template<>
1.2003 ++ moneypunct<wchar_t, true>::~moneypunct()
1.2004 ++ {
1.2005 ++ if (_M_data->_M_positive_sign_size)
1.2006 ++ delete [] _M_data->_M_positive_sign;
1.2007 ++ if (_M_data->_M_negative_sign_size
1.2008 ++ && wcscmp(_M_data->_M_negative_sign, L"()") != 0)
1.2009 ++ delete [] _M_data->_M_negative_sign;
1.2010 ++ if (_M_data->_M_curr_symbol_size)
1.2011 ++ delete [] _M_data->_M_curr_symbol;
1.2012 ++ delete _M_data;
1.2013 ++ }
1.2014 ++
1.2015 ++ template<>
1.2016 ++ moneypunct<wchar_t, false>::~moneypunct()
1.2017 ++ {
1.2018 ++ if (_M_data->_M_positive_sign_size)
1.2019 ++ delete [] _M_data->_M_positive_sign;
1.2020 ++ if (_M_data->_M_negative_sign_size
1.2021 ++ && wcscmp(_M_data->_M_negative_sign, L"()") != 0)
1.2022 ++ delete [] _M_data->_M_negative_sign;
1.2023 ++ if (_M_data->_M_curr_symbol_size)
1.2024 ++ delete [] _M_data->_M_curr_symbol;
1.2025 ++ delete _M_data;
1.2026 ++ }
1.2027 ++#endif
1.2028 ++}
1.2029 +--- gcc/libstdc++-v3/config/locale/uclibc/numeric_members.cc
1.2030 ++++ gcc/libstdc++-v3/config/locale/uclibc/numeric_members.cc
1.2031 +@@ -0,0 +1,160 @@
1.2032 ++// std::numpunct implementation details, GNU version -*- C++ -*-
1.2033 ++
1.2034 ++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.2035 ++//
1.2036 ++// This file is part of the GNU ISO C++ Library. This library is free
1.2037 ++// software; you can redistribute it and/or modify it under the
1.2038 ++// terms of the GNU General Public License as published by the
1.2039 ++// Free Software Foundation; either version 2, or (at your option)
1.2040 ++// any later version.
1.2041 ++
1.2042 ++// This library is distributed in the hope that it will be useful,
1.2043 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.2044 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.2045 ++// GNU General Public License for more details.
1.2046 ++
1.2047 ++// You should have received a copy of the GNU General Public License along
1.2048 ++// with this library; see the file COPYING. If not, write to the Free
1.2049 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.2050 ++// USA.
1.2051 ++
1.2052 ++// As a special exception, you may use this file as part of a free software
1.2053 ++// library without restriction. Specifically, if other files instantiate
1.2054 ++// templates or use macros or inline functions from this file, or you compile
1.2055 ++// this file and link it with other files to produce an executable, this
1.2056 ++// file does not by itself cause the resulting executable to be covered by
1.2057 ++// the GNU General Public License. This exception does not however
1.2058 ++// invalidate any other reasons why the executable file might be covered by
1.2059 ++// the GNU General Public License.
1.2060 ++
1.2061 ++//
1.2062 ++// ISO C++ 14882: 22.2.3.1.2 numpunct virtual functions
1.2063 ++//
1.2064 ++
1.2065 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.2066 ++
1.2067 ++#define _LIBC
1.2068 ++#include <locale>
1.2069 ++#undef _LIBC
1.2070 ++#include <bits/c++locale_internal.h>
1.2071 ++
1.2072 ++#ifdef __UCLIBC_MJN3_ONLY__
1.2073 ++#warning tailor for stub locale support
1.2074 ++#endif
1.2075 ++#ifndef __UCLIBC_HAS_XLOCALE__
1.2076 ++#define __nl_langinfo_l(N, L) nl_langinfo((N))
1.2077 ++#endif
1.2078 ++
1.2079 ++namespace std
1.2080 ++{
1.2081 ++ template<>
1.2082 ++ void
1.2083 ++ numpunct<char>::_M_initialize_numpunct(__c_locale __cloc)
1.2084 ++ {
1.2085 ++ if (!_M_data)
1.2086 ++ _M_data = new __numpunct_cache<char>;
1.2087 ++
1.2088 ++ if (!__cloc)
1.2089 ++ {
1.2090 ++ // "C" locale
1.2091 ++ _M_data->_M_grouping = "";
1.2092 ++ _M_data->_M_grouping_size = 0;
1.2093 ++ _M_data->_M_use_grouping = false;
1.2094 ++
1.2095 ++ _M_data->_M_decimal_point = '.';
1.2096 ++ _M_data->_M_thousands_sep = ',';
1.2097 ++
1.2098 ++ for (size_t __i = 0; __i < __num_base::_S_oend; ++__i)
1.2099 ++ _M_data->_M_atoms_out[__i] = __num_base::_S_atoms_out[__i];
1.2100 ++
1.2101 ++ for (size_t __j = 0; __j < __num_base::_S_iend; ++__j)
1.2102 ++ _M_data->_M_atoms_in[__j] = __num_base::_S_atoms_in[__j];
1.2103 ++ }
1.2104 ++ else
1.2105 ++ {
1.2106 ++ // Named locale.
1.2107 ++ _M_data->_M_decimal_point = *(__nl_langinfo_l(DECIMAL_POINT,
1.2108 ++ __cloc));
1.2109 ++ _M_data->_M_thousands_sep = *(__nl_langinfo_l(THOUSANDS_SEP,
1.2110 ++ __cloc));
1.2111 ++
1.2112 ++ // Check for NULL, which implies no grouping.
1.2113 ++ if (_M_data->_M_thousands_sep == '\0')
1.2114 ++ _M_data->_M_grouping = "";
1.2115 ++ else
1.2116 ++ _M_data->_M_grouping = __nl_langinfo_l(GROUPING, __cloc);
1.2117 ++ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1.2118 ++ }
1.2119 ++
1.2120 ++ // NB: There is no way to extact this info from posix locales.
1.2121 ++ // _M_truename = __nl_langinfo_l(YESSTR, __cloc);
1.2122 ++ _M_data->_M_truename = "true";
1.2123 ++ _M_data->_M_truename_size = 4;
1.2124 ++ // _M_falsename = __nl_langinfo_l(NOSTR, __cloc);
1.2125 ++ _M_data->_M_falsename = "false";
1.2126 ++ _M_data->_M_falsename_size = 5;
1.2127 ++ }
1.2128 ++
1.2129 ++ template<>
1.2130 ++ numpunct<char>::~numpunct()
1.2131 ++ { delete _M_data; }
1.2132 ++
1.2133 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.2134 ++ template<>
1.2135 ++ void
1.2136 ++ numpunct<wchar_t>::_M_initialize_numpunct(__c_locale __cloc)
1.2137 ++ {
1.2138 ++ if (!_M_data)
1.2139 ++ _M_data = new __numpunct_cache<wchar_t>;
1.2140 ++
1.2141 ++ if (!__cloc)
1.2142 ++ {
1.2143 ++ // "C" locale
1.2144 ++ _M_data->_M_grouping = "";
1.2145 ++ _M_data->_M_grouping_size = 0;
1.2146 ++ _M_data->_M_use_grouping = false;
1.2147 ++
1.2148 ++ _M_data->_M_decimal_point = L'.';
1.2149 ++ _M_data->_M_thousands_sep = L',';
1.2150 ++
1.2151 ++ // Use ctype::widen code without the facet...
1.2152 ++ for (size_t __i = 0; __i < __num_base::_S_oend; ++__i)
1.2153 ++ _M_data->_M_atoms_out[__i] =
1.2154 ++ static_cast<wchar_t>(__num_base::_S_atoms_out[__i]);
1.2155 ++
1.2156 ++ for (size_t __j = 0; __j < __num_base::_S_iend; ++__j)
1.2157 ++ _M_data->_M_atoms_in[__j] =
1.2158 ++ static_cast<wchar_t>(__num_base::_S_atoms_in[__j]);
1.2159 ++ }
1.2160 ++ else
1.2161 ++ {
1.2162 ++ // Named locale.
1.2163 ++ // NB: In the GNU model wchar_t is always 32 bit wide.
1.2164 ++ union { char *__s; wchar_t __w; } __u;
1.2165 ++ __u.__s = __nl_langinfo_l(_NL_NUMERIC_DECIMAL_POINT_WC, __cloc);
1.2166 ++ _M_data->_M_decimal_point = __u.__w;
1.2167 ++
1.2168 ++ __u.__s = __nl_langinfo_l(_NL_NUMERIC_THOUSANDS_SEP_WC, __cloc);
1.2169 ++ _M_data->_M_thousands_sep = __u.__w;
1.2170 ++
1.2171 ++ if (_M_data->_M_thousands_sep == L'\0')
1.2172 ++ _M_data->_M_grouping = "";
1.2173 ++ else
1.2174 ++ _M_data->_M_grouping = __nl_langinfo_l(GROUPING, __cloc);
1.2175 ++ _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1.2176 ++ }
1.2177 ++
1.2178 ++ // NB: There is no way to extact this info from posix locales.
1.2179 ++ // _M_truename = __nl_langinfo_l(YESSTR, __cloc);
1.2180 ++ _M_data->_M_truename = L"true";
1.2181 ++ _M_data->_M_truename_size = 4;
1.2182 ++ // _M_falsename = __nl_langinfo_l(NOSTR, __cloc);
1.2183 ++ _M_data->_M_falsename = L"false";
1.2184 ++ _M_data->_M_falsename_size = 5;
1.2185 ++ }
1.2186 ++
1.2187 ++ template<>
1.2188 ++ numpunct<wchar_t>::~numpunct()
1.2189 ++ { delete _M_data; }
1.2190 ++ #endif
1.2191 ++}
1.2192 +--- gcc/libstdc++-v3/config/locale/uclibc/time_members.cc
1.2193 ++++ gcc/libstdc++-v3/config/locale/uclibc/time_members.cc
1.2194 +@@ -0,0 +1,406 @@
1.2195 ++// std::time_get, std::time_put implementation, GNU version -*- C++ -*-
1.2196 ++
1.2197 ++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.2198 ++//
1.2199 ++// This file is part of the GNU ISO C++ Library. This library is free
1.2200 ++// software; you can redistribute it and/or modify it under the
1.2201 ++// terms of the GNU General Public License as published by the
1.2202 ++// Free Software Foundation; either version 2, or (at your option)
1.2203 ++// any later version.
1.2204 ++
1.2205 ++// This library is distributed in the hope that it will be useful,
1.2206 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.2207 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.2208 ++// GNU General Public License for more details.
1.2209 ++
1.2210 ++// You should have received a copy of the GNU General Public License along
1.2211 ++// with this library; see the file COPYING. If not, write to the Free
1.2212 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.2213 ++// USA.
1.2214 ++
1.2215 ++// As a special exception, you may use this file as part of a free software
1.2216 ++// library without restriction. Specifically, if other files instantiate
1.2217 ++// templates or use macros or inline functions from this file, or you compile
1.2218 ++// this file and link it with other files to produce an executable, this
1.2219 ++// file does not by itself cause the resulting executable to be covered by
1.2220 ++// the GNU General Public License. This exception does not however
1.2221 ++// invalidate any other reasons why the executable file might be covered by
1.2222 ++// the GNU General Public License.
1.2223 ++
1.2224 ++//
1.2225 ++// ISO C++ 14882: 22.2.5.1.2 - time_get virtual functions
1.2226 ++// ISO C++ 14882: 22.2.5.3.2 - time_put virtual functions
1.2227 ++//
1.2228 ++
1.2229 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.2230 ++
1.2231 ++#include <locale>
1.2232 ++#include <bits/c++locale_internal.h>
1.2233 ++
1.2234 ++#ifdef __UCLIBC_MJN3_ONLY__
1.2235 ++#warning tailor for stub locale support
1.2236 ++#endif
1.2237 ++#ifndef __UCLIBC_HAS_XLOCALE__
1.2238 ++#define __nl_langinfo_l(N, L) nl_langinfo((N))
1.2239 ++#endif
1.2240 ++
1.2241 ++namespace std
1.2242 ++{
1.2243 ++ template<>
1.2244 ++ void
1.2245 ++ __timepunct<char>::
1.2246 ++ _M_put(char* __s, size_t __maxlen, const char* __format,
1.2247 ++ const tm* __tm) const
1.2248 ++ {
1.2249 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.2250 ++ const size_t __len = __strftime_l(__s, __maxlen, __format, __tm,
1.2251 ++ _M_c_locale_timepunct);
1.2252 ++#else
1.2253 ++ char* __old = strdup(setlocale(LC_ALL, NULL));
1.2254 ++ setlocale(LC_ALL, _M_name_timepunct);
1.2255 ++ const size_t __len = strftime(__s, __maxlen, __format, __tm);
1.2256 ++ setlocale(LC_ALL, __old);
1.2257 ++ free(__old);
1.2258 ++#endif
1.2259 ++ // Make sure __s is null terminated.
1.2260 ++ if (__len == 0)
1.2261 ++ __s[0] = '\0';
1.2262 ++ }
1.2263 ++
1.2264 ++ template<>
1.2265 ++ void
1.2266 ++ __timepunct<char>::_M_initialize_timepunct(__c_locale __cloc)
1.2267 ++ {
1.2268 ++ if (!_M_data)
1.2269 ++ _M_data = new __timepunct_cache<char>;
1.2270 ++
1.2271 ++ if (!__cloc)
1.2272 ++ {
1.2273 ++ // "C" locale
1.2274 ++ _M_c_locale_timepunct = _S_get_c_locale();
1.2275 ++
1.2276 ++ _M_data->_M_date_format = "%m/%d/%y";
1.2277 ++ _M_data->_M_date_era_format = "%m/%d/%y";
1.2278 ++ _M_data->_M_time_format = "%H:%M:%S";
1.2279 ++ _M_data->_M_time_era_format = "%H:%M:%S";
1.2280 ++ _M_data->_M_date_time_format = "";
1.2281 ++ _M_data->_M_date_time_era_format = "";
1.2282 ++ _M_data->_M_am = "AM";
1.2283 ++ _M_data->_M_pm = "PM";
1.2284 ++ _M_data->_M_am_pm_format = "";
1.2285 ++
1.2286 ++ // Day names, starting with "C"'s Sunday.
1.2287 ++ _M_data->_M_day1 = "Sunday";
1.2288 ++ _M_data->_M_day2 = "Monday";
1.2289 ++ _M_data->_M_day3 = "Tuesday";
1.2290 ++ _M_data->_M_day4 = "Wednesday";
1.2291 ++ _M_data->_M_day5 = "Thursday";
1.2292 ++ _M_data->_M_day6 = "Friday";
1.2293 ++ _M_data->_M_day7 = "Saturday";
1.2294 ++
1.2295 ++ // Abbreviated day names, starting with "C"'s Sun.
1.2296 ++ _M_data->_M_aday1 = "Sun";
1.2297 ++ _M_data->_M_aday2 = "Mon";
1.2298 ++ _M_data->_M_aday3 = "Tue";
1.2299 ++ _M_data->_M_aday4 = "Wed";
1.2300 ++ _M_data->_M_aday5 = "Thu";
1.2301 ++ _M_data->_M_aday6 = "Fri";
1.2302 ++ _M_data->_M_aday7 = "Sat";
1.2303 ++
1.2304 ++ // Month names, starting with "C"'s January.
1.2305 ++ _M_data->_M_month01 = "January";
1.2306 ++ _M_data->_M_month02 = "February";
1.2307 ++ _M_data->_M_month03 = "March";
1.2308 ++ _M_data->_M_month04 = "April";
1.2309 ++ _M_data->_M_month05 = "May";
1.2310 ++ _M_data->_M_month06 = "June";
1.2311 ++ _M_data->_M_month07 = "July";
1.2312 ++ _M_data->_M_month08 = "August";
1.2313 ++ _M_data->_M_month09 = "September";
1.2314 ++ _M_data->_M_month10 = "October";
1.2315 ++ _M_data->_M_month11 = "November";
1.2316 ++ _M_data->_M_month12 = "December";
1.2317 ++
1.2318 ++ // Abbreviated month names, starting with "C"'s Jan.
1.2319 ++ _M_data->_M_amonth01 = "Jan";
1.2320 ++ _M_data->_M_amonth02 = "Feb";
1.2321 ++ _M_data->_M_amonth03 = "Mar";
1.2322 ++ _M_data->_M_amonth04 = "Apr";
1.2323 ++ _M_data->_M_amonth05 = "May";
1.2324 ++ _M_data->_M_amonth06 = "Jun";
1.2325 ++ _M_data->_M_amonth07 = "Jul";
1.2326 ++ _M_data->_M_amonth08 = "Aug";
1.2327 ++ _M_data->_M_amonth09 = "Sep";
1.2328 ++ _M_data->_M_amonth10 = "Oct";
1.2329 ++ _M_data->_M_amonth11 = "Nov";
1.2330 ++ _M_data->_M_amonth12 = "Dec";
1.2331 ++ }
1.2332 ++ else
1.2333 ++ {
1.2334 ++ _M_c_locale_timepunct = _S_clone_c_locale(__cloc);
1.2335 ++
1.2336 ++ _M_data->_M_date_format = __nl_langinfo_l(D_FMT, __cloc);
1.2337 ++ _M_data->_M_date_era_format = __nl_langinfo_l(ERA_D_FMT, __cloc);
1.2338 ++ _M_data->_M_time_format = __nl_langinfo_l(T_FMT, __cloc);
1.2339 ++ _M_data->_M_time_era_format = __nl_langinfo_l(ERA_T_FMT, __cloc);
1.2340 ++ _M_data->_M_date_time_format = __nl_langinfo_l(D_T_FMT, __cloc);
1.2341 ++ _M_data->_M_date_time_era_format = __nl_langinfo_l(ERA_D_T_FMT,
1.2342 ++ __cloc);
1.2343 ++ _M_data->_M_am = __nl_langinfo_l(AM_STR, __cloc);
1.2344 ++ _M_data->_M_pm = __nl_langinfo_l(PM_STR, __cloc);
1.2345 ++ _M_data->_M_am_pm_format = __nl_langinfo_l(T_FMT_AMPM, __cloc);
1.2346 ++
1.2347 ++ // Day names, starting with "C"'s Sunday.
1.2348 ++ _M_data->_M_day1 = __nl_langinfo_l(DAY_1, __cloc);
1.2349 ++ _M_data->_M_day2 = __nl_langinfo_l(DAY_2, __cloc);
1.2350 ++ _M_data->_M_day3 = __nl_langinfo_l(DAY_3, __cloc);
1.2351 ++ _M_data->_M_day4 = __nl_langinfo_l(DAY_4, __cloc);
1.2352 ++ _M_data->_M_day5 = __nl_langinfo_l(DAY_5, __cloc);
1.2353 ++ _M_data->_M_day6 = __nl_langinfo_l(DAY_6, __cloc);
1.2354 ++ _M_data->_M_day7 = __nl_langinfo_l(DAY_7, __cloc);
1.2355 ++
1.2356 ++ // Abbreviated day names, starting with "C"'s Sun.
1.2357 ++ _M_data->_M_aday1 = __nl_langinfo_l(ABDAY_1, __cloc);
1.2358 ++ _M_data->_M_aday2 = __nl_langinfo_l(ABDAY_2, __cloc);
1.2359 ++ _M_data->_M_aday3 = __nl_langinfo_l(ABDAY_3, __cloc);
1.2360 ++ _M_data->_M_aday4 = __nl_langinfo_l(ABDAY_4, __cloc);
1.2361 ++ _M_data->_M_aday5 = __nl_langinfo_l(ABDAY_5, __cloc);
1.2362 ++ _M_data->_M_aday6 = __nl_langinfo_l(ABDAY_6, __cloc);
1.2363 ++ _M_data->_M_aday7 = __nl_langinfo_l(ABDAY_7, __cloc);
1.2364 ++
1.2365 ++ // Month names, starting with "C"'s January.
1.2366 ++ _M_data->_M_month01 = __nl_langinfo_l(MON_1, __cloc);
1.2367 ++ _M_data->_M_month02 = __nl_langinfo_l(MON_2, __cloc);
1.2368 ++ _M_data->_M_month03 = __nl_langinfo_l(MON_3, __cloc);
1.2369 ++ _M_data->_M_month04 = __nl_langinfo_l(MON_4, __cloc);
1.2370 ++ _M_data->_M_month05 = __nl_langinfo_l(MON_5, __cloc);
1.2371 ++ _M_data->_M_month06 = __nl_langinfo_l(MON_6, __cloc);
1.2372 ++ _M_data->_M_month07 = __nl_langinfo_l(MON_7, __cloc);
1.2373 ++ _M_data->_M_month08 = __nl_langinfo_l(MON_8, __cloc);
1.2374 ++ _M_data->_M_month09 = __nl_langinfo_l(MON_9, __cloc);
1.2375 ++ _M_data->_M_month10 = __nl_langinfo_l(MON_10, __cloc);
1.2376 ++ _M_data->_M_month11 = __nl_langinfo_l(MON_11, __cloc);
1.2377 ++ _M_data->_M_month12 = __nl_langinfo_l(MON_12, __cloc);
1.2378 ++
1.2379 ++ // Abbreviated month names, starting with "C"'s Jan.
1.2380 ++ _M_data->_M_amonth01 = __nl_langinfo_l(ABMON_1, __cloc);
1.2381 ++ _M_data->_M_amonth02 = __nl_langinfo_l(ABMON_2, __cloc);
1.2382 ++ _M_data->_M_amonth03 = __nl_langinfo_l(ABMON_3, __cloc);
1.2383 ++ _M_data->_M_amonth04 = __nl_langinfo_l(ABMON_4, __cloc);
1.2384 ++ _M_data->_M_amonth05 = __nl_langinfo_l(ABMON_5, __cloc);
1.2385 ++ _M_data->_M_amonth06 = __nl_langinfo_l(ABMON_6, __cloc);
1.2386 ++ _M_data->_M_amonth07 = __nl_langinfo_l(ABMON_7, __cloc);
1.2387 ++ _M_data->_M_amonth08 = __nl_langinfo_l(ABMON_8, __cloc);
1.2388 ++ _M_data->_M_amonth09 = __nl_langinfo_l(ABMON_9, __cloc);
1.2389 ++ _M_data->_M_amonth10 = __nl_langinfo_l(ABMON_10, __cloc);
1.2390 ++ _M_data->_M_amonth11 = __nl_langinfo_l(ABMON_11, __cloc);
1.2391 ++ _M_data->_M_amonth12 = __nl_langinfo_l(ABMON_12, __cloc);
1.2392 ++ }
1.2393 ++ }
1.2394 ++
1.2395 ++#ifdef _GLIBCXX_USE_WCHAR_T
1.2396 ++ template<>
1.2397 ++ void
1.2398 ++ __timepunct<wchar_t>::
1.2399 ++ _M_put(wchar_t* __s, size_t __maxlen, const wchar_t* __format,
1.2400 ++ const tm* __tm) const
1.2401 ++ {
1.2402 ++#ifdef __UCLIBC_HAS_XLOCALE__
1.2403 ++ __wcsftime_l(__s, __maxlen, __format, __tm, _M_c_locale_timepunct);
1.2404 ++ const size_t __len = __wcsftime_l(__s, __maxlen, __format, __tm,
1.2405 ++ _M_c_locale_timepunct);
1.2406 ++#else
1.2407 ++ char* __old = strdup(setlocale(LC_ALL, NULL));
1.2408 ++ setlocale(LC_ALL, _M_name_timepunct);
1.2409 ++ const size_t __len = wcsftime(__s, __maxlen, __format, __tm);
1.2410 ++ setlocale(LC_ALL, __old);
1.2411 ++ free(__old);
1.2412 ++#endif
1.2413 ++ // Make sure __s is null terminated.
1.2414 ++ if (__len == 0)
1.2415 ++ __s[0] = L'\0';
1.2416 ++ }
1.2417 ++
1.2418 ++ template<>
1.2419 ++ void
1.2420 ++ __timepunct<wchar_t>::_M_initialize_timepunct(__c_locale __cloc)
1.2421 ++ {
1.2422 ++ if (!_M_data)
1.2423 ++ _M_data = new __timepunct_cache<wchar_t>;
1.2424 ++
1.2425 ++#warning wide time stuff
1.2426 ++// if (!__cloc)
1.2427 ++ {
1.2428 ++ // "C" locale
1.2429 ++ _M_c_locale_timepunct = _S_get_c_locale();
1.2430 ++
1.2431 ++ _M_data->_M_date_format = L"%m/%d/%y";
1.2432 ++ _M_data->_M_date_era_format = L"%m/%d/%y";
1.2433 ++ _M_data->_M_time_format = L"%H:%M:%S";
1.2434 ++ _M_data->_M_time_era_format = L"%H:%M:%S";
1.2435 ++ _M_data->_M_date_time_format = L"";
1.2436 ++ _M_data->_M_date_time_era_format = L"";
1.2437 ++ _M_data->_M_am = L"AM";
1.2438 ++ _M_data->_M_pm = L"PM";
1.2439 ++ _M_data->_M_am_pm_format = L"";
1.2440 ++
1.2441 ++ // Day names, starting with "C"'s Sunday.
1.2442 ++ _M_data->_M_day1 = L"Sunday";
1.2443 ++ _M_data->_M_day2 = L"Monday";
1.2444 ++ _M_data->_M_day3 = L"Tuesday";
1.2445 ++ _M_data->_M_day4 = L"Wednesday";
1.2446 ++ _M_data->_M_day5 = L"Thursday";
1.2447 ++ _M_data->_M_day6 = L"Friday";
1.2448 ++ _M_data->_M_day7 = L"Saturday";
1.2449 ++
1.2450 ++ // Abbreviated day names, starting with "C"'s Sun.
1.2451 ++ _M_data->_M_aday1 = L"Sun";
1.2452 ++ _M_data->_M_aday2 = L"Mon";
1.2453 ++ _M_data->_M_aday3 = L"Tue";
1.2454 ++ _M_data->_M_aday4 = L"Wed";
1.2455 ++ _M_data->_M_aday5 = L"Thu";
1.2456 ++ _M_data->_M_aday6 = L"Fri";
1.2457 ++ _M_data->_M_aday7 = L"Sat";
1.2458 ++
1.2459 ++ // Month names, starting with "C"'s January.
1.2460 ++ _M_data->_M_month01 = L"January";
1.2461 ++ _M_data->_M_month02 = L"February";
1.2462 ++ _M_data->_M_month03 = L"March";
1.2463 ++ _M_data->_M_month04 = L"April";
1.2464 ++ _M_data->_M_month05 = L"May";
1.2465 ++ _M_data->_M_month06 = L"June";
1.2466 ++ _M_data->_M_month07 = L"July";
1.2467 ++ _M_data->_M_month08 = L"August";
1.2468 ++ _M_data->_M_month09 = L"September";
1.2469 ++ _M_data->_M_month10 = L"October";
1.2470 ++ _M_data->_M_month11 = L"November";
1.2471 ++ _M_data->_M_month12 = L"December";
1.2472 ++
1.2473 ++ // Abbreviated month names, starting with "C"'s Jan.
1.2474 ++ _M_data->_M_amonth01 = L"Jan";
1.2475 ++ _M_data->_M_amonth02 = L"Feb";
1.2476 ++ _M_data->_M_amonth03 = L"Mar";
1.2477 ++ _M_data->_M_amonth04 = L"Apr";
1.2478 ++ _M_data->_M_amonth05 = L"May";
1.2479 ++ _M_data->_M_amonth06 = L"Jun";
1.2480 ++ _M_data->_M_amonth07 = L"Jul";
1.2481 ++ _M_data->_M_amonth08 = L"Aug";
1.2482 ++ _M_data->_M_amonth09 = L"Sep";
1.2483 ++ _M_data->_M_amonth10 = L"Oct";
1.2484 ++ _M_data->_M_amonth11 = L"Nov";
1.2485 ++ _M_data->_M_amonth12 = L"Dec";
1.2486 ++ }
1.2487 ++#if 0
1.2488 ++ else
1.2489 ++ {
1.2490 ++ _M_c_locale_timepunct = _S_clone_c_locale(__cloc);
1.2491 ++
1.2492 ++ union { char *__s; wchar_t *__w; } __u;
1.2493 ++
1.2494 ++ __u.__s = __nl_langinfo_l(_NL_WD_FMT, __cloc);
1.2495 ++ _M_data->_M_date_format = __u.__w;
1.2496 ++ __u.__s = __nl_langinfo_l(_NL_WERA_D_FMT, __cloc);
1.2497 ++ _M_data->_M_date_era_format = __u.__w;
1.2498 ++ __u.__s = __nl_langinfo_l(_NL_WT_FMT, __cloc);
1.2499 ++ _M_data->_M_time_format = __u.__w;
1.2500 ++ __u.__s = __nl_langinfo_l(_NL_WERA_T_FMT, __cloc);
1.2501 ++ _M_data->_M_time_era_format = __u.__w;
1.2502 ++ __u.__s = __nl_langinfo_l(_NL_WD_T_FMT, __cloc);
1.2503 ++ _M_data->_M_date_time_format = __u.__w;
1.2504 ++ __u.__s = __nl_langinfo_l(_NL_WERA_D_T_FMT, __cloc);
1.2505 ++ _M_data->_M_date_time_era_format = __u.__w;
1.2506 ++ __u.__s = __nl_langinfo_l(_NL_WAM_STR, __cloc);
1.2507 ++ _M_data->_M_am = __u.__w;
1.2508 ++ __u.__s = __nl_langinfo_l(_NL_WPM_STR, __cloc);
1.2509 ++ _M_data->_M_pm = __u.__w;
1.2510 ++ __u.__s = __nl_langinfo_l(_NL_WT_FMT_AMPM, __cloc);
1.2511 ++ _M_data->_M_am_pm_format = __u.__w;
1.2512 ++
1.2513 ++ // Day names, starting with "C"'s Sunday.
1.2514 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_1, __cloc);
1.2515 ++ _M_data->_M_day1 = __u.__w;
1.2516 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_2, __cloc);
1.2517 ++ _M_data->_M_day2 = __u.__w;
1.2518 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_3, __cloc);
1.2519 ++ _M_data->_M_day3 = __u.__w;
1.2520 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_4, __cloc);
1.2521 ++ _M_data->_M_day4 = __u.__w;
1.2522 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_5, __cloc);
1.2523 ++ _M_data->_M_day5 = __u.__w;
1.2524 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_6, __cloc);
1.2525 ++ _M_data->_M_day6 = __u.__w;
1.2526 ++ __u.__s = __nl_langinfo_l(_NL_WDAY_7, __cloc);
1.2527 ++ _M_data->_M_day7 = __u.__w;
1.2528 ++
1.2529 ++ // Abbreviated day names, starting with "C"'s Sun.
1.2530 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_1, __cloc);
1.2531 ++ _M_data->_M_aday1 = __u.__w;
1.2532 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_2, __cloc);
1.2533 ++ _M_data->_M_aday2 = __u.__w;
1.2534 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_3, __cloc);
1.2535 ++ _M_data->_M_aday3 = __u.__w;
1.2536 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_4, __cloc);
1.2537 ++ _M_data->_M_aday4 = __u.__w;
1.2538 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_5, __cloc);
1.2539 ++ _M_data->_M_aday5 = __u.__w;
1.2540 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_6, __cloc);
1.2541 ++ _M_data->_M_aday6 = __u.__w;
1.2542 ++ __u.__s = __nl_langinfo_l(_NL_WABDAY_7, __cloc);
1.2543 ++ _M_data->_M_aday7 = __u.__w;
1.2544 ++
1.2545 ++ // Month names, starting with "C"'s January.
1.2546 ++ __u.__s = __nl_langinfo_l(_NL_WMON_1, __cloc);
1.2547 ++ _M_data->_M_month01 = __u.__w;
1.2548 ++ __u.__s = __nl_langinfo_l(_NL_WMON_2, __cloc);
1.2549 ++ _M_data->_M_month02 = __u.__w;
1.2550 ++ __u.__s = __nl_langinfo_l(_NL_WMON_3, __cloc);
1.2551 ++ _M_data->_M_month03 = __u.__w;
1.2552 ++ __u.__s = __nl_langinfo_l(_NL_WMON_4, __cloc);
1.2553 ++ _M_data->_M_month04 = __u.__w;
1.2554 ++ __u.__s = __nl_langinfo_l(_NL_WMON_5, __cloc);
1.2555 ++ _M_data->_M_month05 = __u.__w;
1.2556 ++ __u.__s = __nl_langinfo_l(_NL_WMON_6, __cloc);
1.2557 ++ _M_data->_M_month06 = __u.__w;
1.2558 ++ __u.__s = __nl_langinfo_l(_NL_WMON_7, __cloc);
1.2559 ++ _M_data->_M_month07 = __u.__w;
1.2560 ++ __u.__s = __nl_langinfo_l(_NL_WMON_8, __cloc);
1.2561 ++ _M_data->_M_month08 = __u.__w;
1.2562 ++ __u.__s = __nl_langinfo_l(_NL_WMON_9, __cloc);
1.2563 ++ _M_data->_M_month09 = __u.__w;
1.2564 ++ __u.__s = __nl_langinfo_l(_NL_WMON_10, __cloc);
1.2565 ++ _M_data->_M_month10 = __u.__w;
1.2566 ++ __u.__s = __nl_langinfo_l(_NL_WMON_11, __cloc);
1.2567 ++ _M_data->_M_month11 = __u.__w;
1.2568 ++ __u.__s = __nl_langinfo_l(_NL_WMON_12, __cloc);
1.2569 ++ _M_data->_M_month12 = __u.__w;
1.2570 ++
1.2571 ++ // Abbreviated month names, starting with "C"'s Jan.
1.2572 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_1, __cloc);
1.2573 ++ _M_data->_M_amonth01 = __u.__w;
1.2574 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_2, __cloc);
1.2575 ++ _M_data->_M_amonth02 = __u.__w;
1.2576 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_3, __cloc);
1.2577 ++ _M_data->_M_amonth03 = __u.__w;
1.2578 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_4, __cloc);
1.2579 ++ _M_data->_M_amonth04 = __u.__w;
1.2580 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_5, __cloc);
1.2581 ++ _M_data->_M_amonth05 = __u.__w;
1.2582 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_6, __cloc);
1.2583 ++ _M_data->_M_amonth06 = __u.__w;
1.2584 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_7, __cloc);
1.2585 ++ _M_data->_M_amonth07 = __u.__w;
1.2586 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_8, __cloc);
1.2587 ++ _M_data->_M_amonth08 = __u.__w;
1.2588 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_9, __cloc);
1.2589 ++ _M_data->_M_amonth09 = __u.__w;
1.2590 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_10, __cloc);
1.2591 ++ _M_data->_M_amonth10 = __u.__w;
1.2592 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_11, __cloc);
1.2593 ++ _M_data->_M_amonth11 = __u.__w;
1.2594 ++ __u.__s = __nl_langinfo_l(_NL_WABMON_12, __cloc);
1.2595 ++ _M_data->_M_amonth12 = __u.__w;
1.2596 ++ }
1.2597 ++#endif // 0
1.2598 ++ }
1.2599 ++#endif
1.2600 ++}
1.2601 +--- gcc/libstdc++-v3/config/locale/uclibc/time_members.h
1.2602 ++++ gcc/libstdc++-v3/config/locale/uclibc/time_members.h
1.2603 +@@ -0,0 +1,68 @@
1.2604 ++// std::time_get, std::time_put implementation, GNU version -*- C++ -*-
1.2605 ++
1.2606 ++// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1.2607 ++//
1.2608 ++// This file is part of the GNU ISO C++ Library. This library is free
1.2609 ++// software; you can redistribute it and/or modify it under the
1.2610 ++// terms of the GNU General Public License as published by the
1.2611 ++// Free Software Foundation; either version 2, or (at your option)
1.2612 ++// any later version.
1.2613 ++
1.2614 ++// This library is distributed in the hope that it will be useful,
1.2615 ++// but WITHOUT ANY WARRANTY; without even the implied warranty of
1.2616 ++// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1.2617 ++// GNU General Public License for more details.
1.2618 ++
1.2619 ++// You should have received a copy of the GNU General Public License along
1.2620 ++// with this library; see the file COPYING. If not, write to the Free
1.2621 ++// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
1.2622 ++// USA.
1.2623 ++
1.2624 ++// As a special exception, you may use this file as part of a free software
1.2625 ++// library without restriction. Specifically, if other files instantiate
1.2626 ++// templates or use macros or inline functions from this file, or you compile
1.2627 ++// this file and link it with other files to produce an executable, this
1.2628 ++// file does not by itself cause the resulting executable to be covered by
1.2629 ++// the GNU General Public License. This exception does not however
1.2630 ++// invalidate any other reasons why the executable file might be covered by
1.2631 ++// the GNU General Public License.
1.2632 ++
1.2633 ++//
1.2634 ++// ISO C++ 14882: 22.2.5.1.2 - time_get functions
1.2635 ++// ISO C++ 14882: 22.2.5.3.2 - time_put functions
1.2636 ++//
1.2637 ++
1.2638 ++// Written by Benjamin Kosnik <bkoz@redhat.com>
1.2639 ++
1.2640 ++ template<typename _CharT>
1.2641 ++ __timepunct<_CharT>::__timepunct(size_t __refs)
1.2642 ++ : facet(__refs), _M_data(NULL), _M_c_locale_timepunct(NULL),
1.2643 ++ _M_name_timepunct(_S_get_c_name())
1.2644 ++ { _M_initialize_timepunct(); }
1.2645 ++
1.2646 ++ template<typename _CharT>
1.2647 ++ __timepunct<_CharT>::__timepunct(__cache_type* __cache, size_t __refs)
1.2648 ++ : facet(__refs), _M_data(__cache), _M_c_locale_timepunct(NULL),
1.2649 ++ _M_name_timepunct(_S_get_c_name())
1.2650 ++ { _M_initialize_timepunct(); }
1.2651 ++
1.2652 ++ template<typename _CharT>
1.2653 ++ __timepunct<_CharT>::__timepunct(__c_locale __cloc, const char* __s,
1.2654 ++ size_t __refs)
1.2655 ++ : facet(__refs), _M_data(NULL), _M_c_locale_timepunct(NULL),
1.2656 ++ _M_name_timepunct(__s)
1.2657 ++ {
1.2658 ++ char* __tmp = new char[std::strlen(__s) + 1];
1.2659 ++ std::strcpy(__tmp, __s);
1.2660 ++ _M_name_timepunct = __tmp;
1.2661 ++ _M_initialize_timepunct(__cloc);
1.2662 ++ }
1.2663 ++
1.2664 ++ template<typename _CharT>
1.2665 ++ __timepunct<_CharT>::~__timepunct()
1.2666 ++ {
1.2667 ++ if (_M_name_timepunct != _S_get_c_name())
1.2668 ++ delete [] _M_name_timepunct;
1.2669 ++ delete _M_data;
1.2670 ++ _S_destroy_c_locale(_M_c_locale_timepunct);
1.2671 ++ }
1.2672 +--- gcc/libstdc++-v3/configure
1.2673 ++++ gcc/libstdc++-v3/configure
1.2674 +@@ -5764,7 +5764,7 @@
1.2675 + enableval="$enable_clocale"
1.2676 +
1.2677 + case "$enableval" in
1.2678 +- generic|gnu|ieee_1003.1-2001|yes|no|auto) ;;
1.2679 ++ generic|gnu|ieee_1003.1-2001|uclibc|yes|no|auto) ;;
1.2680 + *) { { echo "$as_me:$LINENO: error: Unknown argument to enable/disable clocale" >&5
1.2681 + echo "$as_me: error: Unknown argument to enable/disable clocale" >&2;}
1.2682 + { (exit 1); exit 1; }; } ;;
1.2683 +@@ -5789,6 +5789,9 @@
1.2684 + # Default to "generic".
1.2685 + if test $enable_clocale_flag = auto; then
1.2686 + case ${target_os} in
1.2687 ++ linux-uclibc*)
1.2688 ++ enable_clocale_flag=uclibc
1.2689 ++ ;;
1.2690 + linux* | gnu* | kfreebsd*-gnu | knetbsd*-gnu)
1.2691 + cat >conftest.$ac_ext <<_ACEOF
1.2692 + /* confdefs.h. */
1.2693 +@@ -6019,6 +6022,76 @@
1.2694 + CTIME_CC=config/locale/generic/time_members.cc
1.2695 + CLOCALE_INTERNAL_H=config/locale/generic/c++locale_internal.h
1.2696 + ;;
1.2697 ++ uclibc)
1.2698 ++ echo "$as_me:$LINENO: result: uclibc" >&5
1.2699 ++echo "${ECHO_T}uclibc" >&6
1.2700 ++
1.2701 ++ # Declare intention to use gettext, and add support for specific
1.2702 ++ # languages.
1.2703 ++ # For some reason, ALL_LINGUAS has to be before AM-GNU-GETTEXT
1.2704 ++ ALL_LINGUAS="de fr"
1.2705 ++
1.2706 ++ # Don't call AM-GNU-GETTEXT here. Instead, assume glibc.
1.2707 ++ # Extract the first word of "msgfmt", so it can be a program name with args.
1.2708 ++set dummy msgfmt; ac_word=$2
1.2709 ++echo "$as_me:$LINENO: checking for $ac_word" >&5
1.2710 ++echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
1.2711 ++if test "${ac_cv_prog_check_msgfmt+set}" = set; then
1.2712 ++ echo $ECHO_N "(cached) $ECHO_C" >&6
1.2713 ++else
1.2714 ++ if test -n "$check_msgfmt"; then
1.2715 ++ ac_cv_prog_check_msgfmt="$check_msgfmt" # Let the user override the test.
1.2716 ++else
1.2717 ++as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
1.2718 ++for as_dir in $PATH
1.2719 ++do
1.2720 ++ IFS=$as_save_IFS
1.2721 ++ test -z "$as_dir" && as_dir=.
1.2722 ++ for ac_exec_ext in '' $ac_executable_extensions; do
1.2723 ++ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
1.2724 ++ ac_cv_prog_check_msgfmt="yes"
1.2725 ++ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
1.2726 ++ break 2
1.2727 ++ fi
1.2728 ++done
1.2729 ++done
1.2730 ++
1.2731 ++ test -z "$ac_cv_prog_check_msgfmt" && ac_cv_prog_check_msgfmt="no"
1.2732 ++fi
1.2733 ++fi
1.2734 ++check_msgfmt=$ac_cv_prog_check_msgfmt
1.2735 ++if test -n "$check_msgfmt"; then
1.2736 ++ echo "$as_me:$LINENO: result: $check_msgfmt" >&5
1.2737 ++echo "${ECHO_T}$check_msgfmt" >&6
1.2738 ++else
1.2739 ++ echo "$as_me:$LINENO: result: no" >&5
1.2740 ++echo "${ECHO_T}no" >&6
1.2741 ++fi
1.2742 ++
1.2743 ++ if test x"$check_msgfmt" = x"yes" && test x"$enable_nls" = x"yes"; then
1.2744 ++ USE_NLS=yes
1.2745 ++ fi
1.2746 ++ # Export the build objects.
1.2747 ++ for ling in $ALL_LINGUAS; do \
1.2748 ++ glibcxx_MOFILES="$glibcxx_MOFILES $ling.mo"; \
1.2749 ++ glibcxx_POFILES="$glibcxx_POFILES $ling.po"; \
1.2750 ++ done
1.2751 ++
1.2752 ++
1.2753 ++
1.2754 ++ CLOCALE_H=config/locale/uclibc/c_locale.h
1.2755 ++ CLOCALE_CC=config/locale/uclibc/c_locale.cc
1.2756 ++ CCODECVT_CC=config/locale/uclibc/codecvt_members.cc
1.2757 ++ CCOLLATE_CC=config/locale/uclibc/collate_members.cc
1.2758 ++ CCTYPE_CC=config/locale/uclibc/ctype_members.cc
1.2759 ++ CMESSAGES_H=config/locale/uclibc/messages_members.h
1.2760 ++ CMESSAGES_CC=config/locale/uclibc/messages_members.cc
1.2761 ++ CMONEY_CC=config/locale/uclibc/monetary_members.cc
1.2762 ++ CNUMERIC_CC=config/locale/uclibc/numeric_members.cc
1.2763 ++ CTIME_H=config/locale/uclibc/time_members.h
1.2764 ++ CTIME_CC=config/locale/uclibc/time_members.cc
1.2765 ++ CLOCALE_INTERNAL_H=config/locale/uclibc/c++locale_internal.h
1.2766 ++ ;;
1.2767 + esac
1.2768 +
1.2769 + # This is where the testsuite looks for locale catalogs, using the
1.2770 +--- gcc/libstdc++-v3/include/c_compatibility/wchar.h
1.2771 ++++ gcc/libstdc++-v3/include/c_compatibility/wchar.h
1.2772 +@@ -101,7 +101,9 @@
1.2773 + using std::wmemcpy;
1.2774 + using std::wmemmove;
1.2775 + using std::wmemset;
1.2776 ++#if _GLIBCXX_HAVE_WCSFTIME
1.2777 + using std::wcsftime;
1.2778 ++#endif
1.2779 +
1.2780 + #if _GLIBCXX_USE_C99
1.2781 + using std::wcstold;
1.2782 +--- gcc/libstdc++-v3/include/c_std/std_cwchar.h
1.2783 ++++ gcc/libstdc++-v3/include/c_std/std_cwchar.h
1.2784 +@@ -182,7 +182,9 @@
1.2785 + using ::wcscoll;
1.2786 + using ::wcscpy;
1.2787 + using ::wcscspn;
1.2788 ++#if _GLIBCXX_HAVE_WCSFTIME
1.2789 + using ::wcsftime;
1.2790 ++#endif
1.2791 + using ::wcslen;
1.2792 + using ::wcsncat;
1.2793 + using ::wcsncmp;