massive cleanup of toolchain/
[openwrt.git] / toolchain / gcc / patches / 4.1.1 / 200-uclibc-locale.patch
1 diff -urN gcc-4.1.0-dist/libstdc++-v3/acinclude.m4 gcc-4.1.0/libstdc++-v3/acinclude.m4
2 --- gcc-4.1.0-dist/libstdc++-v3/acinclude.m4    2006-03-26 12:08:28.000000000 -0700
3 +++ gcc-4.1.0/libstdc++-v3/acinclude.m4 2006-03-25 22:06:30.000000000 -0700
4 @@ -1071,7 +1071,7 @@
5    AC_MSG_CHECKING([for C locale to use])
6    GLIBCXX_ENABLE(clocale,auto,[@<:@=MODEL@:>@],
7      [use MODEL for target locale package],
8 -    [permit generic|gnu|ieee_1003.1-2001|yes|no|auto])
9 +    [permit generic|gnu|ieee_1003.1-2001|uclibc|yes|no|auto])
10    
11    # If they didn't use this option switch, or if they specified --enable
12    # with no specific model, we'll have to look for one.  If they
13 @@ -1087,6 +1087,9 @@
14    # Default to "generic".
15    if test $enable_clocale_flag = auto; then
16      case ${target_os} in
17 +      *-uclibc*)
18 +        enable_clocale_flag=uclibc
19 +        ;;
20        linux* | gnu* | kfreebsd*-gnu | knetbsd*-gnu)
21          AC_EGREP_CPP([_GLIBCXX_ok], [
22          #include <features.h>
23 @@ -1230,6 +1233,40 @@
24        CTIME_CC=config/locale/generic/time_members.cc
25        CLOCALE_INTERNAL_H=config/locale/generic/c++locale_internal.h
26        ;;
27 +    uclibc)
28 +      AC_MSG_RESULT(uclibc)
29 +
30 +      # Declare intention to use gettext, and add support for specific
31 +      # languages.
32 +      # For some reason, ALL_LINGUAS has to be before AM-GNU-GETTEXT
33 +      ALL_LINGUAS="de fr"
34 +
35 +      # Don't call AM-GNU-GETTEXT here. Instead, assume glibc.
36 +      AC_CHECK_PROG(check_msgfmt, msgfmt, yes, no)
37 +      if test x"$check_msgfmt" = x"yes" && test x"$enable_nls" = x"yes"; then
38 +        USE_NLS=yes
39 +      fi
40 +      # Export the build objects.
41 +      for ling in $ALL_LINGUAS; do \
42 +        glibcxx_MOFILES="$glibcxx_MOFILES $ling.mo"; \
43 +        glibcxx_POFILES="$glibcxx_POFILES $ling.po"; \
44 +      done
45 +      AC_SUBST(glibcxx_MOFILES)
46 +      AC_SUBST(glibcxx_POFILES)
47 +
48 +      CLOCALE_H=config/locale/uclibc/c_locale.h
49 +      CLOCALE_CC=config/locale/uclibc/c_locale.cc
50 +      CCODECVT_CC=config/locale/uclibc/codecvt_members.cc
51 +      CCOLLATE_CC=config/locale/uclibc/collate_members.cc
52 +      CCTYPE_CC=config/locale/uclibc/ctype_members.cc
53 +      CMESSAGES_H=config/locale/uclibc/messages_members.h
54 +      CMESSAGES_CC=config/locale/uclibc/messages_members.cc
55 +      CMONEY_CC=config/locale/uclibc/monetary_members.cc
56 +      CNUMERIC_CC=config/locale/uclibc/numeric_members.cc
57 +      CTIME_H=config/locale/uclibc/time_members.h
58 +      CTIME_CC=config/locale/uclibc/time_members.cc
59 +      CLOCALE_INTERNAL_H=config/locale/uclibc/c++locale_internal.h
60 +      ;;
61    esac
62  
63    # This is where the testsuite looks for locale catalogs, using the
64 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/c++locale_internal.h gcc-4.1.0/libstdc++-v3/config/locale/uclibc/c++locale_internal.h
65 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/c++locale_internal.h       1969-12-31 17:00:00.000000000 -0700
66 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/c++locale_internal.h    2006-03-25 22:18:37.000000000 -0700
67 @@ -0,0 +1,63 @@
68 +// Prototypes for GLIBC thread locale __-prefixed functions -*- C++ -*-
69 +
70 +// Copyright (C) 2002, 2004, 2005 Free Software Foundation, Inc.
71 +//
72 +// This file is part of the GNU ISO C++ Library.  This library is free
73 +// software; you can redistribute it and/or modify it under the
74 +// terms of the GNU General Public License as published by the
75 +// Free Software Foundation; either version 2, or (at your option)
76 +// any later version.
77 +
78 +// This library is distributed in the hope that it will be useful,
79 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
80 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
81 +// GNU General Public License for more details.
82 +
83 +// You should have received a copy of the GNU General Public License along
84 +// with this library; see the file COPYING.  If not, write to the Free
85 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
86 +// USA.
87 +
88 +// As a special exception, you may use this file as part of a free software
89 +// library without restriction.  Specifically, if other files instantiate
90 +// templates or use macros or inline functions from this file, or you compile
91 +// this file and link it with other files to produce an executable, this
92 +// file does not by itself cause the resulting executable to be covered by
93 +// the GNU General Public License.  This exception does not however
94 +// invalidate any other reasons why the executable file might be covered by
95 +// the GNU General Public License.
96 +
97 +// Written by Jakub Jelinek <jakub@redhat.com>
98 +
99 +#include <bits/c++config.h>
100 +#include <clocale>
101 +
102 +#ifdef __UCLIBC_MJN3_ONLY__
103 +#warning clean this up
104 +#endif
105 +
106 +#ifdef __UCLIBC_HAS_XLOCALE__
107 +                                                  
108 +extern "C" __typeof(nl_langinfo_l) __nl_langinfo_l;
109 +extern "C" __typeof(strcoll_l) __strcoll_l;
110 +extern "C" __typeof(strftime_l) __strftime_l;
111 +extern "C" __typeof(strtod_l) __strtod_l;
112 +extern "C" __typeof(strtof_l) __strtof_l;
113 +extern "C" __typeof(strtold_l) __strtold_l;
114 +extern "C" __typeof(strxfrm_l) __strxfrm_l;
115 +extern "C" __typeof(newlocale) __newlocale;
116 +extern "C" __typeof(freelocale) __freelocale;
117 +extern "C" __typeof(duplocale) __duplocale;
118 +extern "C" __typeof(uselocale) __uselocale;
119 +
120 +#ifdef _GLIBCXX_USE_WCHAR_T
121 +extern "C" __typeof(iswctype_l) __iswctype_l;
122 +extern "C" __typeof(towlower_l) __towlower_l;
123 +extern "C" __typeof(towupper_l) __towupper_l;
124 +extern "C" __typeof(wcscoll_l) __wcscoll_l;
125 +extern "C" __typeof(wcsftime_l) __wcsftime_l;
126 +extern "C" __typeof(wcsxfrm_l) __wcsxfrm_l;
127 +extern "C" __typeof(wctype_l) __wctype_l;
128 +#endif 
129 +
130 +#endif // GLIBC 2.3 and later
131 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/c_locale.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/c_locale.cc
132 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/c_locale.cc        1969-12-31 17:00:00.000000000 -0700
133 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/c_locale.cc     2006-03-25 22:18:37.000000000 -0700
134 @@ -0,0 +1,152 @@
135 +// Wrapper for underlying C-language localization -*- C++ -*-
136 +
137 +// Copyright (C) 2001, 2002, 2003, 2004, 2005 
138 +// Free Software Foundation, Inc.
139 +//
140 +// This file is part of the GNU ISO C++ Library.  This library is free
141 +// software; you can redistribute it and/or modify it under the
142 +// terms of the GNU General Public License as published by the
143 +// Free Software Foundation; either version 2, or (at your option)
144 +// any later version.
145 +
146 +// This library is distributed in the hope that it will be useful,
147 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
148 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
149 +// GNU General Public License for more details.
150 +
151 +// You should have received a copy of the GNU General Public License along
152 +// with this library; see the file COPYING.  If not, write to the Free
153 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
154 +// USA.
155 +
156 +// As a special exception, you may use this file as part of a free software
157 +// library without restriction.  Specifically, if other files instantiate
158 +// templates or use macros or inline functions from this file, or you compile
159 +// this file and link it with other files to produce an executable, this
160 +// file does not by itself cause the resulting executable to be covered by
161 +// the GNU General Public License.  This exception does not however
162 +// invalidate any other reasons why the executable file might be covered by
163 +// the GNU General Public License.
164 +
165 +//
166 +// ISO C++ 14882: 22.8  Standard locale categories.
167 +//
168 +
169 +// Written by Benjamin Kosnik <bkoz@redhat.com>
170 +
171 +#include <cerrno>  // For errno
172 +#include <locale>
173 +#include <stdexcept>
174 +#include <langinfo.h>
175 +#include <bits/c++locale_internal.h>
176 +
177 +#ifndef __UCLIBC_HAS_XLOCALE__
178 +#define __strtol_l(S, E, B, L)      strtol((S), (E), (B))
179 +#define __strtoul_l(S, E, B, L)     strtoul((S), (E), (B))
180 +#define __strtoll_l(S, E, B, L)     strtoll((S), (E), (B))
181 +#define __strtoull_l(S, E, B, L)    strtoull((S), (E), (B))
182 +#define __strtof_l(S, E, L)         strtof((S), (E))
183 +#define __strtod_l(S, E, L)         strtod((S), (E))
184 +#define __strtold_l(S, E, L)        strtold((S), (E))
185 +#warning should dummy __newlocale check for C|POSIX ?
186 +#define __newlocale(a, b, c)        NULL
187 +#define __freelocale(a)             ((void)0)
188 +#define __duplocale(a)              __c_locale()
189 +#endif
190 +
191 +namespace std 
192 +{
193 +  template<>
194 +    void
195 +    __convert_to_v(const char* __s, float& __v, ios_base::iostate& __err, 
196 +                  const __c_locale& __cloc)
197 +    {
198 +      char* __sanity;
199 +      errno = 0;
200 +      float __f = __strtof_l(__s, &__sanity, __cloc);
201 +      if (__sanity != __s && errno != ERANGE)
202 +       __v = __f;
203 +      else
204 +       __err |= ios_base::failbit;
205 +    }
206 +
207 +  template<>
208 +    void
209 +    __convert_to_v(const char* __s, double& __v, ios_base::iostate& __err, 
210 +                  const __c_locale& __cloc)
211 +    {
212 +      char* __sanity;
213 +      errno = 0;
214 +      double __d = __strtod_l(__s, &__sanity, __cloc);
215 +      if (__sanity != __s && errno != ERANGE)
216 +       __v = __d;
217 +      else
218 +       __err |= ios_base::failbit;
219 +    }
220 +
221 +  template<>
222 +    void
223 +    __convert_to_v(const char* __s, long double& __v, ios_base::iostate& __err,
224 +                  const __c_locale& __cloc)
225 +    {
226 +      char* __sanity;
227 +      errno = 0;
228 +      long double __ld = __strtold_l(__s, &__sanity, __cloc);
229 +      if (__sanity != __s && errno != ERANGE)
230 +       __v = __ld;
231 +      else
232 +       __err |= ios_base::failbit;
233 +    }
234 +
235 +  void
236 +  locale::facet::_S_create_c_locale(__c_locale& __cloc, const char* __s, 
237 +                                   __c_locale __old)
238 +  {
239 +    __cloc = __newlocale(1 << LC_ALL, __s, __old);
240 +#ifdef __UCLIBC_HAS_XLOCALE__
241 +    if (!__cloc)
242 +      {
243 +       // This named locale is not supported by the underlying OS.
244 +       __throw_runtime_error(__N("locale::facet::_S_create_c_locale "
245 +                             "name not valid"));
246 +      }
247 +#endif
248 +  }
249 +  
250 +  void
251 +  locale::facet::_S_destroy_c_locale(__c_locale& __cloc)
252 +  {
253 +    if (__cloc && _S_get_c_locale() != __cloc)
254 +      __freelocale(__cloc); 
255 +  }
256 +
257 +  __c_locale
258 +  locale::facet::_S_clone_c_locale(__c_locale& __cloc)
259 +  { return __duplocale(__cloc); }
260 +} // namespace std
261 +
262 +namespace __gnu_cxx
263 +{
264 +  const char* const category_names[6 + _GLIBCXX_NUM_CATEGORIES] =
265 +    {
266 +      "LC_CTYPE", 
267 +      "LC_NUMERIC",
268 +      "LC_TIME", 
269 +      "LC_COLLATE", 
270 +      "LC_MONETARY",
271 +      "LC_MESSAGES", 
272 +#if _GLIBCXX_NUM_CATEGORIES != 0
273 +      "LC_PAPER", 
274 +      "LC_NAME", 
275 +      "LC_ADDRESS",
276 +      "LC_TELEPHONE", 
277 +      "LC_MEASUREMENT", 
278 +      "LC_IDENTIFICATION" 
279 +#endif
280 +    };
281 +}
282 +
283 +namespace std
284 +{
285 +  const char* const* const locale::_S_categories = __gnu_cxx::category_names;
286 +}  // namespace std
287 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/c_locale.h gcc-4.1.0/libstdc++-v3/config/locale/uclibc/c_locale.h
288 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/c_locale.h 1969-12-31 17:00:00.000000000 -0700
289 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/c_locale.h      2006-03-26 13:03:42.000000000 -0700
290 @@ -0,0 +1,117 @@
291 +// Wrapper for underlying C-language localization -*- C++ -*-
292 +
293 +// Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
294 +//
295 +// This file is part of the GNU ISO C++ Library.  This library is free
296 +// software; you can redistribute it and/or modify it under the
297 +// terms of the GNU General Public License as published by the
298 +// Free Software Foundation; either version 2, or (at your option)
299 +// any later version.
300 +
301 +// This library is distributed in the hope that it will be useful,
302 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
303 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
304 +// GNU General Public License for more details.
305 +
306 +// You should have received a copy of the GNU General Public License along
307 +// with this library; see the file COPYING.  If not, write to the Free
308 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
309 +// USA.
310 +
311 +// As a special exception, you may use this file as part of a free software
312 +// library without restriction.  Specifically, if other files instantiate
313 +// templates or use macros or inline functions from this file, or you compile
314 +// this file and link it with other files to produce an executable, this
315 +// file does not by itself cause the resulting executable to be covered by
316 +// the GNU General Public License.  This exception does not however
317 +// invalidate any other reasons why the executable file might be covered by
318 +// the GNU General Public License.
319 +
320 +//
321 +// ISO C++ 14882: 22.8  Standard locale categories.
322 +//
323 +
324 +// Written by Benjamin Kosnik <bkoz@redhat.com>
325 +
326 +#ifndef _C_LOCALE_H
327 +#define _C_LOCALE_H 1
328 +
329 +#pragma GCC system_header
330 +
331 +#include <cstring>              // get std::strlen
332 +#include <cstdio>               // get std::snprintf or std::sprintf
333 +#include <clocale>
334 +#include <langinfo.h>          // For codecvt
335 +#ifdef __UCLIBC_MJN3_ONLY__
336 +#warning fix this
337 +#endif
338 +#ifdef __UCLIBC_HAS_LOCALE__
339 +#include <iconv.h>             // For codecvt using iconv, iconv_t
340 +#endif
341 +#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__
342 +#include <libintl.h>           // For messages
343 +#endif
344 +
345 +#ifdef __UCLIBC_MJN3_ONLY__
346 +#warning what is _GLIBCXX_C_LOCALE_GNU for
347 +#endif
348 +#define _GLIBCXX_C_LOCALE_GNU 1
349 +
350 +#ifdef __UCLIBC_MJN3_ONLY__
351 +#warning fix categories
352 +#endif
353 +// #define _GLIBCXX_NUM_CATEGORIES 6
354 +#define _GLIBCXX_NUM_CATEGORIES 0
355
356 +#ifdef __UCLIBC_HAS_XLOCALE__
357 +namespace __gnu_cxx
358 +{
359 +  extern "C" __typeof(uselocale) __uselocale;
360 +}
361 +#endif
362 +
363 +namespace std
364 +{
365 +#ifdef __UCLIBC_HAS_XLOCALE__
366 +  typedef __locale_t           __c_locale;
367 +#else
368 +  typedef int*                 __c_locale;
369 +#endif
370 +
371 +  // Convert numeric value of type _Tv to string and return length of
372 +  // string.  If snprintf is available use it, otherwise fall back to
373 +  // the unsafe sprintf which, in general, can be dangerous and should
374 +  // be avoided.
375 +  template<typename _Tv>
376 +    int
377 +    __convert_from_v(char* __out, 
378 +                    const int __size __attribute__ ((__unused__)),
379 +                    const char* __fmt,
380 +#ifdef __UCLIBC_HAS_XLOCALE__
381 +                    _Tv __v, const __c_locale& __cloc, int __prec)
382 +    {
383 +      __c_locale __old = __gnu_cxx::__uselocale(__cloc);
384 +#else
385 +                    _Tv __v, const __c_locale&, int __prec)
386 +    {
387 +# ifdef __UCLIBC_HAS_LOCALE__
388 +      char* __old = std::setlocale(LC_ALL, NULL);
389 +      char* __sav = new char[std::strlen(__old) + 1];
390 +      std::strcpy(__sav, __old);
391 +      std::setlocale(LC_ALL, "C");
392 +# endif
393 +#endif
394 +
395 +      const int __ret = std::snprintf(__out, __size, __fmt, __prec, __v);
396 +
397 +#ifdef __UCLIBC_HAS_XLOCALE__
398 +      __gnu_cxx::__uselocale(__old);
399 +#elif defined __UCLIBC_HAS_LOCALE__
400 +      std::setlocale(LC_ALL, __sav);
401 +      delete [] __sav;
402 +#endif
403 +      return __ret;
404 +    }
405 +}
406 +
407 +#endif
408 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/codecvt_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/codecvt_members.cc
409 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/codecvt_members.cc 1969-12-31 17:00:00.000000000 -0700
410 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/codecvt_members.cc      2006-03-25 22:18:37.000000000 -0700
411 @@ -0,0 +1,306 @@
412 +// std::codecvt implementation details, GNU version -*- C++ -*-
413 +
414 +// Copyright (C) 2002, 2003 Free Software Foundation, Inc.
415 +//
416 +// This file is part of the GNU ISO C++ Library.  This library is free
417 +// software; you can redistribute it and/or modify it under the
418 +// terms of the GNU General Public License as published by the
419 +// Free Software Foundation; either version 2, or (at your option)
420 +// any later version.
421 +
422 +// This library is distributed in the hope that it will be useful,
423 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
424 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
425 +// GNU General Public License for more details.
426 +
427 +// You should have received a copy of the GNU General Public License along
428 +// with this library; see the file COPYING.  If not, write to the Free
429 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
430 +// USA.
431 +
432 +// As a special exception, you may use this file as part of a free software
433 +// library without restriction.  Specifically, if other files instantiate
434 +// templates or use macros or inline functions from this file, or you compile
435 +// this file and link it with other files to produce an executable, this
436 +// file does not by itself cause the resulting executable to be covered by
437 +// the GNU General Public License.  This exception does not however
438 +// invalidate any other reasons why the executable file might be covered by
439 +// the GNU General Public License.
440 +
441 +//
442 +// ISO C++ 14882: 22.2.1.5 - Template class codecvt
443 +//
444 +
445 +// Written by Benjamin Kosnik <bkoz@redhat.com>
446 +
447 +#include <locale>
448 +#include <bits/c++locale_internal.h>
449 +
450 +namespace std
451 +{
452 +  // Specializations.
453 +#ifdef _GLIBCXX_USE_WCHAR_T
454 +  codecvt_base::result
455 +  codecvt<wchar_t, char, mbstate_t>::
456 +  do_out(state_type& __state, const intern_type* __from, 
457 +        const intern_type* __from_end, const intern_type*& __from_next,
458 +        extern_type* __to, extern_type* __to_end,
459 +        extern_type*& __to_next) const
460 +  {
461 +    result __ret = ok;
462 +    state_type __tmp_state(__state);
463 +
464 +#ifdef __UCLIBC_HAS_XLOCALE__
465 +    __c_locale __old = __uselocale(_M_c_locale_codecvt);
466 +#endif
467 +
468 +    // wcsnrtombs is *very* fast but stops if encounters NUL characters:
469 +    // in case we fall back to wcrtomb and then continue, in a loop.
470 +    // NB: wcsnrtombs is a GNU extension
471 +    for (__from_next = __from, __to_next = __to;
472 +        __from_next < __from_end && __to_next < __to_end
473 +        && __ret == ok;)
474 +      {
475 +       const intern_type* __from_chunk_end = wmemchr(__from_next, L'\0',
476 +                                                     __from_end - __from_next);
477 +       if (!__from_chunk_end)
478 +         __from_chunk_end = __from_end;
479 +
480 +       __from = __from_next;
481 +       const size_t __conv = wcsnrtombs(__to_next, &__from_next,
482 +                                        __from_chunk_end - __from_next,
483 +                                        __to_end - __to_next, &__state);
484 +       if (__conv == static_cast<size_t>(-1))
485 +         {
486 +           // In case of error, in order to stop at the exact place we
487 +           // have to start again from the beginning with a series of
488 +           // wcrtomb.
489 +           for (; __from < __from_next; ++__from)
490 +             __to_next += wcrtomb(__to_next, *__from, &__tmp_state);
491 +           __state = __tmp_state;
492 +           __ret = error;
493 +         }
494 +       else if (__from_next && __from_next < __from_chunk_end)
495 +         {
496 +           __to_next += __conv;
497 +           __ret = partial;
498 +         }
499 +       else
500 +         {
501 +           __from_next = __from_chunk_end;
502 +           __to_next += __conv;
503 +         }
504 +
505 +       if (__from_next < __from_end && __ret == ok)
506 +         {
507 +           extern_type __buf[MB_LEN_MAX];
508 +           __tmp_state = __state;
509 +           const size_t __conv = wcrtomb(__buf, *__from_next, &__tmp_state);
510 +           if (__conv > static_cast<size_t>(__to_end - __to_next))
511 +             __ret = partial;
512 +           else
513 +             {
514 +               memcpy(__to_next, __buf, __conv);
515 +               __state = __tmp_state;
516 +               __to_next += __conv;
517 +               ++__from_next;
518 +             }
519 +         }
520 +      }
521 +
522 +#ifdef __UCLIBC_HAS_XLOCALE__
523 +    __uselocale(__old);
524 +#endif
525 +
526 +    return __ret; 
527 +  }
528 +  
529 +  codecvt_base::result
530 +  codecvt<wchar_t, char, mbstate_t>::
531 +  do_in(state_type& __state, const extern_type* __from, 
532 +       const extern_type* __from_end, const extern_type*& __from_next,
533 +       intern_type* __to, intern_type* __to_end,
534 +       intern_type*& __to_next) const
535 +  {
536 +    result __ret = ok;
537 +    state_type __tmp_state(__state);
538 +
539 +#ifdef __UCLIBC_HAS_XLOCALE__
540 +    __c_locale __old = __uselocale(_M_c_locale_codecvt);
541 +#endif
542 +
543 +    // mbsnrtowcs is *very* fast but stops if encounters NUL characters:
544 +    // in case we store a L'\0' and then continue, in a loop.
545 +    // NB: mbsnrtowcs is a GNU extension
546 +    for (__from_next = __from, __to_next = __to;
547 +        __from_next < __from_end && __to_next < __to_end
548 +        && __ret == ok;)
549 +      {
550 +       const extern_type* __from_chunk_end;
551 +       __from_chunk_end = static_cast<const extern_type*>(memchr(__from_next, '\0',
552 +                                                                 __from_end
553 +                                                                 - __from_next));
554 +       if (!__from_chunk_end)
555 +         __from_chunk_end = __from_end;
556 +
557 +       __from = __from_next;
558 +       size_t __conv = mbsnrtowcs(__to_next, &__from_next,
559 +                                  __from_chunk_end - __from_next,
560 +                                  __to_end - __to_next, &__state);
561 +       if (__conv == static_cast<size_t>(-1))
562 +         {
563 +           // In case of error, in order to stop at the exact place we
564 +           // have to start again from the beginning with a series of
565 +           // mbrtowc.
566 +           for (;; ++__to_next, __from += __conv)
567 +             {
568 +               __conv = mbrtowc(__to_next, __from, __from_end - __from,
569 +                                &__tmp_state);
570 +               if (__conv == static_cast<size_t>(-1)
571 +                   || __conv == static_cast<size_t>(-2))
572 +                 break;
573 +             }
574 +           __from_next = __from;
575 +           __state = __tmp_state;          
576 +           __ret = error;
577 +         }
578 +       else if (__from_next && __from_next < __from_chunk_end)
579 +         {
580 +           // It is unclear what to return in this case (see DR 382). 
581 +           __to_next += __conv;
582 +           __ret = partial;
583 +         }
584 +       else
585 +         {
586 +           __from_next = __from_chunk_end;
587 +           __to_next += __conv;
588 +         }
589 +
590 +       if (__from_next < __from_end && __ret == ok)
591 +         {
592 +           if (__to_next < __to_end)
593 +             {
594 +               // XXX Probably wrong for stateful encodings
595 +               __tmp_state = __state;          
596 +               ++__from_next;
597 +               *__to_next++ = L'\0';
598 +             }
599 +           else
600 +             __ret = partial;
601 +         }
602 +      }
603 +
604 +#ifdef __UCLIBC_HAS_XLOCALE__
605 +    __uselocale(__old);
606 +#endif
607 +
608 +    return __ret; 
609 +  }
610 +
611 +  int 
612 +  codecvt<wchar_t, char, mbstate_t>::
613 +  do_encoding() const throw()
614 +  {
615 +    // XXX This implementation assumes that the encoding is
616 +    // stateless and is either single-byte or variable-width.
617 +    int __ret = 0;
618 +#ifdef __UCLIBC_HAS_XLOCALE__
619 +    __c_locale __old = __uselocale(_M_c_locale_codecvt);
620 +#endif
621 +    if (MB_CUR_MAX == 1)
622 +      __ret = 1;
623 +#ifdef __UCLIBC_HAS_XLOCALE__
624 +    __uselocale(__old);
625 +#endif
626 +    return __ret;
627 +  }  
628 +
629 +  int 
630 +  codecvt<wchar_t, char, mbstate_t>::
631 +  do_max_length() const throw()
632 +  {
633 +#ifdef __UCLIBC_HAS_XLOCALE__
634 +    __c_locale __old = __uselocale(_M_c_locale_codecvt);
635 +#endif
636 +    // XXX Probably wrong for stateful encodings.
637 +    int __ret = MB_CUR_MAX;
638 +#ifdef __UCLIBC_HAS_XLOCALE__
639 +    __uselocale(__old);
640 +#endif
641 +    return __ret;
642 +  }
643 +  
644 +  int 
645 +  codecvt<wchar_t, char, mbstate_t>::
646 +  do_length(state_type& __state, const extern_type* __from,
647 +           const extern_type* __end, size_t __max) const
648 +  {
649 +    int __ret = 0;
650 +    state_type __tmp_state(__state);
651 +
652 +#ifdef __UCLIBC_HAS_XLOCALE__
653 +    __c_locale __old = __uselocale(_M_c_locale_codecvt);
654 +#endif
655 +
656 +    // mbsnrtowcs is *very* fast but stops if encounters NUL characters:
657 +    // in case we advance past it and then continue, in a loop.
658 +    // NB: mbsnrtowcs is a GNU extension
659 +  
660 +    // A dummy internal buffer is needed in order for mbsnrtocws to consider
661 +    // its fourth parameter (it wouldn't with NULL as first parameter).
662 +    wchar_t* __to = static_cast<wchar_t*>(__builtin_alloca(sizeof(wchar_t) 
663 +                                                          * __max));
664 +    while (__from < __end && __max)
665 +      {
666 +       const extern_type* __from_chunk_end;
667 +       __from_chunk_end = static_cast<const extern_type*>(memchr(__from, '\0',
668 +                                                                 __end
669 +                                                                 - __from));
670 +       if (!__from_chunk_end)
671 +         __from_chunk_end = __end;
672 +
673 +       const extern_type* __tmp_from = __from;
674 +       size_t __conv = mbsnrtowcs(__to, &__from,
675 +                                  __from_chunk_end - __from,
676 +                                  __max, &__state);
677 +       if (__conv == static_cast<size_t>(-1))
678 +         {
679 +           // In case of error, in order to stop at the exact place we
680 +           // have to start again from the beginning with a series of
681 +           // mbrtowc.
682 +           for (__from = __tmp_from;; __from += __conv)
683 +             {
684 +               __conv = mbrtowc(NULL, __from, __end - __from,
685 +                                &__tmp_state);
686 +               if (__conv == static_cast<size_t>(-1)
687 +                   || __conv == static_cast<size_t>(-2))
688 +                 break;
689 +             }
690 +           __state = __tmp_state;
691 +           __ret += __from - __tmp_from;
692 +           break;
693 +         }
694 +       if (!__from)
695 +         __from = __from_chunk_end;
696 +       
697 +       __ret += __from - __tmp_from;
698 +       __max -= __conv;
699 +
700 +       if (__from < __end && __max)
701 +         {
702 +           // XXX Probably wrong for stateful encodings
703 +           __tmp_state = __state;
704 +           ++__from;
705 +           ++__ret;
706 +           --__max;
707 +         }
708 +      }
709 +
710 +#ifdef __UCLIBC_HAS_XLOCALE__
711 +    __uselocale(__old);
712 +#endif
713 +
714 +    return __ret; 
715 +  }
716 +#endif
717 +}
718 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/collate_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/collate_members.cc
719 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/collate_members.cc 1969-12-31 17:00:00.000000000 -0700
720 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/collate_members.cc      2006-03-25 22:18:37.000000000 -0700
721 @@ -0,0 +1,80 @@
722 +// std::collate implementation details, GNU version -*- C++ -*-
723 +
724 +// Copyright (C) 2001, 2002 Free Software Foundation, Inc.
725 +//
726 +// This file is part of the GNU ISO C++ Library.  This library is free
727 +// software; you can redistribute it and/or modify it under the
728 +// terms of the GNU General Public License as published by the
729 +// Free Software Foundation; either version 2, or (at your option)
730 +// any later version.
731 +
732 +// This library is distributed in the hope that it will be useful,
733 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
734 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
735 +// GNU General Public License for more details.
736 +
737 +// You should have received a copy of the GNU General Public License along
738 +// with this library; see the file COPYING.  If not, write to the Free
739 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
740 +// USA.
741 +
742 +// As a special exception, you may use this file as part of a free software
743 +// library without restriction.  Specifically, if other files instantiate
744 +// templates or use macros or inline functions from this file, or you compile
745 +// this file and link it with other files to produce an executable, this
746 +// file does not by itself cause the resulting executable to be covered by
747 +// the GNU General Public License.  This exception does not however
748 +// invalidate any other reasons why the executable file might be covered by
749 +// the GNU General Public License.
750 +
751 +//
752 +// ISO C++ 14882: 22.2.4.1.2  collate virtual functions
753 +//
754 +
755 +// Written by Benjamin Kosnik <bkoz@redhat.com>
756 +
757 +#include <locale>
758 +#include <bits/c++locale_internal.h>
759 +
760 +#ifndef __UCLIBC_HAS_XLOCALE__
761 +#define __strcoll_l(S1, S2, L)      strcoll((S1), (S2))
762 +#define __strxfrm_l(S1, S2, N, L)   strxfrm((S1), (S2), (N))
763 +#define __wcscoll_l(S1, S2, L)      wcscoll((S1), (S2))
764 +#define __wcsxfrm_l(S1, S2, N, L)   wcsxfrm((S1), (S2), (N))
765 +#endif
766 +
767 +namespace std
768 +{
769 +  // These are basically extensions to char_traits, and perhaps should
770 +  // be put there instead of here.
771 +  template<>
772 +    int 
773 +    collate<char>::_M_compare(const char* __one, const char* __two) const
774 +    { 
775 +      int __cmp = __strcoll_l(__one, __two, _M_c_locale_collate);
776 +      return (__cmp >> (8 * sizeof (int) - 2)) | (__cmp != 0);
777 +    }
778 +  
779 +  template<>
780 +    size_t
781 +    collate<char>::_M_transform(char* __to, const char* __from, 
782 +                               size_t __n) const 
783 +    { return __strxfrm_l(__to, __from, __n, _M_c_locale_collate); }
784 +
785 +#ifdef _GLIBCXX_USE_WCHAR_T
786 +  template<>
787 +    int 
788 +    collate<wchar_t>::_M_compare(const wchar_t* __one, 
789 +                                const wchar_t* __two) const
790 +    {
791 +      int __cmp = __wcscoll_l(__one, __two, _M_c_locale_collate);
792 +      return (__cmp >> (8 * sizeof (int) - 2)) | (__cmp != 0);
793 +    }
794 +  
795 +  template<>
796 +    size_t
797 +    collate<wchar_t>::_M_transform(wchar_t* __to, const wchar_t* __from,
798 +                                  size_t __n) const
799 +    { return __wcsxfrm_l(__to, __from, __n, _M_c_locale_collate); }
800 +#endif
801 +}
802 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/ctype_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/ctype_members.cc
803 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/ctype_members.cc   1969-12-31 17:00:00.000000000 -0700
804 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/ctype_members.cc        2006-03-25 22:18:37.000000000 -0700
805 @@ -0,0 +1,314 @@
806 +// std::ctype implementation details, GNU version -*- C++ -*-
807 +
808 +// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
809 +//
810 +// This file is part of the GNU ISO C++ Library.  This library is free
811 +// software; you can redistribute it and/or modify it under the
812 +// terms of the GNU General Public License as published by the
813 +// Free Software Foundation; either version 2, or (at your option)
814 +// any later version.
815 +
816 +// This library is distributed in the hope that it will be useful,
817 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
818 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
819 +// GNU General Public License for more details.
820 +
821 +// You should have received a copy of the GNU General Public License along
822 +// with this library; see the file COPYING.  If not, write to the Free
823 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
824 +// USA.
825 +
826 +// As a special exception, you may use this file as part of a free software
827 +// library without restriction.  Specifically, if other files instantiate
828 +// templates or use macros or inline functions from this file, or you compile
829 +// this file and link it with other files to produce an executable, this
830 +// file does not by itself cause the resulting executable to be covered by
831 +// the GNU General Public License.  This exception does not however
832 +// invalidate any other reasons why the executable file might be covered by
833 +// the GNU General Public License.
834 +
835 +//
836 +// ISO C++ 14882: 22.2.1.1.2  ctype virtual functions.
837 +//
838 +
839 +// Written by Benjamin Kosnik <bkoz@redhat.com>
840 +
841 +#define _LIBC
842 +#include <locale>
843 +#undef _LIBC
844 +#include <bits/c++locale_internal.h>
845 +
846 +#ifndef __UCLIBC_HAS_XLOCALE__
847 +#define __wctype_l(S, L)           wctype((S))
848 +#define __towupper_l(C, L)         towupper((C))
849 +#define __towlower_l(C, L)         towlower((C))
850 +#define __iswctype_l(C, M, L)      iswctype((C), (M))
851 +#endif
852 +
853 +namespace std
854 +{
855 +  // NB: The other ctype<char> specializations are in src/locale.cc and
856 +  // various /config/os/* files.
857 +  template<>
858 +    ctype_byname<char>::ctype_byname(const char* __s, size_t __refs)
859 +    : ctype<char>(0, false, __refs) 
860 +    {          
861 +      if (std::strcmp(__s, "C") != 0 && std::strcmp(__s, "POSIX") != 0)
862 +       {
863 +         this->_S_destroy_c_locale(this->_M_c_locale_ctype);
864 +         this->_S_create_c_locale(this->_M_c_locale_ctype, __s); 
865 +#ifdef __UCLIBC_HAS_XLOCALE__
866 +         this->_M_toupper = this->_M_c_locale_ctype->__ctype_toupper;
867 +         this->_M_tolower = this->_M_c_locale_ctype->__ctype_tolower;
868 +         this->_M_table = this->_M_c_locale_ctype->__ctype_b;
869 +#endif
870 +       }
871 +    }
872 +
873 +#ifdef _GLIBCXX_USE_WCHAR_T  
874 +  ctype<wchar_t>::__wmask_type
875 +  ctype<wchar_t>::_M_convert_to_wmask(const mask __m) const
876 +  {
877 +    __wmask_type __ret;
878 +    switch (__m)
879 +      {
880 +      case space:
881 +       __ret = __wctype_l("space", _M_c_locale_ctype);
882 +       break;
883 +      case print:
884 +       __ret = __wctype_l("print", _M_c_locale_ctype);
885 +       break;
886 +      case cntrl:
887 +       __ret = __wctype_l("cntrl", _M_c_locale_ctype);
888 +       break;
889 +      case upper:
890 +       __ret = __wctype_l("upper", _M_c_locale_ctype);
891 +       break;
892 +      case lower:
893 +       __ret = __wctype_l("lower", _M_c_locale_ctype);
894 +       break;
895 +      case alpha:
896 +       __ret = __wctype_l("alpha", _M_c_locale_ctype);
897 +       break;
898 +      case digit:
899 +       __ret = __wctype_l("digit", _M_c_locale_ctype);
900 +       break;
901 +      case punct:
902 +       __ret = __wctype_l("punct", _M_c_locale_ctype);
903 +       break;
904 +      case xdigit:
905 +       __ret = __wctype_l("xdigit", _M_c_locale_ctype);
906 +       break;
907 +      case alnum:
908 +       __ret = __wctype_l("alnum", _M_c_locale_ctype);
909 +       break;
910 +      case graph:
911 +       __ret = __wctype_l("graph", _M_c_locale_ctype);
912 +       break;
913 +      default:
914 +       __ret = __wmask_type();
915 +      }
916 +    return __ret;
917 +  }
918 +  
919 +  wchar_t
920 +  ctype<wchar_t>::do_toupper(wchar_t __c) const
921 +  { return __towupper_l(__c, _M_c_locale_ctype); }
922 +
923 +  const wchar_t*
924 +  ctype<wchar_t>::do_toupper(wchar_t* __lo, const wchar_t* __hi) const
925 +  {
926 +    while (__lo < __hi)
927 +      {
928 +        *__lo = __towupper_l(*__lo, _M_c_locale_ctype);
929 +        ++__lo;
930 +      }
931 +    return __hi;
932 +  }
933 +  
934 +  wchar_t
935 +  ctype<wchar_t>::do_tolower(wchar_t __c) const
936 +  { return __towlower_l(__c, _M_c_locale_ctype); }
937 +  
938 +  const wchar_t*
939 +  ctype<wchar_t>::do_tolower(wchar_t* __lo, const wchar_t* __hi) const
940 +  {
941 +    while (__lo < __hi)
942 +      {
943 +        *__lo = __towlower_l(*__lo, _M_c_locale_ctype);
944 +        ++__lo;
945 +      }
946 +    return __hi;
947 +  }
948 +
949 +  bool
950 +  ctype<wchar_t>::
951 +  do_is(mask __m, wchar_t __c) const
952 +  { 
953 +    // The case of __m == ctype_base::space is particularly important,
954 +    // due to its use in many istream functions.  Therefore we deal with
955 +    // it first, exploiting the knowledge that on GNU systems _M_bit[5]
956 +    // is the mask corresponding to ctype_base::space.  NB: an encoding
957 +    // change would not affect correctness!
958 +    bool __ret = false;
959 +    if (__m == _M_bit[5])
960 +      __ret = __iswctype_l(__c, _M_wmask[5], _M_c_locale_ctype);
961 +    else
962 +      {
963 +       // Highest bitmask in ctype_base == 10, but extra in "C"
964 +       // library for blank.
965 +       const size_t __bitmasksize = 11;
966 +       for (size_t __bitcur = 0; __bitcur <= __bitmasksize; ++__bitcur)
967 +         if (__m & _M_bit[__bitcur])
968 +           {
969 +             if (__iswctype_l(__c, _M_wmask[__bitcur], _M_c_locale_ctype))
970 +               {
971 +                 __ret = true;
972 +                 break;
973 +               }
974 +             else if (__m == _M_bit[__bitcur])
975 +               break;
976 +           }
977 +      }
978 +    return __ret;    
979 +  }
980 +
981 +  const wchar_t* 
982 +  ctype<wchar_t>::
983 +  do_is(const wchar_t* __lo, const wchar_t* __hi, mask* __vec) const
984 +  {
985 +    for (; __lo < __hi; ++__vec, ++__lo)
986 +      {
987 +       // Highest bitmask in ctype_base == 10, but extra in "C"
988 +       // library for blank.
989 +       const size_t __bitmasksize = 11; 
990 +       mask __m = 0;
991 +       for (size_t __bitcur = 0; __bitcur <= __bitmasksize; ++__bitcur)
992 +         if (__iswctype_l(*__lo, _M_wmask[__bitcur], _M_c_locale_ctype))
993 +           __m |= _M_bit[__bitcur];
994 +       *__vec = __m;
995 +      }
996 +    return __hi;
997 +  }
998 +  
999 +  const wchar_t* 
1000 +  ctype<wchar_t>::
1001 +  do_scan_is(mask __m, const wchar_t* __lo, const wchar_t* __hi) const
1002 +  {
1003 +    while (__lo < __hi && !this->do_is(__m, *__lo))
1004 +      ++__lo;
1005 +    return __lo;
1006 +  }
1007 +
1008 +  const wchar_t*
1009 +  ctype<wchar_t>::
1010 +  do_scan_not(mask __m, const char_type* __lo, const char_type* __hi) const
1011 +  {
1012 +    while (__lo < __hi && this->do_is(__m, *__lo) != 0)
1013 +      ++__lo;
1014 +    return __lo;
1015 +  }
1016 +
1017 +  wchar_t
1018 +  ctype<wchar_t>::
1019 +  do_widen(char __c) const
1020 +  { return _M_widen[static_cast<unsigned char>(__c)]; }
1021 +
1022 +  const char* 
1023 +  ctype<wchar_t>::
1024 +  do_widen(const char* __lo, const char* __hi, wchar_t* __dest) const
1025 +  {
1026 +    while (__lo < __hi)
1027 +      {
1028 +       *__dest = _M_widen[static_cast<unsigned char>(*__lo)];
1029 +       ++__lo;
1030 +       ++__dest;
1031 +      }
1032 +    return __hi;
1033 +  }
1034 +
1035 +  char
1036 +  ctype<wchar_t>::
1037 +  do_narrow(wchar_t __wc, char __dfault) const
1038 +  {
1039 +    if (__wc >= 0 && __wc < 128 && _M_narrow_ok)
1040 +      return _M_narrow[__wc];
1041 +#ifdef __UCLIBC_HAS_XLOCALE__
1042 +    __c_locale __old = __uselocale(_M_c_locale_ctype);
1043 +#endif
1044 +    const int __c = wctob(__wc);
1045 +#ifdef __UCLIBC_HAS_XLOCALE__
1046 +    __uselocale(__old);
1047 +#endif
1048 +    return (__c == EOF ? __dfault : static_cast<char>(__c)); 
1049 +  }
1050 +
1051 +  const wchar_t*
1052 +  ctype<wchar_t>::
1053 +  do_narrow(const wchar_t* __lo, const wchar_t* __hi, char __dfault, 
1054 +           char* __dest) const
1055 +  {
1056 +#ifdef __UCLIBC_HAS_XLOCALE__
1057 +    __c_locale __old = __uselocale(_M_c_locale_ctype);
1058 +#endif
1059 +    if (_M_narrow_ok)
1060 +      while (__lo < __hi)
1061 +       {
1062 +         if (*__lo >= 0 && *__lo < 128)
1063 +           *__dest = _M_narrow[*__lo];
1064 +         else
1065 +           {
1066 +             const int __c = wctob(*__lo);
1067 +             *__dest = (__c == EOF ? __dfault : static_cast<char>(__c));
1068 +           }
1069 +         ++__lo;
1070 +         ++__dest;
1071 +       }
1072 +    else
1073 +      while (__lo < __hi)
1074 +       {
1075 +         const int __c = wctob(*__lo);
1076 +         *__dest = (__c == EOF ? __dfault : static_cast<char>(__c));
1077 +         ++__lo;
1078 +         ++__dest;
1079 +       }
1080 +#ifdef __UCLIBC_HAS_XLOCALE__
1081 +    __uselocale(__old);
1082 +#endif
1083 +    return __hi;
1084 +  }
1085 +
1086 +  void
1087 +  ctype<wchar_t>::_M_initialize_ctype()
1088 +  {
1089 +#ifdef __UCLIBC_HAS_XLOCALE__
1090 +    __c_locale __old = __uselocale(_M_c_locale_ctype);
1091 +#endif
1092 +    wint_t __i;
1093 +    for (__i = 0; __i < 128; ++__i)
1094 +      {
1095 +       const int __c = wctob(__i);
1096 +       if (__c == EOF)
1097 +         break;
1098 +       else
1099 +         _M_narrow[__i] = static_cast<char>(__c);
1100 +      }
1101 +    if (__i == 128)
1102 +      _M_narrow_ok = true;
1103 +    else
1104 +      _M_narrow_ok = false;
1105 +    for (size_t __j = 0;
1106 +        __j < sizeof(_M_widen) / sizeof(wint_t); ++__j)
1107 +      _M_widen[__j] = btowc(__j);
1108 +
1109 +    for (size_t __k = 0; __k <= 11; ++__k)
1110 +      { 
1111 +       _M_bit[__k] = static_cast<mask>(_ISbit(__k));
1112 +       _M_wmask[__k] = _M_convert_to_wmask(_M_bit[__k]);
1113 +      }
1114 +#ifdef __UCLIBC_HAS_XLOCALE__
1115 +    __uselocale(__old);
1116 +#endif
1117 +  }
1118 +#endif //  _GLIBCXX_USE_WCHAR_T
1119 +}
1120 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/messages_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/messages_members.cc
1121 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/messages_members.cc        1969-12-31 17:00:00.000000000 -0700
1122 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/messages_members.cc     2006-03-25 22:18:37.000000000 -0700
1123 @@ -0,0 +1,100 @@
1124 +// std::messages implementation details, GNU version -*- C++ -*-
1125 +
1126 +// Copyright (C) 2001, 2002 Free Software Foundation, Inc.
1127 +//
1128 +// This file is part of the GNU ISO C++ Library.  This library is free
1129 +// software; you can redistribute it and/or modify it under the
1130 +// terms of the GNU General Public License as published by the
1131 +// Free Software Foundation; either version 2, or (at your option)
1132 +// any later version.
1133 +
1134 +// This library is distributed in the hope that it will be useful,
1135 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
1136 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1137 +// GNU General Public License for more details.
1138 +
1139 +// You should have received a copy of the GNU General Public License along
1140 +// with this library; see the file COPYING.  If not, write to the Free
1141 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
1142 +// USA.
1143 +
1144 +// As a special exception, you may use this file as part of a free software
1145 +// library without restriction.  Specifically, if other files instantiate
1146 +// templates or use macros or inline functions from this file, or you compile
1147 +// this file and link it with other files to produce an executable, this
1148 +// file does not by itself cause the resulting executable to be covered by
1149 +// the GNU General Public License.  This exception does not however
1150 +// invalidate any other reasons why the executable file might be covered by
1151 +// the GNU General Public License.
1152 +
1153 +//
1154 +// ISO C++ 14882: 22.2.7.1.2  messages virtual functions
1155 +//
1156 +
1157 +// Written by Benjamin Kosnik <bkoz@redhat.com>
1158 +
1159 +#include <locale>
1160 +#include <bits/c++locale_internal.h>
1161 +
1162 +#ifdef __UCLIBC_MJN3_ONLY__
1163 +#warning fix gettext stuff
1164 +#endif
1165 +#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__
1166 +extern "C" char *__dcgettext(const char *domainname,
1167 +                            const char *msgid, int category);
1168 +#undef gettext
1169 +#define gettext(msgid) __dcgettext(NULL, msgid, LC_MESSAGES)
1170 +#else
1171 +#undef gettext
1172 +#define gettext(msgid) (msgid)
1173 +#endif
1174 +
1175 +namespace std
1176 +{
1177 +  // Specializations.
1178 +  template<>
1179 +    string
1180 +    messages<char>::do_get(catalog, int, int, const string& __dfault) const
1181 +    {
1182 +#ifdef __UCLIBC_HAS_XLOCALE__
1183 +      __c_locale __old = __uselocale(_M_c_locale_messages);
1184 +      const char* __msg = const_cast<const char*>(gettext(__dfault.c_str()));
1185 +      __uselocale(__old);
1186 +      return string(__msg);
1187 +#elif defined __UCLIBC_HAS_LOCALE__
1188 +      char* __old = strdup(setlocale(LC_ALL, NULL));
1189 +      setlocale(LC_ALL, _M_name_messages);
1190 +      const char* __msg = gettext(__dfault.c_str());
1191 +      setlocale(LC_ALL, __old);
1192 +      free(__old);
1193 +      return string(__msg);
1194 +#else
1195 +      const char* __msg = gettext(__dfault.c_str());
1196 +      return string(__msg);
1197 +#endif
1198 +    }
1199 +
1200 +#ifdef _GLIBCXX_USE_WCHAR_T
1201 +  template<>
1202 +    wstring
1203 +    messages<wchar_t>::do_get(catalog, int, int, const wstring& __dfault) const
1204 +    {
1205 +# ifdef __UCLIBC_HAS_XLOCALE__
1206 +      __c_locale __old = __uselocale(_M_c_locale_messages);
1207 +      char* __msg = gettext(_M_convert_to_char(__dfault));
1208 +      __uselocale(__old);
1209 +      return _M_convert_from_char(__msg);
1210 +# elif defined __UCLIBC_HAS_LOCALE__
1211 +      char* __old = strdup(setlocale(LC_ALL, NULL));
1212 +      setlocale(LC_ALL, _M_name_messages);
1213 +      char* __msg = gettext(_M_convert_to_char(__dfault));
1214 +      setlocale(LC_ALL, __old);
1215 +      free(__old);
1216 +      return _M_convert_from_char(__msg);
1217 +# else
1218 +      char* __msg = gettext(_M_convert_to_char(__dfault));
1219 +      return _M_convert_from_char(__msg);
1220 +# endif
1221 +    }
1222 +#endif
1223 +}
1224 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/messages_members.h gcc-4.1.0/libstdc++-v3/config/locale/uclibc/messages_members.h
1225 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/messages_members.h 1969-12-31 17:00:00.000000000 -0700
1226 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/messages_members.h      2006-03-25 22:18:37.000000000 -0700
1227 @@ -0,0 +1,121 @@
1228 +// std::messages implementation details, GNU version -*- C++ -*-
1229 +
1230 +// Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
1231 +//
1232 +// This file is part of the GNU ISO C++ Library.  This library is free
1233 +// software; you can redistribute it and/or modify it under the
1234 +// terms of the GNU General Public License as published by the
1235 +// Free Software Foundation; either version 2, or (at your option)
1236 +// any later version.
1237 +
1238 +// This library is distributed in the hope that it will be useful,
1239 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
1240 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1241 +// GNU General Public License for more details.
1242 +
1243 +// You should have received a copy of the GNU General Public License along
1244 +// with this library; see the file COPYING.  If not, write to the Free
1245 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
1246 +// USA.
1247 +
1248 +// As a special exception, you may use this file as part of a free software
1249 +// library without restriction.  Specifically, if other files instantiate
1250 +// templates or use macros or inline functions from this file, or you compile
1251 +// this file and link it with other files to produce an executable, this
1252 +// file does not by itself cause the resulting executable to be covered by
1253 +// the GNU General Public License.  This exception does not however
1254 +// invalidate any other reasons why the executable file might be covered by
1255 +// the GNU General Public License.
1256 +
1257 +//
1258 +// ISO C++ 14882: 22.2.7.1.2  messages functions
1259 +//
1260 +
1261 +// Written by Benjamin Kosnik <bkoz@redhat.com>
1262 +
1263 +#ifdef __UCLIBC_MJN3_ONLY__
1264 +#warning fix prototypes for *textdomain funcs
1265 +#endif
1266 +#ifdef __UCLIBC_HAS_GETTEXT_AWARENESS__
1267 +extern "C" char *__textdomain(const char *domainname);
1268 +extern "C" char *__bindtextdomain(const char *domainname,
1269 +                                 const char *dirname);
1270 +#else
1271 +#undef __textdomain
1272 +#undef __bindtextdomain
1273 +#define __textdomain(D)           ((void)0)
1274 +#define __bindtextdomain(D,P)     ((void)0)
1275 +#endif
1276 +
1277 +  // Non-virtual member functions.
1278 +  template<typename _CharT>
1279 +     messages<_CharT>::messages(size_t __refs)
1280 +     : facet(__refs), _M_c_locale_messages(_S_get_c_locale()), 
1281 +       _M_name_messages(_S_get_c_name())
1282 +     { }
1283 +
1284 +  template<typename _CharT>
1285 +     messages<_CharT>::messages(__c_locale __cloc, const char* __s, 
1286 +                               size_t __refs) 
1287 +     : facet(__refs), _M_c_locale_messages(NULL), _M_name_messages(NULL)
1288 +     {
1289 +       const size_t __len = std::strlen(__s) + 1;
1290 +       char* __tmp = new char[__len];
1291 +       std::memcpy(__tmp, __s, __len);
1292 +       _M_name_messages = __tmp;
1293 +
1294 +       // Last to avoid leaking memory if new throws.
1295 +       _M_c_locale_messages = _S_clone_c_locale(__cloc);
1296 +     }
1297 +
1298 +  template<typename _CharT>
1299 +    typename messages<_CharT>::catalog 
1300 +    messages<_CharT>::open(const basic_string<char>& __s, const locale& __loc, 
1301 +                          const char* __dir) const
1302 +    { 
1303 +      __bindtextdomain(__s.c_str(), __dir);
1304 +      return this->do_open(__s, __loc); 
1305 +    }
1306 +
1307 +  // Virtual member functions.
1308 +  template<typename _CharT>
1309 +    messages<_CharT>::~messages()
1310 +    { 
1311 +      if (_M_name_messages != _S_get_c_name())
1312 +       delete [] _M_name_messages;
1313 +      _S_destroy_c_locale(_M_c_locale_messages); 
1314 +    }
1315 +
1316 +  template<typename _CharT>
1317 +    typename messages<_CharT>::catalog 
1318 +    messages<_CharT>::do_open(const basic_string<char>& __s, 
1319 +                             const locale&) const
1320 +    { 
1321 +      // No error checking is done, assume the catalog exists and can
1322 +      // be used.
1323 +      __textdomain(__s.c_str());
1324 +      return 0;
1325 +    }
1326 +
1327 +  template<typename _CharT>
1328 +    void    
1329 +    messages<_CharT>::do_close(catalog) const 
1330 +    { }
1331 +
1332 +   // messages_byname
1333 +   template<typename _CharT>
1334 +     messages_byname<_CharT>::messages_byname(const char* __s, size_t __refs)
1335 +     : messages<_CharT>(__refs) 
1336 +     { 
1337 +       if (this->_M_name_messages != locale::facet::_S_get_c_name())
1338 +        delete [] this->_M_name_messages;
1339 +       char* __tmp = new char[std::strlen(__s) + 1];
1340 +       std::strcpy(__tmp, __s);
1341 +       this->_M_name_messages = __tmp;
1342 +
1343 +       if (std::strcmp(__s, "C") != 0 && std::strcmp(__s, "POSIX") != 0)
1344 +        {
1345 +          this->_S_destroy_c_locale(this->_M_c_locale_messages);
1346 +          this->_S_create_c_locale(this->_M_c_locale_messages, __s); 
1347 +        }
1348 +     }
1349 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/monetary_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/monetary_members.cc
1350 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/monetary_members.cc        1969-12-31 17:00:00.000000000 -0700
1351 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/monetary_members.cc     2006-03-25 22:18:37.000000000 -0700
1352 @@ -0,0 +1,692 @@
1353 +// std::moneypunct implementation details, GNU version -*- C++ -*-
1354 +
1355 +// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
1356 +//
1357 +// This file is part of the GNU ISO C++ Library.  This library is free
1358 +// software; you can redistribute it and/or modify it under the
1359 +// terms of the GNU General Public License as published by the
1360 +// Free Software Foundation; either version 2, or (at your option)
1361 +// any later version.
1362 +
1363 +// This library is distributed in the hope that it will be useful,
1364 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
1365 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1366 +// GNU General Public License for more details.
1367 +
1368 +// You should have received a copy of the GNU General Public License along
1369 +// with this library; see the file COPYING.  If not, write to the Free
1370 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
1371 +// USA.
1372 +
1373 +// As a special exception, you may use this file as part of a free software
1374 +// library without restriction.  Specifically, if other files instantiate
1375 +// templates or use macros or inline functions from this file, or you compile
1376 +// this file and link it with other files to produce an executable, this
1377 +// file does not by itself cause the resulting executable to be covered by
1378 +// the GNU General Public License.  This exception does not however
1379 +// invalidate any other reasons why the executable file might be covered by
1380 +// the GNU General Public License.
1381 +
1382 +//
1383 +// ISO C++ 14882: 22.2.6.3.2  moneypunct virtual functions
1384 +//
1385 +
1386 +// Written by Benjamin Kosnik <bkoz@redhat.com>
1387 +
1388 +#define _LIBC
1389 +#include <locale>
1390 +#undef _LIBC
1391 +#include <bits/c++locale_internal.h>
1392 +
1393 +#ifdef __UCLIBC_MJN3_ONLY__
1394 +#warning optimize this for uclibc
1395 +#warning tailor for stub locale support
1396 +#endif
1397 +
1398 +#ifndef __UCLIBC_HAS_XLOCALE__
1399 +#define __nl_langinfo_l(N, L)         nl_langinfo((N))
1400 +#endif
1401 +
1402 +namespace std
1403 +{
1404 +  // Construct and return valid pattern consisting of some combination of:
1405 +  // space none symbol sign value
1406 +  money_base::pattern
1407 +  money_base::_S_construct_pattern(char __precedes, char __space, char __posn)
1408 +  { 
1409 +    pattern __ret;
1410 +
1411 +    // This insanely complicated routine attempts to construct a valid
1412 +    // pattern for use with monyepunct. A couple of invariants:
1413 +
1414 +    // if (__precedes) symbol -> value
1415 +    // else value -> symbol
1416 +    
1417 +    // if (__space) space
1418 +    // else none
1419 +
1420 +    // none == never first
1421 +    // space never first or last
1422 +
1423 +    // Any elegant implementations of this are welcome.
1424 +    switch (__posn)
1425 +      {
1426 +      case 0:
1427 +      case 1:
1428 +       // 1 The sign precedes the value and symbol.
1429 +       __ret.field[0] = sign;
1430 +       if (__space)
1431 +         {
1432 +           // Pattern starts with sign.
1433 +           if (__precedes)
1434 +             {
1435 +               __ret.field[1] = symbol;
1436 +               __ret.field[3] = value;
1437 +             }
1438 +           else
1439 +             {
1440 +               __ret.field[1] = value;
1441 +               __ret.field[3] = symbol;
1442 +             }
1443 +           __ret.field[2] = space;
1444 +         }
1445 +       else
1446 +         {
1447 +           // Pattern starts with sign and ends with none.
1448 +           if (__precedes)
1449 +             {
1450 +               __ret.field[1] = symbol;
1451 +               __ret.field[2] = value;
1452 +             }
1453 +           else
1454 +             {
1455 +               __ret.field[1] = value;
1456 +               __ret.field[2] = symbol;
1457 +             }
1458 +           __ret.field[3] = none;
1459 +         }
1460 +       break;
1461 +      case 2:
1462 +       // 2 The sign follows the value and symbol.
1463 +       if (__space)
1464 +         {
1465 +           // Pattern either ends with sign.
1466 +           if (__precedes)
1467 +             {
1468 +               __ret.field[0] = symbol;
1469 +               __ret.field[2] = value;
1470 +             }
1471 +           else
1472 +             {
1473 +               __ret.field[0] = value;
1474 +               __ret.field[2] = symbol;
1475 +             }
1476 +           __ret.field[1] = space;
1477 +           __ret.field[3] = sign;
1478 +         }
1479 +       else
1480 +         {
1481 +           // Pattern ends with sign then none.
1482 +           if (__precedes)
1483 +             {
1484 +               __ret.field[0] = symbol;
1485 +               __ret.field[1] = value;
1486 +             }
1487 +           else
1488 +             {
1489 +               __ret.field[0] = value;
1490 +               __ret.field[1] = symbol;
1491 +             }
1492 +           __ret.field[2] = sign;
1493 +           __ret.field[3] = none;
1494 +         }
1495 +       break;
1496 +      case 3:
1497 +       // 3 The sign immediately precedes the symbol.
1498 +       if (__precedes)
1499 +         {
1500 +           __ret.field[0] = sign;
1501 +           __ret.field[1] = symbol;        
1502 +           if (__space)
1503 +             {
1504 +               __ret.field[2] = space;
1505 +               __ret.field[3] = value;
1506 +             }
1507 +           else
1508 +             {
1509 +               __ret.field[2] = value;         
1510 +               __ret.field[3] = none;
1511 +             }
1512 +         }
1513 +       else
1514 +         {
1515 +           __ret.field[0] = value;
1516 +           if (__space)
1517 +             {
1518 +               __ret.field[1] = space;
1519 +               __ret.field[2] = sign;
1520 +               __ret.field[3] = symbol;
1521 +             }
1522 +           else
1523 +             {
1524 +               __ret.field[1] = sign;
1525 +               __ret.field[2] = symbol;
1526 +               __ret.field[3] = none;
1527 +             }
1528 +         }
1529 +       break;
1530 +      case 4:
1531 +       // 4 The sign immediately follows the symbol.
1532 +       if (__precedes)
1533 +         {
1534 +           __ret.field[0] = symbol;
1535 +           __ret.field[1] = sign;
1536 +           if (__space)
1537 +             {
1538 +               __ret.field[2] = space;
1539 +               __ret.field[3] = value;
1540 +             }
1541 +           else
1542 +             {
1543 +               __ret.field[2] = value;
1544 +               __ret.field[3] = none;
1545 +             }
1546 +         }
1547 +       else
1548 +         {
1549 +           __ret.field[0] = value;
1550 +           if (__space)
1551 +             {
1552 +               __ret.field[1] = space;
1553 +               __ret.field[2] = symbol;
1554 +               __ret.field[3] = sign;
1555 +             }
1556 +           else
1557 +             {
1558 +               __ret.field[1] = symbol;
1559 +               __ret.field[2] = sign;
1560 +               __ret.field[3] = none;
1561 +             }
1562 +         }
1563 +       break;
1564 +      default:
1565 +       __ret = pattern();
1566 +      }
1567 +    return __ret;
1568 +  }
1569 +
1570 +  template<> 
1571 +    void
1572 +    moneypunct<char, true>::_M_initialize_moneypunct(__c_locale __cloc, 
1573 +                                                    const char*)
1574 +    {
1575 +      if (!_M_data)
1576 +       _M_data = new __moneypunct_cache<char, true>;
1577 +
1578 +      if (!__cloc)
1579 +       {
1580 +         // "C" locale
1581 +         _M_data->_M_decimal_point = '.';
1582 +         _M_data->_M_thousands_sep = ',';
1583 +         _M_data->_M_grouping = "";
1584 +         _M_data->_M_grouping_size = 0;
1585 +         _M_data->_M_curr_symbol = "";
1586 +         _M_data->_M_curr_symbol_size = 0;
1587 +         _M_data->_M_positive_sign = "";
1588 +         _M_data->_M_positive_sign_size = 0;
1589 +         _M_data->_M_negative_sign = "";
1590 +         _M_data->_M_negative_sign_size = 0;
1591 +         _M_data->_M_frac_digits = 0;
1592 +         _M_data->_M_pos_format = money_base::_S_default_pattern;
1593 +         _M_data->_M_neg_format = money_base::_S_default_pattern;
1594 +
1595 +         for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1596 +           _M_data->_M_atoms[__i] = money_base::_S_atoms[__i];
1597 +       }
1598 +      else
1599 +       {
1600 +         // Named locale.
1601 +         _M_data->_M_decimal_point = *(__nl_langinfo_l(__MON_DECIMAL_POINT, 
1602 +                                                       __cloc));
1603 +         _M_data->_M_thousands_sep = *(__nl_langinfo_l(__MON_THOUSANDS_SEP, 
1604 +                                                       __cloc));
1605 +         _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1606 +         _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1607 +         _M_data->_M_positive_sign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1608 +         _M_data->_M_positive_sign_size = strlen(_M_data->_M_positive_sign);
1609 +
1610 +         char __nposn = *(__nl_langinfo_l(__INT_N_SIGN_POSN, __cloc));
1611 +         if (!__nposn)
1612 +           _M_data->_M_negative_sign = "()";
1613 +         else
1614 +           _M_data->_M_negative_sign = __nl_langinfo_l(__NEGATIVE_SIGN, 
1615 +                                                       __cloc);
1616 +         _M_data->_M_negative_sign_size = strlen(_M_data->_M_negative_sign);
1617 +
1618 +         // _Intl == true
1619 +         _M_data->_M_curr_symbol = __nl_langinfo_l(__INT_CURR_SYMBOL, __cloc);
1620 +         _M_data->_M_curr_symbol_size = strlen(_M_data->_M_curr_symbol);
1621 +         _M_data->_M_frac_digits = *(__nl_langinfo_l(__INT_FRAC_DIGITS, 
1622 +                                                     __cloc));
1623 +         char __pprecedes = *(__nl_langinfo_l(__INT_P_CS_PRECEDES, __cloc));
1624 +         char __pspace = *(__nl_langinfo_l(__INT_P_SEP_BY_SPACE, __cloc));
1625 +         char __pposn = *(__nl_langinfo_l(__INT_P_SIGN_POSN, __cloc));
1626 +         _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace, 
1627 +                                                       __pposn);
1628 +         char __nprecedes = *(__nl_langinfo_l(__INT_N_CS_PRECEDES, __cloc));
1629 +         char __nspace = *(__nl_langinfo_l(__INT_N_SEP_BY_SPACE, __cloc));
1630 +         _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace, 
1631 +                                                       __nposn);
1632 +       }
1633 +    }
1634 +
1635 +  template<> 
1636 +    void
1637 +    moneypunct<char, false>::_M_initialize_moneypunct(__c_locale __cloc, 
1638 +                                                     const char*)
1639 +    {
1640 +      if (!_M_data)
1641 +       _M_data = new __moneypunct_cache<char, false>;
1642 +
1643 +      if (!__cloc)
1644 +       {
1645 +         // "C" locale
1646 +         _M_data->_M_decimal_point = '.';
1647 +         _M_data->_M_thousands_sep = ',';
1648 +         _M_data->_M_grouping = "";
1649 +         _M_data->_M_grouping_size = 0;
1650 +         _M_data->_M_curr_symbol = "";
1651 +         _M_data->_M_curr_symbol_size = 0;
1652 +         _M_data->_M_positive_sign = "";
1653 +         _M_data->_M_positive_sign_size = 0;
1654 +         _M_data->_M_negative_sign = "";
1655 +         _M_data->_M_negative_sign_size = 0;
1656 +         _M_data->_M_frac_digits = 0;
1657 +         _M_data->_M_pos_format = money_base::_S_default_pattern;
1658 +         _M_data->_M_neg_format = money_base::_S_default_pattern;
1659 +
1660 +         for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1661 +           _M_data->_M_atoms[__i] = money_base::_S_atoms[__i];
1662 +       }
1663 +      else
1664 +       {
1665 +         // Named locale.
1666 +         _M_data->_M_decimal_point = *(__nl_langinfo_l(__MON_DECIMAL_POINT, 
1667 +                                                       __cloc));
1668 +         _M_data->_M_thousands_sep = *(__nl_langinfo_l(__MON_THOUSANDS_SEP, 
1669 +                                                       __cloc));
1670 +         _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1671 +         _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1672 +         _M_data->_M_positive_sign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1673 +         _M_data->_M_positive_sign_size = strlen(_M_data->_M_positive_sign);
1674 +
1675 +         char __nposn = *(__nl_langinfo_l(__N_SIGN_POSN, __cloc));
1676 +         if (!__nposn)
1677 +           _M_data->_M_negative_sign = "()";
1678 +         else
1679 +           _M_data->_M_negative_sign = __nl_langinfo_l(__NEGATIVE_SIGN,
1680 +                                                       __cloc);
1681 +         _M_data->_M_negative_sign_size = strlen(_M_data->_M_negative_sign);
1682 +
1683 +         // _Intl == false
1684 +         _M_data->_M_curr_symbol = __nl_langinfo_l(__CURRENCY_SYMBOL, __cloc);
1685 +         _M_data->_M_curr_symbol_size = strlen(_M_data->_M_curr_symbol);
1686 +         _M_data->_M_frac_digits = *(__nl_langinfo_l(__FRAC_DIGITS, __cloc));
1687 +         char __pprecedes = *(__nl_langinfo_l(__P_CS_PRECEDES, __cloc));
1688 +         char __pspace = *(__nl_langinfo_l(__P_SEP_BY_SPACE, __cloc));
1689 +         char __pposn = *(__nl_langinfo_l(__P_SIGN_POSN, __cloc));
1690 +         _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace, 
1691 +                                                       __pposn);
1692 +         char __nprecedes = *(__nl_langinfo_l(__N_CS_PRECEDES, __cloc));
1693 +         char __nspace = *(__nl_langinfo_l(__N_SEP_BY_SPACE, __cloc));
1694 +         _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace, 
1695 +                                                       __nposn);
1696 +       }
1697 +    }
1698 +
1699 +  template<> 
1700 +    moneypunct<char, true>::~moneypunct()
1701 +    { delete _M_data; }
1702 +
1703 +  template<> 
1704 +    moneypunct<char, false>::~moneypunct()
1705 +    { delete _M_data; }
1706 +
1707 +#ifdef _GLIBCXX_USE_WCHAR_T
1708 +  template<> 
1709 +    void
1710 +    moneypunct<wchar_t, true>::_M_initialize_moneypunct(__c_locale __cloc, 
1711 +#ifdef __UCLIBC_HAS_XLOCALE__
1712 +                                                       const char*)
1713 +#else
1714 +                                                       const char* __name)
1715 +#endif
1716 +    {
1717 +      if (!_M_data)
1718 +       _M_data = new __moneypunct_cache<wchar_t, true>;
1719 +
1720 +      if (!__cloc)
1721 +       {
1722 +         // "C" locale
1723 +         _M_data->_M_decimal_point = L'.';
1724 +         _M_data->_M_thousands_sep = L',';
1725 +         _M_data->_M_grouping = "";
1726 +         _M_data->_M_grouping_size = 0;
1727 +         _M_data->_M_curr_symbol = L"";
1728 +         _M_data->_M_curr_symbol_size = 0;
1729 +         _M_data->_M_positive_sign = L"";
1730 +         _M_data->_M_positive_sign_size = 0;
1731 +         _M_data->_M_negative_sign = L"";
1732 +         _M_data->_M_negative_sign_size = 0;
1733 +         _M_data->_M_frac_digits = 0;
1734 +         _M_data->_M_pos_format = money_base::_S_default_pattern;
1735 +         _M_data->_M_neg_format = money_base::_S_default_pattern;
1736 +
1737 +         // Use ctype::widen code without the facet...
1738 +         for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1739 +           _M_data->_M_atoms[__i] =
1740 +             static_cast<wchar_t>(money_base::_S_atoms[__i]);
1741 +       }
1742 +      else
1743 +       {
1744 +         // Named locale.
1745 +#ifdef __UCLIBC_HAS_XLOCALE__
1746 +         __c_locale __old = __uselocale(__cloc);
1747 +#else
1748 +         // Switch to named locale so that mbsrtowcs will work.
1749 +         char* __old = strdup(setlocale(LC_ALL, NULL));
1750 +         setlocale(LC_ALL, __name);
1751 +#endif
1752 +
1753 +#ifdef __UCLIBC_MJN3_ONLY__
1754 +#warning fix this... should be monetary
1755 +#endif
1756 +#ifdef __UCLIBC__
1757 +# ifdef __UCLIBC_HAS_XLOCALE__
1758 +         _M_data->_M_decimal_point = __cloc->decimal_point_wc;
1759 +         _M_data->_M_thousands_sep = __cloc->thousands_sep_wc;
1760 +# else
1761 +         _M_data->_M_decimal_point = __global_locale->decimal_point_wc;
1762 +         _M_data->_M_thousands_sep = __global_locale->thousands_sep_wc;
1763 +# endif
1764 +#else
1765 +         union { char *__s; wchar_t __w; } __u;
1766 +         __u.__s = __nl_langinfo_l(_NL_MONETARY_DECIMAL_POINT_WC, __cloc);
1767 +         _M_data->_M_decimal_point = __u.__w;
1768 +
1769 +         __u.__s = __nl_langinfo_l(_NL_MONETARY_THOUSANDS_SEP_WC, __cloc);
1770 +         _M_data->_M_thousands_sep = __u.__w;
1771 +#endif
1772 +         _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1773 +         _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1774 +
1775 +         const char* __cpossign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1776 +         const char* __cnegsign = __nl_langinfo_l(__NEGATIVE_SIGN, __cloc);
1777 +         const char* __ccurr = __nl_langinfo_l(__INT_CURR_SYMBOL, __cloc);
1778 +
1779 +         wchar_t* __wcs_ps = 0;
1780 +         wchar_t* __wcs_ns = 0;
1781 +         const char __nposn = *(__nl_langinfo_l(__INT_N_SIGN_POSN, __cloc));
1782 +         try
1783 +           {
1784 +             mbstate_t __state;
1785 +             size_t __len = strlen(__cpossign);
1786 +             if (__len)
1787 +               {
1788 +                 ++__len;
1789 +                 memset(&__state, 0, sizeof(mbstate_t));
1790 +                 __wcs_ps = new wchar_t[__len];
1791 +                 mbsrtowcs(__wcs_ps, &__cpossign, __len, &__state);
1792 +                 _M_data->_M_positive_sign = __wcs_ps;
1793 +               }
1794 +             else
1795 +               _M_data->_M_positive_sign = L"";
1796 +             _M_data->_M_positive_sign_size = wcslen(_M_data->_M_positive_sign);
1797 +             
1798 +             __len = strlen(__cnegsign);
1799 +             if (!__nposn)
1800 +               _M_data->_M_negative_sign = L"()";
1801 +             else if (__len)
1802 +               { 
1803 +                 ++__len;
1804 +                 memset(&__state, 0, sizeof(mbstate_t));
1805 +                 __wcs_ns = new wchar_t[__len];
1806 +                 mbsrtowcs(__wcs_ns, &__cnegsign, __len, &__state);
1807 +                 _M_data->_M_negative_sign = __wcs_ns;
1808 +               }
1809 +             else
1810 +               _M_data->_M_negative_sign = L"";
1811 +             _M_data->_M_negative_sign_size = wcslen(_M_data->_M_negative_sign);
1812 +             
1813 +             // _Intl == true.
1814 +             __len = strlen(__ccurr);
1815 +             if (__len)
1816 +               {
1817 +                 ++__len;
1818 +                 memset(&__state, 0, sizeof(mbstate_t));
1819 +                 wchar_t* __wcs = new wchar_t[__len];
1820 +                 mbsrtowcs(__wcs, &__ccurr, __len, &__state);
1821 +                 _M_data->_M_curr_symbol = __wcs;
1822 +               }
1823 +             else
1824 +               _M_data->_M_curr_symbol = L"";
1825 +             _M_data->_M_curr_symbol_size = wcslen(_M_data->_M_curr_symbol);
1826 +           }
1827 +         catch (...)
1828 +           {
1829 +             delete _M_data;
1830 +             _M_data = 0;
1831 +             delete __wcs_ps;
1832 +             delete __wcs_ns;        
1833 +#ifdef __UCLIBC_HAS_XLOCALE__
1834 +             __uselocale(__old);
1835 +#else
1836 +             setlocale(LC_ALL, __old);
1837 +             free(__old);
1838 +#endif
1839 +             __throw_exception_again;
1840 +           } 
1841 +         
1842 +         _M_data->_M_frac_digits = *(__nl_langinfo_l(__INT_FRAC_DIGITS, 
1843 +                                                     __cloc));
1844 +         char __pprecedes = *(__nl_langinfo_l(__INT_P_CS_PRECEDES, __cloc));
1845 +         char __pspace = *(__nl_langinfo_l(__INT_P_SEP_BY_SPACE, __cloc));
1846 +         char __pposn = *(__nl_langinfo_l(__INT_P_SIGN_POSN, __cloc));
1847 +         _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace, 
1848 +                                                       __pposn);
1849 +         char __nprecedes = *(__nl_langinfo_l(__INT_N_CS_PRECEDES, __cloc));
1850 +         char __nspace = *(__nl_langinfo_l(__INT_N_SEP_BY_SPACE, __cloc));
1851 +         _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace, 
1852 +                                                       __nposn);
1853 +
1854 +#ifdef __UCLIBC_HAS_XLOCALE__
1855 +         __uselocale(__old);
1856 +#else
1857 +         setlocale(LC_ALL, __old);
1858 +         free(__old);
1859 +#endif
1860 +       }
1861 +    }
1862 +
1863 +  template<> 
1864 +  void
1865 +  moneypunct<wchar_t, false>::_M_initialize_moneypunct(__c_locale __cloc,
1866 +#ifdef __UCLIBC_HAS_XLOCALE__
1867 +                                                      const char*)
1868 +#else
1869 +                                                       const char* __name)
1870 +#endif
1871 +  {
1872 +    if (!_M_data)
1873 +      _M_data = new __moneypunct_cache<wchar_t, false>;
1874 +
1875 +    if (!__cloc)
1876 +       {
1877 +         // "C" locale
1878 +         _M_data->_M_decimal_point = L'.';
1879 +         _M_data->_M_thousands_sep = L',';
1880 +         _M_data->_M_grouping = "";
1881 +          _M_data->_M_grouping_size = 0;
1882 +         _M_data->_M_curr_symbol = L"";
1883 +         _M_data->_M_curr_symbol_size = 0;
1884 +         _M_data->_M_positive_sign = L"";
1885 +         _M_data->_M_positive_sign_size = 0;
1886 +         _M_data->_M_negative_sign = L"";
1887 +         _M_data->_M_negative_sign_size = 0;
1888 +         _M_data->_M_frac_digits = 0;
1889 +         _M_data->_M_pos_format = money_base::_S_default_pattern;
1890 +         _M_data->_M_neg_format = money_base::_S_default_pattern;
1891 +
1892 +         // Use ctype::widen code without the facet...
1893 +         for (size_t __i = 0; __i < money_base::_S_end; ++__i)
1894 +           _M_data->_M_atoms[__i] =
1895 +             static_cast<wchar_t>(money_base::_S_atoms[__i]);
1896 +       }
1897 +      else
1898 +       {
1899 +         // Named locale.
1900 +#ifdef __UCLIBC_HAS_XLOCALE__
1901 +         __c_locale __old = __uselocale(__cloc);
1902 +#else
1903 +         // Switch to named locale so that mbsrtowcs will work.
1904 +         char* __old = strdup(setlocale(LC_ALL, NULL));
1905 +         setlocale(LC_ALL, __name);
1906 +#endif
1907 +
1908 +#ifdef __UCLIBC_MJN3_ONLY__
1909 +#warning fix this... should be monetary
1910 +#endif
1911 +#ifdef __UCLIBC__
1912 +# ifdef __UCLIBC_HAS_XLOCALE__
1913 +         _M_data->_M_decimal_point = __cloc->decimal_point_wc;
1914 +         _M_data->_M_thousands_sep = __cloc->thousands_sep_wc;
1915 +# else
1916 +         _M_data->_M_decimal_point = __global_locale->decimal_point_wc;
1917 +         _M_data->_M_thousands_sep = __global_locale->thousands_sep_wc;
1918 +# endif
1919 +#else
1920 +          union { char *__s; wchar_t __w; } __u;
1921 +         __u.__s = __nl_langinfo_l(_NL_MONETARY_DECIMAL_POINT_WC, __cloc);
1922 +         _M_data->_M_decimal_point = __u.__w;
1923 +
1924 +         __u.__s = __nl_langinfo_l(_NL_MONETARY_THOUSANDS_SEP_WC, __cloc);
1925 +         _M_data->_M_thousands_sep = __u.__w;
1926 +#endif
1927 +         _M_data->_M_grouping = __nl_langinfo_l(__MON_GROUPING, __cloc);
1928 +          _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
1929 +
1930 +         const char* __cpossign = __nl_langinfo_l(__POSITIVE_SIGN, __cloc);
1931 +         const char* __cnegsign = __nl_langinfo_l(__NEGATIVE_SIGN, __cloc);
1932 +         const char* __ccurr = __nl_langinfo_l(__CURRENCY_SYMBOL, __cloc);
1933 +
1934 +         wchar_t* __wcs_ps = 0;
1935 +         wchar_t* __wcs_ns = 0;
1936 +         const char __nposn = *(__nl_langinfo_l(__N_SIGN_POSN, __cloc));
1937 +         try
1938 +            {
1939 +              mbstate_t __state;
1940 +              size_t __len;
1941 +              __len = strlen(__cpossign);
1942 +              if (__len)
1943 +                {
1944 +                 ++__len;
1945 +                 memset(&__state, 0, sizeof(mbstate_t));
1946 +                 __wcs_ps = new wchar_t[__len];
1947 +                 mbsrtowcs(__wcs_ps, &__cpossign, __len, &__state);
1948 +                 _M_data->_M_positive_sign = __wcs_ps;
1949 +               }
1950 +             else
1951 +               _M_data->_M_positive_sign = L"";
1952 +              _M_data->_M_positive_sign_size = wcslen(_M_data->_M_positive_sign);
1953 +             
1954 +             __len = strlen(__cnegsign);
1955 +             if (!__nposn)
1956 +               _M_data->_M_negative_sign = L"()";
1957 +             else if (__len)
1958 +               { 
1959 +                 ++__len;
1960 +                 memset(&__state, 0, sizeof(mbstate_t));
1961 +                 __wcs_ns = new wchar_t[__len];
1962 +                 mbsrtowcs(__wcs_ns, &__cnegsign, __len, &__state);
1963 +                 _M_data->_M_negative_sign = __wcs_ns;
1964 +               }
1965 +             else
1966 +               _M_data->_M_negative_sign = L"";
1967 +              _M_data->_M_negative_sign_size = wcslen(_M_data->_M_negative_sign);
1968 +
1969 +             // _Intl == true.
1970 +             __len = strlen(__ccurr);
1971 +             if (__len)
1972 +               {
1973 +                 ++__len;
1974 +                 memset(&__state, 0, sizeof(mbstate_t));
1975 +                 wchar_t* __wcs = new wchar_t[__len];
1976 +                 mbsrtowcs(__wcs, &__ccurr, __len, &__state);
1977 +                 _M_data->_M_curr_symbol = __wcs;
1978 +               }
1979 +             else
1980 +               _M_data->_M_curr_symbol = L"";
1981 +              _M_data->_M_curr_symbol_size = wcslen(_M_data->_M_curr_symbol);
1982 +           }
1983 +          catch (...)
1984 +           {
1985 +             delete _M_data;
1986 +              _M_data = 0;
1987 +             delete __wcs_ps;
1988 +             delete __wcs_ns;        
1989 +#ifdef __UCLIBC_HAS_XLOCALE__
1990 +             __uselocale(__old);
1991 +#else
1992 +             setlocale(LC_ALL, __old);
1993 +             free(__old);
1994 +#endif
1995 +              __throw_exception_again;
1996 +           }
1997 +
1998 +         _M_data->_M_frac_digits = *(__nl_langinfo_l(__FRAC_DIGITS, __cloc));
1999 +         char __pprecedes = *(__nl_langinfo_l(__P_CS_PRECEDES, __cloc));
2000 +         char __pspace = *(__nl_langinfo_l(__P_SEP_BY_SPACE, __cloc));
2001 +         char __pposn = *(__nl_langinfo_l(__P_SIGN_POSN, __cloc));
2002 +         _M_data->_M_pos_format = _S_construct_pattern(__pprecedes, __pspace, 
2003 +                                                       __pposn);
2004 +         char __nprecedes = *(__nl_langinfo_l(__N_CS_PRECEDES, __cloc));
2005 +         char __nspace = *(__nl_langinfo_l(__N_SEP_BY_SPACE, __cloc));
2006 +         _M_data->_M_neg_format = _S_construct_pattern(__nprecedes, __nspace, 
2007 +                                                       __nposn);
2008 +
2009 +#ifdef __UCLIBC_HAS_XLOCALE__
2010 +         __uselocale(__old);
2011 +#else
2012 +         setlocale(LC_ALL, __old);
2013 +         free(__old);
2014 +#endif
2015 +       }
2016 +    }
2017 +
2018 +  template<> 
2019 +    moneypunct<wchar_t, true>::~moneypunct()
2020 +    {
2021 +      if (_M_data->_M_positive_sign_size)
2022 +       delete [] _M_data->_M_positive_sign;
2023 +      if (_M_data->_M_negative_sign_size
2024 +          && wcscmp(_M_data->_M_negative_sign, L"()") != 0)
2025 +       delete [] _M_data->_M_negative_sign;
2026 +      if (_M_data->_M_curr_symbol_size)
2027 +       delete [] _M_data->_M_curr_symbol;
2028 +      delete _M_data;
2029 +    }
2030 +
2031 +  template<> 
2032 +    moneypunct<wchar_t, false>::~moneypunct()
2033 +    {
2034 +      if (_M_data->_M_positive_sign_size)
2035 +       delete [] _M_data->_M_positive_sign;
2036 +      if (_M_data->_M_negative_sign_size
2037 +          && wcscmp(_M_data->_M_negative_sign, L"()") != 0)
2038 +       delete [] _M_data->_M_negative_sign;
2039 +      if (_M_data->_M_curr_symbol_size)
2040 +       delete [] _M_data->_M_curr_symbol;
2041 +      delete _M_data;
2042 +    }
2043 +#endif
2044 +}
2045 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/numeric_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/numeric_members.cc
2046 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/numeric_members.cc 1969-12-31 17:00:00.000000000 -0700
2047 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/numeric_members.cc      2006-03-25 22:18:37.000000000 -0700
2048 @@ -0,0 +1,173 @@
2049 +// std::numpunct implementation details, GNU version -*- C++ -*-
2050 +
2051 +// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
2052 +//
2053 +// This file is part of the GNU ISO C++ Library.  This library is free
2054 +// software; you can redistribute it and/or modify it under the
2055 +// terms of the GNU General Public License as published by the
2056 +// Free Software Foundation; either version 2, or (at your option)
2057 +// any later version.
2058 +
2059 +// This library is distributed in the hope that it will be useful,
2060 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2061 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2062 +// GNU General Public License for more details.
2063 +
2064 +// You should have received a copy of the GNU General Public License along
2065 +// with this library; see the file COPYING.  If not, write to the Free
2066 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
2067 +// USA.
2068 +
2069 +// As a special exception, you may use this file as part of a free software
2070 +// library without restriction.  Specifically, if other files instantiate
2071 +// templates or use macros or inline functions from this file, or you compile
2072 +// this file and link it with other files to produce an executable, this
2073 +// file does not by itself cause the resulting executable to be covered by
2074 +// the GNU General Public License.  This exception does not however
2075 +// invalidate any other reasons why the executable file might be covered by
2076 +// the GNU General Public License.
2077 +
2078 +//
2079 +// ISO C++ 14882: 22.2.3.1.2  numpunct virtual functions
2080 +//
2081 +
2082 +// Written by Benjamin Kosnik <bkoz@redhat.com>
2083 +
2084 +#define _LIBC
2085 +#include <locale>
2086 +#undef _LIBC
2087 +#include <bits/c++locale_internal.h>
2088 +
2089 +#ifdef __UCLIBC_MJN3_ONLY__
2090 +#warning tailor for stub locale support
2091 +#endif
2092 +#ifndef __UCLIBC_HAS_XLOCALE__
2093 +#define __nl_langinfo_l(N, L)         nl_langinfo((N))
2094 +#endif
2095 +
2096 +namespace std
2097 +{
2098 +  template<> 
2099 +    void
2100 +    numpunct<char>::_M_initialize_numpunct(__c_locale __cloc)
2101 +    {
2102 +      if (!_M_data)
2103 +       _M_data = new __numpunct_cache<char>;
2104 +
2105 +      if (!__cloc)
2106 +       {
2107 +         // "C" locale
2108 +         _M_data->_M_grouping = "";
2109 +         _M_data->_M_grouping_size = 0;
2110 +         _M_data->_M_use_grouping = false;
2111 +
2112 +         _M_data->_M_decimal_point = '.';
2113 +         _M_data->_M_thousands_sep = ',';
2114 +
2115 +         for (size_t __i = 0; __i < __num_base::_S_oend; ++__i)
2116 +           _M_data->_M_atoms_out[__i] = __num_base::_S_atoms_out[__i];
2117 +
2118 +         for (size_t __j = 0; __j < __num_base::_S_iend; ++__j)
2119 +           _M_data->_M_atoms_in[__j] = __num_base::_S_atoms_in[__j];
2120 +       }
2121 +      else
2122 +       {
2123 +         // Named locale.
2124 +         _M_data->_M_decimal_point = *(__nl_langinfo_l(DECIMAL_POINT, 
2125 +                                                       __cloc));
2126 +         _M_data->_M_thousands_sep = *(__nl_langinfo_l(THOUSANDS_SEP, 
2127 +                                                       __cloc));
2128 +
2129 +         // Check for NULL, which implies no grouping.
2130 +         if (_M_data->_M_thousands_sep == '\0')
2131 +           _M_data->_M_grouping = "";
2132 +         else
2133 +           _M_data->_M_grouping = __nl_langinfo_l(GROUPING, __cloc);
2134 +         _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
2135 +       }
2136 +
2137 +      // NB: There is no way to extact this info from posix locales.
2138 +      // _M_truename = __nl_langinfo_l(YESSTR, __cloc);
2139 +      _M_data->_M_truename = "true";
2140 +      _M_data->_M_truename_size = 4;
2141 +      // _M_falsename = __nl_langinfo_l(NOSTR, __cloc);
2142 +      _M_data->_M_falsename = "false";
2143 +      _M_data->_M_falsename_size = 5;
2144 +    }
2145
2146 +  template<> 
2147 +    numpunct<char>::~numpunct()
2148 +    { delete _M_data; }
2149 +   
2150 +#ifdef _GLIBCXX_USE_WCHAR_T
2151 +  template<> 
2152 +    void
2153 +    numpunct<wchar_t>::_M_initialize_numpunct(__c_locale __cloc)
2154 +    {
2155 +      if (!_M_data)
2156 +       _M_data = new __numpunct_cache<wchar_t>;
2157 +
2158 +      if (!__cloc)
2159 +       {
2160 +         // "C" locale
2161 +         _M_data->_M_grouping = "";
2162 +         _M_data->_M_grouping_size = 0;
2163 +         _M_data->_M_use_grouping = false;
2164 +
2165 +         _M_data->_M_decimal_point = L'.';
2166 +         _M_data->_M_thousands_sep = L',';
2167 +
2168 +         // Use ctype::widen code without the facet...
2169 +         for (size_t __i = 0; __i < __num_base::_S_oend; ++__i)
2170 +           _M_data->_M_atoms_out[__i] =
2171 +             static_cast<wchar_t>(__num_base::_S_atoms_out[__i]);
2172 +
2173 +         for (size_t __j = 0; __j < __num_base::_S_iend; ++__j)
2174 +           _M_data->_M_atoms_in[__j] =
2175 +             static_cast<wchar_t>(__num_base::_S_atoms_in[__j]);
2176 +       }
2177 +      else
2178 +       {
2179 +         // Named locale.
2180 +         // NB: In the GNU model wchar_t is always 32 bit wide.
2181 +#ifdef __UCLIBC_MJN3_ONLY__
2182 +#warning fix this
2183 +#endif
2184 +#ifdef __UCLIBC__
2185 +# ifdef __UCLIBC_HAS_XLOCALE__
2186 +         _M_data->_M_decimal_point = __cloc->decimal_point_wc;
2187 +         _M_data->_M_thousands_sep = __cloc->thousands_sep_wc;
2188 +# else
2189 +         _M_data->_M_decimal_point = __global_locale->decimal_point_wc;
2190 +         _M_data->_M_thousands_sep = __global_locale->thousands_sep_wc;
2191 +# endif
2192 +#else
2193 +         union { char *__s; wchar_t __w; } __u;
2194 +         __u.__s = __nl_langinfo_l(_NL_NUMERIC_DECIMAL_POINT_WC, __cloc);
2195 +         _M_data->_M_decimal_point = __u.__w;
2196 +
2197 +         __u.__s = __nl_langinfo_l(_NL_NUMERIC_THOUSANDS_SEP_WC, __cloc);
2198 +         _M_data->_M_thousands_sep = __u.__w;
2199 +#endif
2200 +
2201 +         if (_M_data->_M_thousands_sep == L'\0')
2202 +           _M_data->_M_grouping = "";
2203 +         else
2204 +           _M_data->_M_grouping = __nl_langinfo_l(GROUPING, __cloc);
2205 +         _M_data->_M_grouping_size = strlen(_M_data->_M_grouping);
2206 +       }
2207 +
2208 +      // NB: There is no way to extact this info from posix locales.
2209 +      // _M_truename = __nl_langinfo_l(YESSTR, __cloc);
2210 +      _M_data->_M_truename = L"true";
2211 +      _M_data->_M_truename_size = 4;
2212 +      // _M_falsename = __nl_langinfo_l(NOSTR, __cloc);
2213 +      _M_data->_M_falsename = L"false";
2214 +      _M_data->_M_falsename_size = 5;
2215 +    }
2216 +
2217 +  template<> 
2218 +    numpunct<wchar_t>::~numpunct()
2219 +    { delete _M_data; }
2220 + #endif
2221 +}
2222 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/time_members.cc gcc-4.1.0/libstdc++-v3/config/locale/uclibc/time_members.cc
2223 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/time_members.cc    1969-12-31 17:00:00.000000000 -0700
2224 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/time_members.cc 2006-03-25 22:18:37.000000000 -0700
2225 @@ -0,0 +1,406 @@
2226 +// std::time_get, std::time_put implementation, GNU version -*- C++ -*-
2227 +
2228 +// Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
2229 +//
2230 +// This file is part of the GNU ISO C++ Library.  This library is free
2231 +// software; you can redistribute it and/or modify it under the
2232 +// terms of the GNU General Public License as published by the
2233 +// Free Software Foundation; either version 2, or (at your option)
2234 +// any later version.
2235 +
2236 +// This library is distributed in the hope that it will be useful,
2237 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2238 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2239 +// GNU General Public License for more details.
2240 +
2241 +// You should have received a copy of the GNU General Public License along
2242 +// with this library; see the file COPYING.  If not, write to the Free
2243 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
2244 +// USA.
2245 +
2246 +// As a special exception, you may use this file as part of a free software
2247 +// library without restriction.  Specifically, if other files instantiate
2248 +// templates or use macros or inline functions from this file, or you compile
2249 +// this file and link it with other files to produce an executable, this
2250 +// file does not by itself cause the resulting executable to be covered by
2251 +// the GNU General Public License.  This exception does not however
2252 +// invalidate any other reasons why the executable file might be covered by
2253 +// the GNU General Public License.
2254 +
2255 +//
2256 +// ISO C++ 14882: 22.2.5.1.2 - time_get virtual functions
2257 +// ISO C++ 14882: 22.2.5.3.2 - time_put virtual functions
2258 +//
2259 +
2260 +// Written by Benjamin Kosnik <bkoz@redhat.com>
2261 +
2262 +#include <locale>
2263 +#include <bits/c++locale_internal.h>
2264 +
2265 +#ifdef __UCLIBC_MJN3_ONLY__
2266 +#warning tailor for stub locale support
2267 +#endif
2268 +#ifndef __UCLIBC_HAS_XLOCALE__
2269 +#define __nl_langinfo_l(N, L)         nl_langinfo((N))
2270 +#endif
2271 +
2272 +namespace std
2273 +{
2274 +  template<>
2275 +    void
2276 +    __timepunct<char>::
2277 +    _M_put(char* __s, size_t __maxlen, const char* __format, 
2278 +          const tm* __tm) const
2279 +    {
2280 +#ifdef __UCLIBC_HAS_XLOCALE__
2281 +      const size_t __len = __strftime_l(__s, __maxlen, __format, __tm,
2282 +                                       _M_c_locale_timepunct);
2283 +#else
2284 +      char* __old = strdup(setlocale(LC_ALL, NULL));
2285 +      setlocale(LC_ALL, _M_name_timepunct);
2286 +      const size_t __len = strftime(__s, __maxlen, __format, __tm);
2287 +      setlocale(LC_ALL, __old);
2288 +      free(__old);
2289 +#endif
2290 +      // Make sure __s is null terminated.
2291 +      if (__len == 0)
2292 +       __s[0] = '\0';
2293 +    }
2294 +
2295 +  template<> 
2296 +    void
2297 +    __timepunct<char>::_M_initialize_timepunct(__c_locale __cloc)
2298 +    {
2299 +      if (!_M_data)
2300 +       _M_data = new __timepunct_cache<char>;
2301 +
2302 +      if (!__cloc)
2303 +       {
2304 +         // "C" locale
2305 +         _M_c_locale_timepunct = _S_get_c_locale();
2306 +
2307 +         _M_data->_M_date_format = "%m/%d/%y";
2308 +         _M_data->_M_date_era_format = "%m/%d/%y";
2309 +         _M_data->_M_time_format = "%H:%M:%S";
2310 +         _M_data->_M_time_era_format = "%H:%M:%S";
2311 +         _M_data->_M_date_time_format = "";
2312 +         _M_data->_M_date_time_era_format = "";
2313 +         _M_data->_M_am = "AM";
2314 +         _M_data->_M_pm = "PM";
2315 +         _M_data->_M_am_pm_format = "";
2316 +
2317 +         // Day names, starting with "C"'s Sunday.
2318 +         _M_data->_M_day1 = "Sunday";
2319 +         _M_data->_M_day2 = "Monday";
2320 +         _M_data->_M_day3 = "Tuesday";
2321 +         _M_data->_M_day4 = "Wednesday";
2322 +         _M_data->_M_day5 = "Thursday";
2323 +         _M_data->_M_day6 = "Friday";
2324 +         _M_data->_M_day7 = "Saturday";
2325 +
2326 +         // Abbreviated day names, starting with "C"'s Sun.
2327 +         _M_data->_M_aday1 = "Sun";
2328 +         _M_data->_M_aday2 = "Mon";
2329 +         _M_data->_M_aday3 = "Tue";
2330 +         _M_data->_M_aday4 = "Wed";
2331 +         _M_data->_M_aday5 = "Thu";
2332 +         _M_data->_M_aday6 = "Fri";
2333 +         _M_data->_M_aday7 = "Sat";
2334 +
2335 +         // Month names, starting with "C"'s January.
2336 +         _M_data->_M_month01 = "January";
2337 +         _M_data->_M_month02 = "February";
2338 +         _M_data->_M_month03 = "March";
2339 +         _M_data->_M_month04 = "April";
2340 +         _M_data->_M_month05 = "May";
2341 +         _M_data->_M_month06 = "June";
2342 +         _M_data->_M_month07 = "July";
2343 +         _M_data->_M_month08 = "August";
2344 +         _M_data->_M_month09 = "September";
2345 +         _M_data->_M_month10 = "October";
2346 +         _M_data->_M_month11 = "November";
2347 +         _M_data->_M_month12 = "December";
2348 +
2349 +         // Abbreviated month names, starting with "C"'s Jan.
2350 +         _M_data->_M_amonth01 = "Jan";
2351 +         _M_data->_M_amonth02 = "Feb";
2352 +         _M_data->_M_amonth03 = "Mar";
2353 +         _M_data->_M_amonth04 = "Apr";
2354 +         _M_data->_M_amonth05 = "May";
2355 +         _M_data->_M_amonth06 = "Jun";
2356 +         _M_data->_M_amonth07 = "Jul";
2357 +         _M_data->_M_amonth08 = "Aug";
2358 +         _M_data->_M_amonth09 = "Sep";
2359 +         _M_data->_M_amonth10 = "Oct";
2360 +         _M_data->_M_amonth11 = "Nov";
2361 +         _M_data->_M_amonth12 = "Dec";
2362 +       }
2363 +      else
2364 +       {
2365 +         _M_c_locale_timepunct = _S_clone_c_locale(__cloc); 
2366 +
2367 +         _M_data->_M_date_format = __nl_langinfo_l(D_FMT, __cloc);
2368 +         _M_data->_M_date_era_format = __nl_langinfo_l(ERA_D_FMT, __cloc);
2369 +         _M_data->_M_time_format = __nl_langinfo_l(T_FMT, __cloc);
2370 +         _M_data->_M_time_era_format = __nl_langinfo_l(ERA_T_FMT, __cloc);
2371 +         _M_data->_M_date_time_format = __nl_langinfo_l(D_T_FMT, __cloc);
2372 +         _M_data->_M_date_time_era_format = __nl_langinfo_l(ERA_D_T_FMT,
2373 +                                                            __cloc);
2374 +         _M_data->_M_am = __nl_langinfo_l(AM_STR, __cloc);
2375 +         _M_data->_M_pm = __nl_langinfo_l(PM_STR, __cloc);
2376 +         _M_data->_M_am_pm_format = __nl_langinfo_l(T_FMT_AMPM, __cloc);
2377 +
2378 +         // Day names, starting with "C"'s Sunday.
2379 +         _M_data->_M_day1 = __nl_langinfo_l(DAY_1, __cloc);
2380 +         _M_data->_M_day2 = __nl_langinfo_l(DAY_2, __cloc);
2381 +         _M_data->_M_day3 = __nl_langinfo_l(DAY_3, __cloc);
2382 +         _M_data->_M_day4 = __nl_langinfo_l(DAY_4, __cloc);
2383 +         _M_data->_M_day5 = __nl_langinfo_l(DAY_5, __cloc);
2384 +         _M_data->_M_day6 = __nl_langinfo_l(DAY_6, __cloc);
2385 +         _M_data->_M_day7 = __nl_langinfo_l(DAY_7, __cloc);
2386 +
2387 +         // Abbreviated day names, starting with "C"'s Sun.
2388 +         _M_data->_M_aday1 = __nl_langinfo_l(ABDAY_1, __cloc);
2389 +         _M_data->_M_aday2 = __nl_langinfo_l(ABDAY_2, __cloc);
2390 +         _M_data->_M_aday3 = __nl_langinfo_l(ABDAY_3, __cloc);
2391 +         _M_data->_M_aday4 = __nl_langinfo_l(ABDAY_4, __cloc);
2392 +         _M_data->_M_aday5 = __nl_langinfo_l(ABDAY_5, __cloc);
2393 +         _M_data->_M_aday6 = __nl_langinfo_l(ABDAY_6, __cloc);
2394 +         _M_data->_M_aday7 = __nl_langinfo_l(ABDAY_7, __cloc);
2395 +
2396 +         // Month names, starting with "C"'s January.
2397 +         _M_data->_M_month01 = __nl_langinfo_l(MON_1, __cloc);
2398 +         _M_data->_M_month02 = __nl_langinfo_l(MON_2, __cloc);
2399 +         _M_data->_M_month03 = __nl_langinfo_l(MON_3, __cloc);
2400 +         _M_data->_M_month04 = __nl_langinfo_l(MON_4, __cloc);
2401 +         _M_data->_M_month05 = __nl_langinfo_l(MON_5, __cloc);
2402 +         _M_data->_M_month06 = __nl_langinfo_l(MON_6, __cloc);
2403 +         _M_data->_M_month07 = __nl_langinfo_l(MON_7, __cloc);
2404 +         _M_data->_M_month08 = __nl_langinfo_l(MON_8, __cloc);
2405 +         _M_data->_M_month09 = __nl_langinfo_l(MON_9, __cloc);
2406 +         _M_data->_M_month10 = __nl_langinfo_l(MON_10, __cloc);
2407 +         _M_data->_M_month11 = __nl_langinfo_l(MON_11, __cloc);
2408 +         _M_data->_M_month12 = __nl_langinfo_l(MON_12, __cloc);
2409 +
2410 +         // Abbreviated month names, starting with "C"'s Jan.
2411 +         _M_data->_M_amonth01 = __nl_langinfo_l(ABMON_1, __cloc);
2412 +         _M_data->_M_amonth02 = __nl_langinfo_l(ABMON_2, __cloc);
2413 +         _M_data->_M_amonth03 = __nl_langinfo_l(ABMON_3, __cloc);
2414 +         _M_data->_M_amonth04 = __nl_langinfo_l(ABMON_4, __cloc);
2415 +         _M_data->_M_amonth05 = __nl_langinfo_l(ABMON_5, __cloc);
2416 +         _M_data->_M_amonth06 = __nl_langinfo_l(ABMON_6, __cloc);
2417 +         _M_data->_M_amonth07 = __nl_langinfo_l(ABMON_7, __cloc);
2418 +         _M_data->_M_amonth08 = __nl_langinfo_l(ABMON_8, __cloc);
2419 +         _M_data->_M_amonth09 = __nl_langinfo_l(ABMON_9, __cloc);
2420 +         _M_data->_M_amonth10 = __nl_langinfo_l(ABMON_10, __cloc);
2421 +         _M_data->_M_amonth11 = __nl_langinfo_l(ABMON_11, __cloc);
2422 +         _M_data->_M_amonth12 = __nl_langinfo_l(ABMON_12, __cloc);
2423 +       }
2424 +    }
2425 +
2426 +#ifdef _GLIBCXX_USE_WCHAR_T
2427 +  template<>
2428 +    void
2429 +    __timepunct<wchar_t>::
2430 +    _M_put(wchar_t* __s, size_t __maxlen, const wchar_t* __format, 
2431 +          const tm* __tm) const
2432 +    {
2433 +#ifdef __UCLIBC_HAS_XLOCALE__
2434 +      __wcsftime_l(__s, __maxlen, __format, __tm, _M_c_locale_timepunct);
2435 +      const size_t __len = __wcsftime_l(__s, __maxlen, __format, __tm,
2436 +                                       _M_c_locale_timepunct);
2437 +#else
2438 +      char* __old = strdup(setlocale(LC_ALL, NULL));
2439 +      setlocale(LC_ALL, _M_name_timepunct);
2440 +      const size_t __len = wcsftime(__s, __maxlen, __format, __tm);
2441 +      setlocale(LC_ALL, __old);
2442 +      free(__old);
2443 +#endif
2444 +      // Make sure __s is null terminated.
2445 +      if (__len == 0)
2446 +       __s[0] = L'\0';
2447 +    }
2448 +
2449 +  template<> 
2450 +    void
2451 +    __timepunct<wchar_t>::_M_initialize_timepunct(__c_locale __cloc)
2452 +    {
2453 +      if (!_M_data)
2454 +       _M_data = new __timepunct_cache<wchar_t>;
2455 +
2456 +#warning wide time stuff
2457 +//       if (!__cloc)
2458 +       {
2459 +         // "C" locale
2460 +         _M_c_locale_timepunct = _S_get_c_locale();
2461 +
2462 +         _M_data->_M_date_format = L"%m/%d/%y";
2463 +         _M_data->_M_date_era_format = L"%m/%d/%y";
2464 +         _M_data->_M_time_format = L"%H:%M:%S";
2465 +         _M_data->_M_time_era_format = L"%H:%M:%S";
2466 +         _M_data->_M_date_time_format = L"";
2467 +         _M_data->_M_date_time_era_format = L"";
2468 +         _M_data->_M_am = L"AM";
2469 +         _M_data->_M_pm = L"PM";
2470 +         _M_data->_M_am_pm_format = L"";
2471 +
2472 +         // Day names, starting with "C"'s Sunday.
2473 +         _M_data->_M_day1 = L"Sunday";
2474 +         _M_data->_M_day2 = L"Monday";
2475 +         _M_data->_M_day3 = L"Tuesday";
2476 +         _M_data->_M_day4 = L"Wednesday";
2477 +         _M_data->_M_day5 = L"Thursday";
2478 +         _M_data->_M_day6 = L"Friday";
2479 +         _M_data->_M_day7 = L"Saturday";
2480 +
2481 +         // Abbreviated day names, starting with "C"'s Sun.
2482 +         _M_data->_M_aday1 = L"Sun";
2483 +         _M_data->_M_aday2 = L"Mon";
2484 +         _M_data->_M_aday3 = L"Tue";
2485 +         _M_data->_M_aday4 = L"Wed";
2486 +         _M_data->_M_aday5 = L"Thu";
2487 +         _M_data->_M_aday6 = L"Fri";
2488 +         _M_data->_M_aday7 = L"Sat";
2489 +
2490 +         // Month names, starting with "C"'s January.
2491 +         _M_data->_M_month01 = L"January";
2492 +         _M_data->_M_month02 = L"February";
2493 +         _M_data->_M_month03 = L"March";
2494 +         _M_data->_M_month04 = L"April";
2495 +         _M_data->_M_month05 = L"May";
2496 +         _M_data->_M_month06 = L"June";
2497 +         _M_data->_M_month07 = L"July";
2498 +         _M_data->_M_month08 = L"August";
2499 +         _M_data->_M_month09 = L"September";
2500 +         _M_data->_M_month10 = L"October";
2501 +         _M_data->_M_month11 = L"November";
2502 +         _M_data->_M_month12 = L"December";
2503 +
2504 +         // Abbreviated month names, starting with "C"'s Jan.
2505 +         _M_data->_M_amonth01 = L"Jan";
2506 +         _M_data->_M_amonth02 = L"Feb";
2507 +         _M_data->_M_amonth03 = L"Mar";
2508 +         _M_data->_M_amonth04 = L"Apr";
2509 +         _M_data->_M_amonth05 = L"May";
2510 +         _M_data->_M_amonth06 = L"Jun";
2511 +         _M_data->_M_amonth07 = L"Jul";
2512 +         _M_data->_M_amonth08 = L"Aug";
2513 +         _M_data->_M_amonth09 = L"Sep";
2514 +         _M_data->_M_amonth10 = L"Oct";
2515 +         _M_data->_M_amonth11 = L"Nov";
2516 +         _M_data->_M_amonth12 = L"Dec";
2517 +       }
2518 +#if 0
2519 +      else
2520 +       {
2521 +         _M_c_locale_timepunct = _S_clone_c_locale(__cloc); 
2522 +
2523 +         union { char *__s; wchar_t *__w; } __u;
2524 +
2525 +         __u.__s = __nl_langinfo_l(_NL_WD_FMT, __cloc);
2526 +         _M_data->_M_date_format = __u.__w;
2527 +         __u.__s = __nl_langinfo_l(_NL_WERA_D_FMT, __cloc);
2528 +         _M_data->_M_date_era_format = __u.__w;
2529 +         __u.__s = __nl_langinfo_l(_NL_WT_FMT, __cloc);
2530 +         _M_data->_M_time_format = __u.__w;
2531 +         __u.__s = __nl_langinfo_l(_NL_WERA_T_FMT, __cloc);
2532 +         _M_data->_M_time_era_format = __u.__w;
2533 +         __u.__s = __nl_langinfo_l(_NL_WD_T_FMT, __cloc);
2534 +         _M_data->_M_date_time_format = __u.__w;
2535 +         __u.__s = __nl_langinfo_l(_NL_WERA_D_T_FMT, __cloc);
2536 +         _M_data->_M_date_time_era_format = __u.__w;
2537 +         __u.__s = __nl_langinfo_l(_NL_WAM_STR, __cloc);
2538 +         _M_data->_M_am = __u.__w;
2539 +         __u.__s = __nl_langinfo_l(_NL_WPM_STR, __cloc);
2540 +         _M_data->_M_pm = __u.__w;
2541 +         __u.__s = __nl_langinfo_l(_NL_WT_FMT_AMPM, __cloc);
2542 +         _M_data->_M_am_pm_format = __u.__w;
2543 +
2544 +         // Day names, starting with "C"'s Sunday.
2545 +         __u.__s = __nl_langinfo_l(_NL_WDAY_1, __cloc);
2546 +         _M_data->_M_day1 = __u.__w;
2547 +         __u.__s = __nl_langinfo_l(_NL_WDAY_2, __cloc);
2548 +         _M_data->_M_day2 = __u.__w;
2549 +         __u.__s = __nl_langinfo_l(_NL_WDAY_3, __cloc);
2550 +         _M_data->_M_day3 = __u.__w;
2551 +         __u.__s = __nl_langinfo_l(_NL_WDAY_4, __cloc);
2552 +         _M_data->_M_day4 = __u.__w;
2553 +         __u.__s = __nl_langinfo_l(_NL_WDAY_5, __cloc);
2554 +         _M_data->_M_day5 = __u.__w;
2555 +         __u.__s = __nl_langinfo_l(_NL_WDAY_6, __cloc);
2556 +         _M_data->_M_day6 = __u.__w;
2557 +         __u.__s = __nl_langinfo_l(_NL_WDAY_7, __cloc);
2558 +         _M_data->_M_day7 = __u.__w;
2559 +
2560 +         // Abbreviated day names, starting with "C"'s Sun.
2561 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_1, __cloc);
2562 +         _M_data->_M_aday1 = __u.__w;
2563 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_2, __cloc);
2564 +         _M_data->_M_aday2 = __u.__w;
2565 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_3, __cloc);
2566 +         _M_data->_M_aday3 = __u.__w;
2567 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_4, __cloc);
2568 +         _M_data->_M_aday4 = __u.__w;
2569 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_5, __cloc);
2570 +         _M_data->_M_aday5 = __u.__w;
2571 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_6, __cloc);
2572 +         _M_data->_M_aday6 = __u.__w;
2573 +         __u.__s = __nl_langinfo_l(_NL_WABDAY_7, __cloc);
2574 +         _M_data->_M_aday7 = __u.__w;
2575 +
2576 +         // Month names, starting with "C"'s January.
2577 +         __u.__s = __nl_langinfo_l(_NL_WMON_1, __cloc);
2578 +         _M_data->_M_month01 = __u.__w;
2579 +         __u.__s = __nl_langinfo_l(_NL_WMON_2, __cloc);
2580 +         _M_data->_M_month02 = __u.__w;
2581 +         __u.__s = __nl_langinfo_l(_NL_WMON_3, __cloc);
2582 +         _M_data->_M_month03 = __u.__w;
2583 +         __u.__s = __nl_langinfo_l(_NL_WMON_4, __cloc);
2584 +         _M_data->_M_month04 = __u.__w;
2585 +         __u.__s = __nl_langinfo_l(_NL_WMON_5, __cloc);
2586 +         _M_data->_M_month05 = __u.__w;
2587 +         __u.__s = __nl_langinfo_l(_NL_WMON_6, __cloc);
2588 +         _M_data->_M_month06 = __u.__w;
2589 +         __u.__s = __nl_langinfo_l(_NL_WMON_7, __cloc);
2590 +         _M_data->_M_month07 = __u.__w;
2591 +         __u.__s = __nl_langinfo_l(_NL_WMON_8, __cloc);
2592 +         _M_data->_M_month08 = __u.__w;
2593 +         __u.__s = __nl_langinfo_l(_NL_WMON_9, __cloc);
2594 +         _M_data->_M_month09 = __u.__w;
2595 +         __u.__s = __nl_langinfo_l(_NL_WMON_10, __cloc);
2596 +         _M_data->_M_month10 = __u.__w;
2597 +         __u.__s = __nl_langinfo_l(_NL_WMON_11, __cloc);
2598 +         _M_data->_M_month11 = __u.__w;
2599 +         __u.__s = __nl_langinfo_l(_NL_WMON_12, __cloc);
2600 +         _M_data->_M_month12 = __u.__w;
2601 +
2602 +         // Abbreviated month names, starting with "C"'s Jan.
2603 +         __u.__s = __nl_langinfo_l(_NL_WABMON_1, __cloc);
2604 +         _M_data->_M_amonth01 = __u.__w;
2605 +         __u.__s = __nl_langinfo_l(_NL_WABMON_2, __cloc);
2606 +         _M_data->_M_amonth02 = __u.__w;
2607 +         __u.__s = __nl_langinfo_l(_NL_WABMON_3, __cloc);
2608 +         _M_data->_M_amonth03 = __u.__w;
2609 +         __u.__s = __nl_langinfo_l(_NL_WABMON_4, __cloc);
2610 +         _M_data->_M_amonth04 = __u.__w;
2611 +         __u.__s = __nl_langinfo_l(_NL_WABMON_5, __cloc);
2612 +         _M_data->_M_amonth05 = __u.__w;
2613 +         __u.__s = __nl_langinfo_l(_NL_WABMON_6, __cloc);
2614 +         _M_data->_M_amonth06 = __u.__w;
2615 +         __u.__s = __nl_langinfo_l(_NL_WABMON_7, __cloc);
2616 +         _M_data->_M_amonth07 = __u.__w;
2617 +         __u.__s = __nl_langinfo_l(_NL_WABMON_8, __cloc);
2618 +         _M_data->_M_amonth08 = __u.__w;
2619 +         __u.__s = __nl_langinfo_l(_NL_WABMON_9, __cloc);
2620 +         _M_data->_M_amonth09 = __u.__w;
2621 +         __u.__s = __nl_langinfo_l(_NL_WABMON_10, __cloc);
2622 +         _M_data->_M_amonth10 = __u.__w;
2623 +         __u.__s = __nl_langinfo_l(_NL_WABMON_11, __cloc);
2624 +         _M_data->_M_amonth11 = __u.__w;
2625 +         __u.__s = __nl_langinfo_l(_NL_WABMON_12, __cloc);
2626 +         _M_data->_M_amonth12 = __u.__w;
2627 +       }
2628 +#endif // 0
2629 +    }
2630 +#endif
2631 +}
2632 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/time_members.h gcc-4.1.0/libstdc++-v3/config/locale/uclibc/time_members.h
2633 --- gcc-4.1.0-dist/libstdc++-v3/config/locale/uclibc/time_members.h     1969-12-31 17:00:00.000000000 -0700
2634 +++ gcc-4.1.0/libstdc++-v3/config/locale/uclibc/time_members.h  2005-10-21 02:34:06.000000000 -0600
2635 @@ -0,0 +1,76 @@
2636 +// std::time_get, std::time_put implementation, GNU version -*- C++ -*-
2637 +
2638 +// Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
2639 +//
2640 +// This file is part of the GNU ISO C++ Library.  This library is free
2641 +// software; you can redistribute it and/or modify it under the
2642 +// terms of the GNU General Public License as published by the
2643 +// Free Software Foundation; either version 2, or (at your option)
2644 +// any later version.
2645 +
2646 +// This library is distributed in the hope that it will be useful,
2647 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2648 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2649 +// GNU General Public License for more details.
2650 +
2651 +// You should have received a copy of the GNU General Public License along
2652 +// with this library; see the file COPYING.  If not, write to the Free
2653 +// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
2654 +// USA.
2655 +
2656 +// As a special exception, you may use this file as part of a free software
2657 +// library without restriction.  Specifically, if other files instantiate
2658 +// templates or use macros or inline functions from this file, or you compile
2659 +// this file and link it with other files to produce an executable, this
2660 +// file does not by itself cause the resulting executable to be covered by
2661 +// the GNU General Public License.  This exception does not however
2662 +// invalidate any other reasons why the executable file might be covered by
2663 +// the GNU General Public License.
2664 +
2665 +//
2666 +// ISO C++ 14882: 22.2.5.1.2 - time_get functions
2667 +// ISO C++ 14882: 22.2.5.3.2 - time_put functions
2668 +//
2669 +
2670 +// Written by Benjamin Kosnik <bkoz@redhat.com>
2671 +
2672 +  template<typename _CharT>
2673 +    __timepunct<_CharT>::__timepunct(size_t __refs) 
2674 +    : facet(__refs), _M_data(NULL), _M_c_locale_timepunct(NULL), 
2675 +      _M_name_timepunct(_S_get_c_name())
2676 +    { _M_initialize_timepunct(); }
2677 +
2678 +  template<typename _CharT>
2679 +    __timepunct<_CharT>::__timepunct(__cache_type* __cache, size_t __refs) 
2680 +    : facet(__refs), _M_data(__cache), _M_c_locale_timepunct(NULL), 
2681 +      _M_name_timepunct(_S_get_c_name())
2682 +    { _M_initialize_timepunct(); }
2683 +
2684 +  template<typename _CharT>
2685 +    __timepunct<_CharT>::__timepunct(__c_locale __cloc, const char* __s,
2686 +                                    size_t __refs) 
2687 +    : facet(__refs), _M_data(NULL), _M_c_locale_timepunct(NULL), 
2688 +      _M_name_timepunct(NULL)
2689 +    { 
2690 +      const size_t __len = std::strlen(__s) + 1;
2691 +      char* __tmp = new char[__len];
2692 +      std::memcpy(__tmp, __s, __len);
2693 +      _M_name_timepunct = __tmp;
2694 +
2695 +      try
2696 +       { _M_initialize_timepunct(__cloc); }
2697 +      catch(...)
2698 +       {
2699 +         delete [] _M_name_timepunct;
2700 +         __throw_exception_again;
2701 +       }
2702 +    }
2703 +
2704 +  template<typename _CharT>
2705 +    __timepunct<_CharT>::~__timepunct()
2706 +    { 
2707 +      if (_M_name_timepunct != _S_get_c_name())
2708 +       delete [] _M_name_timepunct;
2709 +      delete _M_data; 
2710 +      _S_destroy_c_locale(_M_c_locale_timepunct); 
2711 +    }
2712 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/ctype_base.h gcc-4.1.0/libstdc++-v3/config/os/uclibc/ctype_base.h
2713 --- gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/ctype_base.h   1969-12-31 17:00:00.000000000 -0700
2714 +++ gcc-4.1.0/libstdc++-v3/config/os/uclibc/ctype_base.h        2006-03-25 22:06:30.000000000 -0700
2715 @@ -0,0 +1,64 @@
2716 +// Locale support -*- C++ -*-
2717 +
2718 +// Copyright (C) 1997, 1998, 1999, 2000, 2002, 2003, 2004
2719 +// Free Software Foundation, Inc.
2720 +//
2721 +// This file is part of the GNU ISO C++ Library.  This library is free
2722 +// software; you can redistribute it and/or modify it under the
2723 +// terms of the GNU General Public License as published by the
2724 +// Free Software Foundation; either version 2, or (at your option)
2725 +// any later version.
2726 +
2727 +// This library is distributed in the hope that it will be useful,
2728 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2729 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2730 +// GNU General Public License for more details.
2731 +
2732 +// You should have received a copy of the GNU General Public License along
2733 +// with this library; see the file COPYING.  If not, write to the Free
2734 +// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
2735 +// USA.
2736 +
2737 +// As a special exception, you may use this file as part of a free software
2738 +// library without restriction.  Specifically, if other files instantiate
2739 +// templates or use macros or inline functions from this file, or you compile
2740 +// this file and link it with other files to produce an executable, this
2741 +// file does not by itself cause the resulting executable to be covered by
2742 +// the GNU General Public License.  This exception does not however
2743 +// invalidate any other reasons why the executable file might be covered by
2744 +// the GNU General Public License.
2745 +
2746 +//
2747 +// ISO C++ 14882: 22.1  Locales
2748 +//
2749 +  
2750 +/** @file ctype_base.h
2751 + *  This is an internal header file, included by other library headers.
2752 + *  You should not attempt to use it directly.
2753 + */
2754 +
2755 +// Information as gleaned from /usr/include/ctype.h
2756 +  
2757 +  /// @brief  Base class for ctype.
2758 +  struct ctype_base
2759 +  {
2760 +    // Note: In uClibc, the following two types depend on configuration.
2761
2762 +    // Non-standard typedefs.
2763 +    typedef const __ctype_touplow_t* __to_type;
2764 +
2765 +    // NB: Offsets into ctype<char>::_M_table force a particular size
2766 +    // on the mask type. Because of this, we don't use an enum.
2767 +    typedef __ctype_mask_t     mask;   
2768 +    static const mask upper            = _ISupper;
2769 +    static const mask lower    = _ISlower;
2770 +    static const mask alpha    = _ISalpha;
2771 +    static const mask digit    = _ISdigit;
2772 +    static const mask xdigit   = _ISxdigit;
2773 +    static const mask space    = _ISspace;
2774 +    static const mask print    = _ISprint;
2775 +    static const mask graph    = _ISalpha | _ISdigit | _ISpunct;
2776 +    static const mask cntrl    = _IScntrl;
2777 +    static const mask punct    = _ISpunct;
2778 +    static const mask alnum    = _ISalpha | _ISdigit;
2779 +  };
2780 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/ctype_inline.h gcc-4.1.0/libstdc++-v3/config/os/uclibc/ctype_inline.h
2781 --- gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/ctype_inline.h 1969-12-31 17:00:00.000000000 -0700
2782 +++ gcc-4.1.0/libstdc++-v3/config/os/uclibc/ctype_inline.h      2006-03-25 22:06:30.000000000 -0700
2783 @@ -0,0 +1,69 @@
2784 +// Locale support -*- C++ -*-
2785 +
2786 +// Copyright (C) 2000, 2002 Free Software Foundation, Inc.
2787 +//
2788 +// This file is part of the GNU ISO C++ Library.  This library is free
2789 +// software; you can redistribute it and/or modify it under the
2790 +// terms of the GNU General Public License as published by the
2791 +// Free Software Foundation; either version 2, or (at your option)
2792 +// any later version.
2793 +
2794 +// This library is distributed in the hope that it will be useful,
2795 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2796 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2797 +// GNU General Public License for more details.
2798 +
2799 +// You should have received a copy of the GNU General Public License along
2800 +// with this library; see the file COPYING.  If not, write to the Free
2801 +// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
2802 +// USA.
2803 +
2804 +// As a special exception, you may use this file as part of a free software
2805 +// library without restriction.  Specifically, if other files instantiate
2806 +// templates or use macros or inline functions from this file, or you compile
2807 +// this file and link it with other files to produce an executable, this
2808 +// file does not by itself cause the resulting executable to be covered by
2809 +// the GNU General Public License.  This exception does not however
2810 +// invalidate any other reasons why the executable file might be covered by
2811 +// the GNU General Public License.
2812 +
2813 +//
2814 +// ISO C++ 14882: 22.1  Locales
2815 +//
2816 +  
2817 +// ctype bits to be inlined go here. Non-inlinable (ie virtual do_*)
2818 +// functions go in ctype.cc
2819 +  
2820 +  bool
2821 +  ctype<char>::
2822 +  is(mask __m, char __c) const
2823 +  { return _M_table[static_cast<unsigned char>(__c)] & __m; }
2824 +
2825 +  const char*
2826 +  ctype<char>::
2827 +  is(const char* __low, const char* __high, mask* __vec) const
2828 +  {
2829 +    while (__low < __high)
2830 +      *__vec++ = _M_table[static_cast<unsigned char>(*__low++)];
2831 +    return __high;
2832 +  }
2833 +
2834 +  const char*
2835 +  ctype<char>::
2836 +  scan_is(mask __m, const char* __low, const char* __high) const
2837 +  {
2838 +    while (__low < __high 
2839 +          && !(_M_table[static_cast<unsigned char>(*__low)] & __m))
2840 +      ++__low;
2841 +    return __low;
2842 +  }
2843 +
2844 +  const char*
2845 +  ctype<char>::
2846 +  scan_not(mask __m, const char* __low, const char* __high) const
2847 +  {
2848 +    while (__low < __high 
2849 +          && (_M_table[static_cast<unsigned char>(*__low)] & __m) != 0)
2850 +      ++__low;
2851 +    return __low;
2852 +  }
2853 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/ctype_noninline.h gcc-4.1.0/libstdc++-v3/config/os/uclibc/ctype_noninline.h
2854 --- gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/ctype_noninline.h      1969-12-31 17:00:00.000000000 -0700
2855 +++ gcc-4.1.0/libstdc++-v3/config/os/uclibc/ctype_noninline.h   2006-03-25 22:06:30.000000000 -0700
2856 @@ -0,0 +1,92 @@
2857 +// Locale support -*- C++ -*-
2858 +
2859 +// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2004
2860 +// Free Software Foundation, Inc.
2861 +//
2862 +// This file is part of the GNU ISO C++ Library.  This library is free
2863 +// software; you can redistribute it and/or modify it under the
2864 +// terms of the GNU General Public License as published by the
2865 +// Free Software Foundation; either version 2, or (at your option)
2866 +// any later version.
2867 +
2868 +// This library is distributed in the hope that it will be useful,
2869 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2870 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2871 +// GNU General Public License for more details.
2872 +
2873 +// You should have received a copy of the GNU General Public License along
2874 +// with this library; see the file COPYING.  If not, write to the Free
2875 +// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
2876 +// USA.
2877 +
2878 +// As a special exception, you may use this file as part of a free software
2879 +// library without restriction.  Specifically, if other files instantiate
2880 +// templates or use macros or inline functions from this file, or you compile
2881 +// this file and link it with other files to produce an executable, this
2882 +// file does not by itself cause the resulting executable to be covered by
2883 +// the GNU General Public License.  This exception does not however
2884 +// invalidate any other reasons why the executable file might be covered by
2885 +// the GNU General Public License.
2886 +
2887 +//
2888 +// ISO C++ 14882: 22.1  Locales
2889 +//
2890 +  
2891 +// Information as gleaned from /usr/include/ctype.h
2892 +
2893 +  const ctype_base::mask*
2894 +  ctype<char>::classic_table() throw()
2895 +  { return __C_ctype_b; }
2896 +
2897 +  ctype<char>::ctype(__c_locale, const mask* __table, bool __del, 
2898 +                    size_t __refs) 
2899 +  : facet(__refs), _M_c_locale_ctype(_S_get_c_locale()), 
2900 +  _M_del(__table != 0 && __del), _M_widen_ok(0), _M_narrow_ok(0)
2901 +  {
2902 +    _M_toupper = __C_ctype_toupper;
2903 +    _M_tolower = __C_ctype_tolower;
2904 +    _M_table = __table ? __table : __C_ctype_b;
2905 +    memset(_M_widen, 0, sizeof(_M_widen));
2906 +    memset(_M_narrow, 0, sizeof(_M_narrow));
2907 +  }
2908 +
2909 +  ctype<char>::ctype(const mask* __table, bool __del, size_t __refs)
2910 +  : facet(__refs), _M_c_locale_ctype(_S_get_c_locale()), 
2911 +  _M_del(__table != 0 && __del), _M_widen_ok(0), _M_narrow_ok(0)
2912 +  {
2913 +    _M_toupper = __C_ctype_toupper;
2914 +    _M_tolower = __C_ctype_tolower;
2915 +    _M_table = __table ? __table : __C_ctype_b;
2916 +    memset(_M_widen, 0, sizeof(_M_widen));
2917 +    memset(_M_narrow, 0, sizeof(_M_narrow));
2918 +  }
2919 +
2920 +  char
2921 +  ctype<char>::do_toupper(char __c) const
2922 +  { return _M_toupper[static_cast<unsigned char>(__c)]; }
2923 +
2924 +  const char*
2925 +  ctype<char>::do_toupper(char* __low, const char* __high) const
2926 +  {
2927 +    while (__low < __high)
2928 +      {
2929 +       *__low = _M_toupper[static_cast<unsigned char>(*__low)];
2930 +       ++__low;
2931 +      }
2932 +    return __high;
2933 +  }
2934 +
2935 +  char
2936 +  ctype<char>::do_tolower(char __c) const
2937 +  { return _M_tolower[static_cast<unsigned char>(__c)]; }
2938 +
2939 +  const char* 
2940 +  ctype<char>::do_tolower(char* __low, const char* __high) const
2941 +  {
2942 +    while (__low < __high)
2943 +      {
2944 +       *__low = _M_tolower[static_cast<unsigned char>(*__low)];
2945 +       ++__low;
2946 +      }
2947 +    return __high;
2948 +  }
2949 diff -urN gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/os_defines.h gcc-4.1.0/libstdc++-v3/config/os/uclibc/os_defines.h
2950 --- gcc-4.1.0-dist/libstdc++-v3/config/os/uclibc/os_defines.h   1969-12-31 17:00:00.000000000 -0700
2951 +++ gcc-4.1.0/libstdc++-v3/config/os/uclibc/os_defines.h        2006-03-25 22:06:30.000000000 -0700
2952 @@ -0,0 +1,44 @@
2953 +// Specific definitions for GNU/Linux  -*- C++ -*-
2954 +
2955 +// Copyright (C) 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
2956 +//
2957 +// This file is part of the GNU ISO C++ Library.  This library is free
2958 +// software; you can redistribute it and/or modify it under the
2959 +// terms of the GNU General Public License as published by the
2960 +// Free Software Foundation; either version 2, or (at your option)
2961 +// any later version.
2962 +
2963 +// This library is distributed in the hope that it will be useful,
2964 +// but WITHOUT ANY WARRANTY; without even the implied warranty of
2965 +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2966 +// GNU General Public License for more details.
2967 +
2968 +// You should have received a copy of the GNU General Public License along
2969 +// with this library; see the file COPYING.  If not, write to the Free
2970 +// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
2971 +// USA.
2972 +
2973 +// As a special exception, you may use this file as part of a free software
2974 +// library without restriction.  Specifically, if other files instantiate
2975 +// templates or use macros or inline functions from this file, or you compile
2976 +// this file and link it with other files to produce an executable, this
2977 +// file does not by itself cause the resulting executable to be covered by
2978 +// the GNU General Public License.  This exception does not however
2979 +// invalidate any other reasons why the executable file might be covered by
2980 +// the GNU General Public License.
2981 +
2982 +#ifndef _GLIBCXX_OS_DEFINES
2983 +#define _GLIBCXX_OS_DEFINES 1
2984 +
2985 +// System-specific #define, typedefs, corrections, etc, go here.  This
2986 +// file will come before all others.
2987 +
2988 +// This keeps isanum, et al from being propagated as macros.
2989 +#define __NO_CTYPE 1
2990 +
2991 +#include <features.h>
2992 +
2993 +// We must not see the optimized string functions GNU libc defines.
2994 +#define __NO_STRING_INLINES
2995 +
2996 +#endif
2997 diff -urN gcc-4.1.0-dist/libstdc++-v3/configure gcc-4.1.0/libstdc++-v3/configure
2998 --- gcc-4.1.0-dist/libstdc++-v3/configure       2006-03-26 12:08:28.000000000 -0700
2999 +++ gcc-4.1.0/libstdc++-v3/configure    2006-03-25 22:06:30.000000000 -0700
3000 @@ -4005,6 +4005,11 @@
3001    lt_cv_deplibs_check_method=pass_all
3002    ;;
3003  
3004 +linux-uclibc*)
3005 +  lt_cv_deplibs_check_method=pass_all
3006 +  lt_cv_file_magic_test_file=`echo /lib/libuClibc-*.so`
3007 +  ;;
3008 +
3009  netbsd* | knetbsd*-gnu)
3010    if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then
3011      lt_cv_deplibs_check_method='match_pattern /lib[^/\.]+\.so\.[0-9]+\.[0-9]+$'
3012 @@ -5740,7 +5745,7 @@
3013    enableval="$enable_clocale"
3014  
3015        case "$enableval" in
3016 -       generic|gnu|ieee_1003.1-2001|yes|no|auto) ;;
3017 +       generic|gnu|ieee_1003.1-2001|uclibc|yes|no|auto) ;;
3018         *) { { echo "$as_me:$LINENO: error: Unknown argument to enable/disable clocale" >&5
3019  echo "$as_me: error: Unknown argument to enable/disable clocale" >&2;}
3020     { (exit 1); exit 1; }; } ;;
3021 @@ -5765,6 +5770,9 @@
3022    # Default to "generic".
3023    if test $enable_clocale_flag = auto; then
3024      case ${target_os} in
3025 +      linux-uclibc*)
3026 +        enable_clocale_flag=uclibc
3027 +       ;;
3028        linux* | gnu* | kfreebsd*-gnu | knetbsd*-gnu)
3029          cat >conftest.$ac_ext <<_ACEOF
3030  /* confdefs.h.  */
3031 @@ -5995,6 +6003,76 @@
3032        CTIME_CC=config/locale/generic/time_members.cc
3033        CLOCALE_INTERNAL_H=config/locale/generic/c++locale_internal.h
3034        ;;
3035 +    uclibc)
3036 +      echo "$as_me:$LINENO: result: uclibc" >&5
3037 +echo "${ECHO_T}uclibc" >&6
3038 +
3039 +      # Declare intention to use gettext, and add support for specific
3040 +      # languages.
3041 +      # For some reason, ALL_LINGUAS has to be before AM-GNU-GETTEXT
3042 +      ALL_LINGUAS="de fr"
3043 +
3044 +      # Don't call AM-GNU-GETTEXT here. Instead, assume glibc.
3045 +      # Extract the first word of "msgfmt", so it can be a program name with args.
3046 +set dummy msgfmt; ac_word=$2
3047 +echo "$as_me:$LINENO: checking for $ac_word" >&5
3048 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
3049 +if test "${ac_cv_prog_check_msgfmt+set}" = set; then
3050 +  echo $ECHO_N "(cached) $ECHO_C" >&6
3051 +else
3052 +  if test -n "$check_msgfmt"; then
3053 +  ac_cv_prog_check_msgfmt="$check_msgfmt" # Let the user override the test.
3054 +else
3055 +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
3056 +for as_dir in $PATH
3057 +do
3058 +  IFS=$as_save_IFS
3059 +  test -z "$as_dir" && as_dir=.
3060 +  for ac_exec_ext in '' $ac_executable_extensions; do
3061 +  if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
3062 +    ac_cv_prog_check_msgfmt="yes"
3063 +    echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
3064 +    break 2
3065 +  fi
3066 +done
3067 +done
3068 +
3069 +  test -z "$ac_cv_prog_check_msgfmt" && ac_cv_prog_check_msgfmt="no"
3070 +fi
3071 +fi
3072 +check_msgfmt=$ac_cv_prog_check_msgfmt
3073 +if test -n "$check_msgfmt"; then
3074 +  echo "$as_me:$LINENO: result: $check_msgfmt" >&5
3075 +echo "${ECHO_T}$check_msgfmt" >&6
3076 +else
3077 +  echo "$as_me:$LINENO: result: no" >&5
3078 +echo "${ECHO_T}no" >&6
3079 +fi
3080 +
3081 +      if test x"$check_msgfmt" = x"yes" && test x"$enable_nls" = x"yes"; then
3082 +        USE_NLS=yes
3083 +      fi
3084 +      # Export the build objects.
3085 +      for ling in $ALL_LINGUAS; do \
3086 +        glibcxx_MOFILES="$glibcxx_MOFILES $ling.mo"; \
3087 +        glibcxx_POFILES="$glibcxx_POFILES $ling.po"; \
3088 +      done
3089 +
3090 +
3091 +
3092 +      CLOCALE_H=config/locale/uclibc/c_locale.h
3093 +      CLOCALE_CC=config/locale/uclibc/c_locale.cc
3094 +      CCODECVT_CC=config/locale/uclibc/codecvt_members.cc
3095 +      CCOLLATE_CC=config/locale/uclibc/collate_members.cc
3096 +      CCTYPE_CC=config/locale/uclibc/ctype_members.cc
3097 +      CMESSAGES_H=config/locale/uclibc/messages_members.h
3098 +      CMESSAGES_CC=config/locale/uclibc/messages_members.cc
3099 +      CMONEY_CC=config/locale/uclibc/monetary_members.cc
3100 +      CNUMERIC_CC=config/locale/uclibc/numeric_members.cc
3101 +      CTIME_H=config/locale/uclibc/time_members.h
3102 +      CTIME_CC=config/locale/uclibc/time_members.cc
3103 +      CLOCALE_INTERNAL_H=config/locale/uclibc/c++locale_internal.h
3104 +      ;;
3105    esac
3106  
3107    # This is where the testsuite looks for locale catalogs, using the
3108 diff -urN gcc-4.1.0-dist/libstdc++-v3/configure.host gcc-4.1.0/libstdc++-v3/configure.host
3109 --- gcc-4.1.0-dist/libstdc++-v3/configure.host  2006-03-26 12:08:28.000000000 -0700
3110 +++ gcc-4.1.0/libstdc++-v3/configure.host       2006-03-25 22:06:30.000000000 -0700
3111 @@ -261,6 +261,12 @@
3112      ;;
3113  esac
3114  
3115 +# Override for uClibc since linux-uclibc gets mishandled above.
3116 +case "${host_os}" in
3117 +  *-uclibc*)
3118 +    os_include_dir="os/uclibc"
3119 +    ;;
3120 +esac
3121  
3122  # Set any OS-dependent and CPU-dependent bits.
3123  # THIS TABLE IS SORTED.  KEEP IT THAT WAY.
3124 diff -urN gcc-4.1.0-dist/libstdc++-v3/crossconfig.m4 gcc-4.1.0/libstdc++-v3/crossconfig.m4
3125 --- gcc-4.1.0-dist/libstdc++-v3/crossconfig.m4  2006-03-26 12:08:28.000000000 -0700
3126 +++ gcc-4.1.0/libstdc++-v3/crossconfig.m4       2006-03-25 22:06:30.000000000 -0700
3127 @@ -143,6 +143,99 @@
3128         ;;
3129      esac
3130      ;;
3131 +  *-uclibc*)
3132 +# Temporary hack until we implement the float versions of the libm funcs
3133 +    AC_CHECK_HEADERS([nan.h ieeefp.h endian.h sys/isa_defs.h \
3134 +      machine/endian.h machine/param.h sys/machine.h sys/types.h \
3135 +      fp.h float.h endian.h inttypes.h locale.h float.h stdint.h])
3136 +    SECTION_FLAGS='-ffunction-sections -fdata-sections'
3137 +    AC_SUBST(SECTION_FLAGS)
3138 +    GLIBCXX_CHECK_LINKER_FEATURES
3139 +    GLIBCXX_CHECK_COMPLEX_MATH_SUPPORT
3140 +    GLIBCXX_CHECK_WCHAR_T_SUPPORT
3141 +
3142 +    # For LFS.
3143 +    AC_DEFINE(HAVE_INT64_T)
3144 +    case "$target" in
3145 +      *-uclinux*)
3146 +        # Don't enable LFS with uClinux
3147 +        ;;
3148 +      *)
3149 +        AC_DEFINE(_GLIBCXX_USE_LFS)
3150 +    esac
3151 +
3152 +    # For showmanyc_helper().
3153 +    AC_CHECK_HEADERS(sys/ioctl.h sys/filio.h)
3154 +    GLIBCXX_CHECK_POLL
3155 +    GLIBCXX_CHECK_S_ISREG_OR_S_IFREG
3156 +
3157 +    # For xsputn_2().
3158 +    AC_CHECK_HEADERS(sys/uio.h)
3159 +    GLIBCXX_CHECK_WRITEV
3160 +
3161 +#     AC_DEFINE(HAVE_ACOSF)
3162 +#     AC_DEFINE(HAVE_ASINF)
3163 +#     AC_DEFINE(HAVE_ATANF)
3164 +#     AC_DEFINE(HAVE_ATAN2F)
3165 +    AC_DEFINE(HAVE_CEILF)
3166 +    AC_DEFINE(HAVE_COPYSIGN)
3167 +#     AC_DEFINE(HAVE_COPYSIGNF)
3168 +#     AC_DEFINE(HAVE_COSF)
3169 +#     AC_DEFINE(HAVE_COSHF)
3170 +#     AC_DEFINE(HAVE_EXPF)
3171 +#     AC_DEFINE(HAVE_FABSF)
3172 +    AC_DEFINE(HAVE_FINITE)
3173 +    AC_DEFINE(HAVE_FINITEF)
3174 +    AC_DEFINE(HAVE_FLOORF)
3175 +#     AC_DEFINE(HAVE_FMODF)
3176 +#     AC_DEFINE(HAVE_FREXPF)
3177 +    AC_DEFINE(HAVE_HYPOT)
3178 +#     AC_DEFINE(HAVE_HYPOTF)
3179 +    AC_DEFINE(HAVE_ISINF)
3180 +    AC_DEFINE(HAVE_ISINFF)
3181 +    AC_DEFINE(HAVE_ISNAN)
3182 +    AC_DEFINE(HAVE_ISNANF)
3183 +#     AC_DEFINE(HAVE_LOGF)
3184 +#     AC_DEFINE(HAVE_LOG10F)
3185 +#     AC_DEFINE(HAVE_MODFF)
3186 +#     AC_DEFINE(HAVE_SINF)
3187 +#     AC_DEFINE(HAVE_SINHF)
3188 +#     AC_DEFINE(HAVE_SINCOS)
3189 +#     AC_DEFINE(HAVE_SINCOSF)
3190 +    AC_DEFINE(HAVE_SQRTF)
3191 +#     AC_DEFINE(HAVE_TANF)
3192 +#     AC_DEFINE(HAVE_TANHF)
3193 +    if test x"long_double_math_on_this_cpu" = x"yes"; then
3194 +      AC_MSG_ERROR([long_double_math_on_this_cpu is yes!])
3195 +#       AC_DEFINE(HAVE_ACOSL)
3196 +#       AC_DEFINE(HAVE_ASINL)
3197 +#       AC_DEFINE(HAVE_ATANL)
3198 +#       AC_DEFINE(HAVE_ATAN2L)
3199 +#       AC_DEFINE(HAVE_CEILL)
3200 +#       AC_DEFINE(HAVE_COPYSIGNL)
3201 +#       AC_DEFINE(HAVE_COSL)
3202 +#       AC_DEFINE(HAVE_COSHL)
3203 +#       AC_DEFINE(HAVE_EXPL)
3204 +#       AC_DEFINE(HAVE_FABSL)
3205 +#       AC_DEFINE(HAVE_FINITEL)
3206 +#       AC_DEFINE(HAVE_FLOORL)
3207 +#       AC_DEFINE(HAVE_FMODL)
3208 +#       AC_DEFINE(HAVE_FREXPL)
3209 +#       AC_DEFINE(HAVE_HYPOTL)
3210 +#       AC_DEFINE(HAVE_ISINFL)
3211 +#       AC_DEFINE(HAVE_ISNANL)
3212 +#       AC_DEFINE(HAVE_LOGL)
3213 +#       AC_DEFINE(HAVE_LOG10L)
3214 +#       AC_DEFINE(HAVE_MODFL)
3215 +#       AC_DEFINE(HAVE_POWL)
3216 +#       AC_DEFINE(HAVE_SINL)
3217 +#       AC_DEFINE(HAVE_SINHL)
3218 +#       AC_DEFINE(HAVE_SINCOSL)
3219 +#       AC_DEFINE(HAVE_SQRTL)
3220 +#       AC_DEFINE(HAVE_TANL)
3221 +#       AC_DEFINE(HAVE_TANHL)
3222 +    fi
3223 +    ;;
3224    *-linux* | *-uclinux* | *-gnu* | *-kfreebsd*-gnu | *-knetbsd*-gnu)
3225      AC_CHECK_HEADERS([nan.h ieeefp.h endian.h sys/isa_defs.h \
3226        machine/endian.h machine/param.h sys/machine.h sys/types.h \
3227 @@ -157,7 +250,7 @@
3228      AC_DEFINE(HAVE_INT64_T)
3229      case "$target" in
3230        *-uclinux*)
3231 -        # Don't enable LFS with uClibc
3232 +        # Don't enable LFS with uClinux
3233          ;;
3234        *)
3235          AC_DEFINE(_GLIBCXX_USE_LFS)
3236 diff -urN gcc-4.1.0-dist/libstdc++-v3/include/c_compatibility/wchar.h gcc-4.1.0/libstdc++-v3/include/c_compatibility/wchar.h
3237 --- gcc-4.1.0-dist/libstdc++-v3/include/c_compatibility/wchar.h 2006-03-26 12:08:28.000000000 -0700
3238 +++ gcc-4.1.0/libstdc++-v3/include/c_compatibility/wchar.h      2006-03-25 22:06:30.000000000 -0700
3239 @@ -101,7 +101,9 @@
3240  using std::wmemcpy;
3241  using std::wmemmove;
3242  using std::wmemset;
3243 +#if _GLIBCXX_HAVE_WCSFTIME
3244  using std::wcsftime;
3245 +#endif
3246  
3247  #if _GLIBCXX_USE_C99
3248  using std::wcstold;
3249 diff -urN gcc-4.1.0-dist/libstdc++-v3/include/c_std/std_cwchar.h gcc-4.1.0/libstdc++-v3/include/c_std/std_cwchar.h
3250 --- gcc-4.1.0-dist/libstdc++-v3/include/c_std/std_cwchar.h      2006-03-26 12:08:28.000000000 -0700
3251 +++ gcc-4.1.0/libstdc++-v3/include/c_std/std_cwchar.h   2006-03-25 22:06:30.000000000 -0700
3252 @@ -180,7 +180,9 @@
3253    using ::wcscoll;
3254    using ::wcscpy;
3255    using ::wcscspn;
3256 +#if _GLIBCXX_HAVE_WCSFTIME
3257    using ::wcsftime;
3258 +#endif
3259    using ::wcslen;
3260    using ::wcsncat;
3261    using ::wcsncmp;