30 #ifndef _LOCALE_FACETS_NONIO_TCC 31 #define _LOCALE_FACETS_NONIO_TCC 1 33 #pragma GCC system_header 35 namespace std _GLIBCXX_VISIBILITY(default)
37 _GLIBCXX_BEGIN_NAMESPACE_VERSION
39 template<
typename _CharT,
bool _Intl>
40 struct __use_cache<__moneypunct_cache<_CharT, _Intl> >
42 const __moneypunct_cache<_CharT, _Intl>*
43 operator() (
const locale& __loc)
const 46 const locale::facet** __caches = __loc._M_impl->_M_caches;
49 __moneypunct_cache<_CharT, _Intl>* __tmp = 0;
52 __tmp =
new __moneypunct_cache<_CharT, _Intl>;
53 __tmp->_M_cache(__loc);
58 __throw_exception_again;
60 __loc._M_impl->_M_install_cache(__tmp, __i);
63 const __moneypunct_cache<_CharT, _Intl>*
>(__caches[__i]);
67 template<
typename _CharT,
bool _Intl>
69 __moneypunct_cache<_CharT, _Intl>::_M_cache(
const locale& __loc)
71 const moneypunct<_CharT, _Intl>& __mp =
72 use_facet<moneypunct<_CharT, _Intl> >(__loc);
74 _M_decimal_point = __mp.decimal_point();
75 _M_thousands_sep = __mp.thousands_sep();
76 _M_frac_digits = __mp.frac_digits();
79 _CharT* __curr_symbol = 0;
80 _CharT* __positive_sign = 0;
81 _CharT* __negative_sign = 0;
84 const string& __g = __mp.grouping();
85 _M_grouping_size = __g.size();
86 __grouping =
new char[_M_grouping_size];
87 __g.copy(__grouping, _M_grouping_size);
88 _M_use_grouping = (_M_grouping_size
89 && static_cast<signed char>(__grouping[0]) > 0
91 != __gnu_cxx::__numeric_traits<char>::__max));
93 const basic_string<_CharT>& __cs = __mp.curr_symbol();
94 _M_curr_symbol_size = __cs.size();
95 __curr_symbol =
new _CharT[_M_curr_symbol_size];
96 __cs.copy(__curr_symbol, _M_curr_symbol_size);
98 const basic_string<_CharT>& __ps = __mp.positive_sign();
99 _M_positive_sign_size = __ps.size();
100 __positive_sign =
new _CharT[_M_positive_sign_size];
101 __ps.copy(__positive_sign, _M_positive_sign_size);
103 const basic_string<_CharT>& __ns = __mp.negative_sign();
104 _M_negative_sign_size = __ns.size();
105 __negative_sign =
new _CharT[_M_negative_sign_size];
106 __ns.copy(__negative_sign, _M_negative_sign_size);
108 _M_pos_format = __mp.pos_format();
109 _M_neg_format = __mp.neg_format();
111 const ctype<_CharT>& __ct = use_facet<ctype<_CharT> >(__loc);
112 __ct.widen(money_base::_S_atoms,
113 money_base::_S_atoms + money_base::_S_end, _M_atoms);
115 _M_grouping = __grouping;
116 _M_curr_symbol = __curr_symbol;
117 _M_positive_sign = __positive_sign;
118 _M_negative_sign = __negative_sign;
123 delete [] __grouping;
124 delete [] __curr_symbol;
125 delete [] __positive_sign;
126 delete [] __negative_sign;
127 __throw_exception_again;
131 _GLIBCXX_BEGIN_NAMESPACE_LDBL_OR_CXX11
133 template<
typename _CharT,
typename _InIter>
136 money_get<_CharT, _InIter>::
137 _M_extract(iter_type __beg, iter_type __end, ios_base& __io,
140 typedef char_traits<_CharT> __traits_type;
141 typedef typename string_type::size_type size_type;
142 typedef money_base::part part;
143 typedef __moneypunct_cache<_CharT, _Intl> __cache_type;
145 const locale& __loc = __io._M_getloc();
146 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
148 __use_cache<__cache_type> __uc;
149 const __cache_type* __lc = __uc(__loc);
150 const char_type* __lit = __lc->_M_atoms;
153 bool __negative =
false;
155 size_type __sign_size = 0;
157 const bool __mandatory_sign = (__lc->_M_positive_sign_size
158 && __lc->_M_negative_sign_size);
160 string __grouping_tmp;
161 if (__lc->_M_use_grouping)
162 __grouping_tmp.reserve(32);
168 bool __testvalid =
true;
170 bool __testdecfound =
false;
176 const char_type* __lit_zero = __lit + money_base::_S_zero;
177 const money_base::pattern __p = __lc->_M_neg_format;
178 for (
int __i = 0; __i < 4 && __testvalid; ++__i)
180 const part __which = static_cast<part>(__p.field[__i]);
183 case money_base::symbol:
190 || (__i == 1 && (__mandatory_sign
191 || (static_cast<part>(__p.field[0])
193 || (static_cast<part>(__p.field[2])
194 == money_base::space)))
195 || (__i == 2 && ((static_cast<part>(__p.field[3])
196 == money_base::value)
198 && (static_cast<part>(__p.field[3])
199 == money_base::sign)))))
201 const size_type __len = __lc->_M_curr_symbol_size;
203 for (; __beg != __end && __j < __len
204 && *__beg == __lc->_M_curr_symbol[__j];
205 ++__beg, (void)++__j);
211 case money_base::sign:
213 if (__lc->_M_positive_sign_size && __beg != __end
214 && *__beg == __lc->_M_positive_sign[0])
216 __sign_size = __lc->_M_positive_sign_size;
219 else if (__lc->_M_negative_sign_size && __beg != __end
220 && *__beg == __lc->_M_negative_sign[0])
223 __sign_size = __lc->_M_negative_sign_size;
226 else if (__lc->_M_positive_sign_size
227 && !__lc->_M_negative_sign_size)
231 else if (__mandatory_sign)
234 case money_base::value:
237 for (; __beg != __end; ++__beg)
239 const char_type __c = *__beg;
240 const char_type* __q = __traits_type::find(__lit_zero,
244 __res += money_base::_S_atoms[__q - __lit];
247 else if (__c == __lc->_M_decimal_point
250 if (__lc->_M_frac_digits <= 0)
255 __testdecfound =
true;
257 else if (__lc->_M_use_grouping
258 && __c == __lc->_M_thousands_sep
264 __grouping_tmp += static_cast<char>(__n);
279 case money_base::space:
281 if (__beg != __end && __ctype.is(ctype_base::space, *__beg))
286 case money_base::none:
289 for (; __beg != __end
290 && __ctype.is(ctype_base::space, *__beg); ++__beg);
296 if (__sign_size > 1 && __testvalid)
298 const char_type* __sign = __negative ? __lc->_M_negative_sign
299 : __lc->_M_positive_sign;
301 for (; __beg != __end && __i < __sign_size
302 && *__beg == __sign[__i]; ++__beg, (void)++__i);
304 if (__i != __sign_size)
311 if (__res.size() > 1)
313 const size_type __first = __res.find_first_not_of(
'0');
316 __res.erase(0, __only_zeros ? __res.size() - 1 : __first);
320 if (__negative && __res[0] !=
'0')
321 __res.insert(__res.begin(),
'-');
324 if (__grouping_tmp.size())
327 __grouping_tmp += static_cast<char>(__testdecfound ? __last_pos
329 if (!std::__verify_grouping(__lc->_M_grouping,
330 __lc->_M_grouping_size,
336 if (__testdecfound && __n != __lc->_M_frac_digits)
352 #if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ \ 353 && _GLIBCXX_USE_CXX11_ABI == 0 354 template<
typename _CharT,
typename _InIter>
356 money_get<_CharT, _InIter>::
357 __do_get(iter_type __beg, iter_type __end,
bool __intl, ios_base& __io,
361 __beg = __intl ? _M_extract<true>(__beg, __end, __io, __err, __str)
362 : _M_extract<false>(__beg, __end, __io, __err, __str);
363 std::__convert_to_v(__str.c_str(), __units, __err, _S_get_c_locale());
368 template<
typename _CharT,
typename _InIter>
372 ios_base::iostate& __err,
long double& __units)
const 375 __beg = __intl ? _M_extract<true>(__beg, __end, __io, __err, __str)
376 : _M_extract<false>(__beg, __end, __io, __err, __str);
377 std::__convert_to_v(__str.
c_str(), __units, __err, _S_get_c_locale());
381 template<
typename _CharT,
typename _InIter>
385 ios_base::iostate& __err,
string_type& __digits)
const 387 typedef typename string::size_type size_type;
390 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
393 __beg = __intl ? _M_extract<true>(__beg, __end, __io, __err, __str)
394 : _M_extract<false>(__beg, __end, __io, __err, __str);
395 const size_type __len = __str.size();
399 __ctype.
widen(__str.data(), __str.data() + __len, &__digits[0]);
404 template<
typename _CharT,
typename _OutIter>
409 const string_type& __digits)
const 411 typedef typename string_type::size_type size_type;
412 typedef money_base::part part;
413 typedef __moneypunct_cache<_CharT, _Intl> __cache_type;
416 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
418 __use_cache<__cache_type> __uc;
419 const __cache_type* __lc = __uc(__loc);
420 const char_type* __lit = __lc->_M_atoms;
424 const char_type* __beg = __digits.data();
426 money_base::pattern __p;
427 const char_type* __sign;
428 size_type __sign_size;
429 if (!(*__beg == __lit[money_base::_S_minus]))
431 __p = __lc->_M_pos_format;
432 __sign = __lc->_M_positive_sign;
433 __sign_size = __lc->_M_positive_sign_size;
437 __p = __lc->_M_neg_format;
438 __sign = __lc->_M_negative_sign;
439 __sign_size = __lc->_M_negative_sign_size;
445 size_type __len = __ctype.
scan_not(ctype_base::digit, __beg,
446 __beg + __digits.size()) - __beg;
453 __value.reserve(2 * __len);
457 long __paddec = __len - __lc->_M_frac_digits;
460 if (__lc->_M_frac_digits < 0)
462 if (__lc->_M_grouping_size)
464 __value.assign(2 * __paddec, char_type());
466 std::__add_grouping(&__value[0], __lc->_M_thousands_sep,
468 __lc->_M_grouping_size,
469 __beg, __beg + __paddec);
470 __value.erase(__vend - &__value[0]);
473 __value.assign(__beg, __paddec);
477 if (__lc->_M_frac_digits > 0)
479 __value += __lc->_M_decimal_point;
481 __value.append(__beg + __paddec, __lc->_M_frac_digits);
485 __value.append(-__paddec, __lit[money_base::_S_zero]);
486 __value.append(__beg, __len);
493 __len = __value.size() + __sign_size;
495 ? __lc->_M_curr_symbol_size : 0);
498 __res.reserve(2 * __len);
500 const size_type __width = static_cast<size_type>(__io.
width());
504 for (
int __i = 0; __i < 4; ++__i)
506 const part __which = static_cast<part>(__p.field[__i]);
509 case money_base::symbol:
511 __res.append(__lc->_M_curr_symbol,
512 __lc->_M_curr_symbol_size);
514 case money_base::sign:
521 case money_base::value:
524 case money_base::space:
529 __res.append(__width - __len, __fill);
533 case money_base::none:
535 __res.append(__width - __len, __fill);
542 __res.append(__sign + 1, __sign_size - 1);
545 __len = __res.size();
550 __res.append(__width - __len, __fill);
553 __res.insert(0, __width - __len, __fill);
558 __s = std::__write(__s, __res.data(), __len);
564 #if defined _GLIBCXX_LONG_DOUBLE_COMPAT && defined __LONG_DOUBLE_128__ \ 565 && _GLIBCXX_USE_CXX11_ABI == 0 566 template<
typename _CharT,
typename _OutIter>
568 money_put<_CharT, _OutIter>::
569 __do_put(iter_type __s,
bool __intl, ios_base& __io, char_type __fill,
570 double __units)
const 571 {
return this->do_put(__s, __intl, __io, __fill, (
long double) __units); }
574 template<
typename _CharT,
typename _OutIter>
578 long double __units)
const 581 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
582 #if _GLIBCXX_USE_C99_STDIO 585 char* __cs = static_cast<char*>(__builtin_alloca(__cs_size));
588 int __len = std::__convert_from_v(_S_get_c_locale(), __cs, __cs_size,
589 "%.*Lf", 0, __units);
591 if (__len >= __cs_size)
593 __cs_size = __len + 1;
594 __cs = static_cast<char*>(__builtin_alloca(__cs_size));
595 __len = std::__convert_from_v(_S_get_c_locale(), __cs, __cs_size,
596 "%.*Lf", 0, __units);
600 const int __cs_size =
601 __gnu_cxx::__numeric_traits<long double>::__max_exponent10 + 3;
602 char* __cs = static_cast<char*>(__builtin_alloca(__cs_size));
603 int __len = std::__convert_from_v(_S_get_c_locale(), __cs, 0,
"%.*Lf",
607 __ctype.
widen(__cs, __cs + __len, &__digits[0]);
608 return __intl ? _M_insert<true>(__s, __io, __fill, __digits)
609 : _M_insert<false>(__s, __io, __fill, __digits);
612 template<
typename _CharT,
typename _OutIter>
617 {
return __intl ? _M_insert<true>(__s, __io, __fill, __digits)
618 : _M_insert<false>(__s, __io, __fill, __digits); }
620 _GLIBCXX_END_NAMESPACE_LDBL_OR_CXX11
625 template<
typename _CharT,
typename _InIter>
628 {
return time_base::no_order; }
632 template<
typename _CharT,
typename _InIter>
636 ios_base::iostate& __err, tm* __tm,
637 const _CharT* __format)
const 640 const __timepunct<_CharT>& __tp = use_facet<__timepunct<_CharT> >(__loc);
641 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
646 for (; __beg != __end && __i < __len && !__tmperr; ++__i)
648 if (__ctype.narrow(__format[__i], 0) ==
'%')
651 char __c = __ctype.narrow(__format[++__i], 0);
653 if (__c ==
'E' || __c ==
'O')
654 __c = __ctype.narrow(__format[++__i], 0);
661 const char_type* __days1[7];
662 __tp._M_days_abbreviated(__days1);
663 __beg = _M_extract_name(__beg, __end, __mem, __days1,
666 __tm->tm_wday = __mem;
670 const char_type* __days2[7];
671 __tp._M_days(__days2);
672 __beg = _M_extract_name(__beg, __end, __mem, __days2,
675 __tm->tm_wday = __mem;
680 const char_type* __months1[12];
681 __tp._M_months_abbreviated(__months1);
682 __beg = _M_extract_name(__beg, __end, __mem,
683 __months1, 12, __io, __tmperr);
685 __tm->tm_mon = __mem;
689 const char_type* __months2[12];
690 __tp._M_months(__months2);
691 __beg = _M_extract_name(__beg, __end, __mem,
692 __months2, 12, __io, __tmperr);
694 __tm->tm_mon = __mem;
698 const char_type* __dt[2];
699 __tp._M_date_time_formats(__dt);
700 __beg = _M_extract_via_format(__beg, __end, __io, __tmperr,
705 __beg = _M_extract_num(__beg, __end, __mem, 1, 31, 2,
708 __tm->tm_mday = __mem;
713 if (__ctype.is(ctype_base::space, *__beg))
714 __beg = _M_extract_num(++__beg, __end, __mem, 1, 9,
717 __beg = _M_extract_num(__beg, __end, __mem, 10, 31,
720 __tm->tm_mday = __mem;
725 __ctype.widen(__cs, __cs + 9, __wcs);
726 __beg = _M_extract_via_format(__beg, __end, __io, __tmperr,
731 __beg = _M_extract_num(__beg, __end, __mem, 0, 23, 2,
734 __tm->tm_hour = __mem;
738 __beg = _M_extract_num(__beg, __end, __mem, 1, 12, 2,
741 __tm->tm_hour = __mem;
745 __beg = _M_extract_num(__beg, __end, __mem, 1, 12, 2,
748 __tm->tm_mon = __mem - 1;
752 __beg = _M_extract_num(__beg, __end, __mem, 0, 59, 2,
755 __tm->tm_min = __mem;
758 if (__ctype.narrow(*__beg, 0) ==
'\n')
766 __ctype.widen(__cs, __cs + 6, __wcs);
767 __beg = _M_extract_via_format(__beg, __end, __io, __tmperr,
774 __beg = _M_extract_num(__beg, __end, __mem, 0, 60, 2,
776 __beg = _M_extract_num(__beg, __end, __mem, 0, 61, 2,
780 __tm->tm_sec = __mem;
783 if (__ctype.narrow(*__beg, 0) ==
'\t')
791 __ctype.widen(__cs, __cs + 9, __wcs);
792 __beg = _M_extract_via_format(__beg, __end, __io, __tmperr,
797 const char_type* __dates[2];
798 __tp._M_date_formats(__dates);
799 __beg = _M_extract_via_format(__beg, __end, __io, __tmperr,
804 const char_type* __times[2];
805 __tp._M_time_formats(__times);
806 __beg = _M_extract_via_format(__beg, __end, __io, __tmperr,
817 __beg = _M_extract_num(__beg, __end, __mem, 0, 9999, 4,
820 __tm->tm_year = __mem < 0 ? __mem + 100 : __mem - 1900;
824 if (__ctype.is(ctype_base::upper, *__beg))
827 __beg = _M_extract_name(__beg, __end, __tmp,
828 __timepunct_cache<_CharT>::_S_timezones,
832 if (__beg != __end && !__tmperr && __tmp == 0
833 && (*__beg == __ctype.widen(
'-')
834 || *__beg == __ctype.widen(
'+')))
836 __beg = _M_extract_num(__beg, __end, __tmp, 0, 23, 2,
838 __beg = _M_extract_num(__beg, __end, __tmp, 0, 59, 2,
853 if (__format[__i] == *__beg)
860 if (__tmperr || __i != __len)
866 template<
typename _CharT,
typename _InIter>
868 time_get<_CharT, _InIter>::
869 _M_extract_num(iter_type __beg, iter_type __end,
int& __member,
870 int __min,
int __max,
size_t __len,
873 const locale& __loc = __io._M_getloc();
874 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
877 int __mult = __len == 2 ? 10 : (__len == 4 ? 1000 : 1);
882 for (; __beg != __end && __i < __len; ++__beg, (void)++__i)
884 const char __c = __ctype.narrow(*__beg,
'*');
885 if (__c >=
'0' && __c <=
'9')
887 __value = __value * 10 + (__c -
'0');
888 const int __valuec = __value * __mult;
889 if (__valuec > __max || __valuec + __mult < __min)
899 else if (__len == 4 && __i == 2)
900 __member = __value - 100;
909 template<
typename _CharT,
typename _InIter>
911 time_get<_CharT, _InIter>::
912 _M_extract_name(iter_type __beg, iter_type __end,
int& __member,
913 const _CharT** __names,
size_t __indexlen,
916 typedef char_traits<_CharT> __traits_type;
917 const locale& __loc = __io._M_getloc();
918 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
920 int* __matches = static_cast<int*>(__builtin_alloca(
sizeof(
int)
922 size_t __nmatches = 0;
924 bool __testvalid =
true;
925 const char_type* __name;
933 const char_type __c = *__beg;
934 for (
size_t __i1 = 0; __i1 < __indexlen; ++__i1)
935 if (__c == __names[__i1][0]
936 || __c == __ctype.toupper(__names[__i1][0]))
937 __matches[__nmatches++] = __i1;
940 while (__nmatches > 1)
943 size_t __minlen = __traits_type::length(__names[__matches[0]]);
944 for (
size_t __i2 = 1; __i2 < __nmatches; ++__i2)
946 __traits_type::length(__names[__matches[__i2]]));
949 if (__pos < __minlen && __beg != __end)
950 for (
size_t __i3 = 0; __i3 < __nmatches;)
952 __name = __names[__matches[__i3]];
953 if (!(__name[__pos] == *__beg))
954 __matches[__i3] = __matches[--__nmatches];
967 __name = __names[__matches[0]];
968 const size_t __len = __traits_type::length(__name);
969 while (__pos < __len && __beg != __end && __name[__pos] == *__beg)
970 ++__beg, (void)++__pos;
973 __member = __matches[0];
985 template<
typename _CharT,
typename _InIter>
987 time_get<_CharT, _InIter>::
988 _M_extract_wday_or_month(iter_type __beg, iter_type __end,
int& __member,
989 const _CharT** __names,
size_t __indexlen,
992 typedef char_traits<_CharT> __traits_type;
993 const locale& __loc = __io._M_getloc();
994 const ctype<_CharT>& __ctype = use_facet<ctype<_CharT> >(__loc);
996 int* __matches = static_cast<int*>(__builtin_alloca(2 *
sizeof(
int)
998 size_t __nmatches = 0;
999 size_t* __matches_lengths = 0;
1004 const char_type __c = *__beg;
1005 for (
size_t __i = 0; __i < 2 * __indexlen; ++__i)
1006 if (__c == __names[__i][0]
1007 || __c == __ctype.toupper(__names[__i][0]))
1008 __matches[__nmatches++] = __i;
1017 = static_cast<size_t*>(__builtin_alloca(
sizeof(
size_t)
1019 for (
size_t __i = 0; __i < __nmatches; ++__i)
1020 __matches_lengths[__i]
1021 = __traits_type::length(__names[__matches[__i]]);
1024 for (; __beg != __end; ++__beg, (void)++__pos)
1026 size_t __nskipped = 0;
1027 const char_type __c = *__beg;
1028 for (
size_t __i = 0; __i < __nmatches;)
1030 const char_type* __name = __names[__matches[__i]];
1031 if (__pos >= __matches_lengths[__i])
1032 ++__nskipped, ++__i;
1033 else if (!(__name[__pos] == __c))
1036 __matches[__i] = __matches[__nmatches];
1037 __matches_lengths[__i] = __matches_lengths[__nmatches];
1042 if (__nskipped == __nmatches)
1046 if ((__nmatches == 1 && __matches_lengths[0] == __pos)
1047 || (__nmatches == 2 && (__matches_lengths[0] == __pos
1048 || __matches_lengths[1] == __pos)))
1049 __member = (__matches[0] >= __indexlen
1050 ? __matches[0] - __indexlen : __matches[0]);
1057 template<
typename _CharT,
typename _InIter>
1061 ios_base::iostate& __err, tm* __tm)
const 1064 const __timepunct<_CharT>& __tp = use_facet<__timepunct<_CharT> >(__loc);
1066 __tp._M_time_formats(__times);
1067 __beg = _M_extract_via_format(__beg, __end, __io, __err,
1074 template<
typename _CharT,
typename _InIter>
1078 ios_base::iostate& __err, tm* __tm)
const 1081 const __timepunct<_CharT>& __tp = use_facet<__timepunct<_CharT> >(__loc);
1083 __tp._M_date_formats(__dates);
1084 __beg = _M_extract_via_format(__beg, __end, __io, __err,
1091 template<
typename _CharT,
typename _InIter>
1095 ios_base::iostate& __err, tm* __tm)
const 1098 const __timepunct<_CharT>& __tp = use_facet<__timepunct<_CharT> >(__loc);
1100 __tp._M_days_abbreviated(__days);
1101 __tp._M_days(__days + 7);
1105 __beg = _M_extract_wday_or_month(__beg, __end, __tmpwday, __days, 7,
1108 __tm->tm_wday = __tmpwday;
1117 template<
typename _CharT,
typename _InIter>
1121 ios_base& __io, ios_base::iostate& __err, tm* __tm)
const 1124 const __timepunct<_CharT>& __tp = use_facet<__timepunct<_CharT> >(__loc);
1126 __tp._M_months_abbreviated(__months);
1127 __tp._M_months(__months + 12);
1131 __beg = _M_extract_wday_or_month(__beg, __end, __tmpmon, __months, 12,
1134 __tm->tm_mon = __tmpmon;
1143 template<
typename _CharT,
typename _InIter>
1147 ios_base::iostate& __err, tm* __tm)
const 1152 __beg = _M_extract_num(__beg, __end, __tmpyear, 0, 9999, 4,
1155 __tm->tm_year = __tmpyear < 0 ? __tmpyear + 100 : __tmpyear - 1900;
1164 #if __cplusplus >= 201103L 1165 template<
typename _CharT,
typename _InIter>
1170 ios_base::iostate& __err, tm* __tm,
const char_type* __fmt,
1174 ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
1176 while (__fmt != __fmtend &&
1184 else if (__ctype.
narrow(*__fmt, 0) ==
'%')
1188 if (++__fmt == __fmtend)
1193 const char __c = __ctype.
narrow(*__fmt, 0);
1194 if (__c !=
'E' && __c !=
'O')
1196 else if (++__fmt != __fmtend)
1199 __format = __ctype.
narrow(*__fmt, 0);
1206 __s = this->do_get(__s, __end, __io, __err, __tm, __format,
1210 else if (__ctype.
is(ctype_base::space, *__fmt))
1213 while (__fmt != __fmtend &&
1214 __ctype.
is(ctype_base::space, *__fmt))
1217 while (__s != __end &&
1218 __ctype.
is(ctype_base::space, *__s))
1237 template<
typename _CharT,
typename _InIter>
1242 ios_base::iostate& __err, tm* __tm,
1243 char __format,
char __mod)
const 1246 ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
1250 __fmt[0] = __ctype.
widen(
'%');
1253 __fmt[1] = __format;
1259 __fmt[2] = __format;
1263 __beg = _M_extract_via_format(__beg, __end, __io, __err, __tm, __fmt);
1269 #endif // __cplusplus >= 201103L 1271 template<
typename _CharT,
typename _OutIter>
1275 const _CharT* __beg,
const _CharT* __end)
const 1278 ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
1279 for (; __beg != __end; ++__beg)
1280 if (__ctype.
narrow(*__beg, 0) !=
'%')
1285 else if (++__beg != __end)
1289 const char __c = __ctype.
narrow(*__beg, 0);
1290 if (__c !=
'E' && __c !=
'O')
1292 else if (++__beg != __end)
1295 __format = __ctype.
narrow(*__beg, 0);
1299 __s = this->do_put(__s, __io, __fill, __tm, __format, __mod);
1306 template<
typename _CharT,
typename _OutIter>
1310 char __format,
char __mod)
const 1313 ctype<_CharT> const& __ctype = use_facet<ctype<_CharT> >(__loc);
1314 __timepunct<_CharT>
const& __tp = use_facet<__timepunct<_CharT> >(__loc);
1318 const size_t __maxlen = 128;
1327 __fmt[0] = __ctype.
widen(
'%');
1330 __fmt[1] = __format;
1336 __fmt[2] = __format;
1340 __tp._M_put(__res, __maxlen, __fmt, __tm);
1349 #if _GLIBCXX_EXTERN_TEMPLATE 1354 extern template class _GLIBCXX_NAMESPACE_LDBL_OR_CXX11
money_get<char>;
1355 extern template class _GLIBCXX_NAMESPACE_LDBL_OR_CXX11
money_put<char>;
1356 extern template class __timepunct<char>;
1366 use_facet<moneypunct<char, true> >(
const locale&);
1370 use_facet<moneypunct<char, false> >(
const locale&);
1374 use_facet<money_put<char> >(
const locale&);
1378 use_facet<money_get<char> >(
const locale&);
1381 const __timepunct<char>&
1382 use_facet<__timepunct<char> >(
const locale&);
1386 use_facet<time_put<char> >(
const locale&);
1390 use_facet<time_get<char> >(
const locale&);
1394 use_facet<messages<char> >(
const locale&);
1398 has_facet<moneypunct<char> >(
const locale&);
1402 has_facet<money_put<char> >(
const locale&);
1406 has_facet<money_get<char> >(
const locale&);
1410 has_facet<__timepunct<char> >(
const locale&);
1414 has_facet<time_put<char> >(
const locale&);
1418 has_facet<time_get<char> >(
const locale&);
1422 has_facet<messages<char> >(
const locale&);
1424 #ifdef _GLIBCXX_USE_WCHAR_T 1431 extern template class __timepunct<wchar_t>;
1441 use_facet<moneypunct<wchar_t, true> >(
const locale&);
1445 use_facet<moneypunct<wchar_t, false> >(
const locale&);
1449 use_facet<money_put<wchar_t> >(
const locale&);
1453 use_facet<money_get<wchar_t> >(
const locale&);
1456 const __timepunct<wchar_t>&
1457 use_facet<__timepunct<wchar_t> >(
const locale&);
1461 use_facet<time_put<wchar_t> >(
const locale&);
1465 use_facet<time_get<wchar_t> >(
const locale&);
1469 use_facet<messages<wchar_t> >(
const locale&);
1473 has_facet<moneypunct<wchar_t> >(
const locale&);
1477 has_facet<money_put<wchar_t> >(
const locale&);
1481 has_facet<money_get<wchar_t> >(
const locale&);
1485 has_facet<__timepunct<wchar_t> >(
const locale&);
1489 has_facet<time_put<wchar_t> >(
const locale&);
1493 has_facet<time_get<wchar_t> >(
const locale&);
1497 has_facet<messages<wchar_t> >(
const locale&);
1501 _GLIBCXX_END_NAMESPACE_VERSION
class moneypunct_byname [22.2.6.4].
static const iostate failbit
Indicates that an input operation failed to read the expected characters, or that an output operation...
_CharT char_type
Public typedefs.
Primary class template time_put.This facet encapsulates the code to format and output dates and times...
virtual iter_type do_get_date(iter_type __beg, iter_type __end, ios_base &__io, ios_base::iostate &__err, tm *__tm) const
Parse input date string.
class messages_byname [22.2.7.2].
Primary class template money_put.This facet encapsulates the code to format and output a monetary amo...
Primary class template moneypunct.This facet encapsulates the punctuation, grouping and other formatt...
virtual dateorder do_date_order() const
Return preferred order of month, day, and year.
static const iostate goodbit
Indicates all is well.
fmtflags flags() const
Access to format flags.
The base of the I/O class hierarchy.This class defines everything that can be defined about I/O that ...
virtual iter_type do_get_weekday(iter_type __beg, iter_type __end, ios_base &, ios_base::iostate &__err, tm *__tm) const
Parse input weekday string.
bool is(mask __m, char_type __c) const
Test char_type classification.
char_type toupper(char_type __c) const
Convert to uppercase.
Primary class template messages.This facet encapsulates the code to retrieve messages from message ca...
Primary class template money_get.This facet encapsulates the code to parse and return a monetary amou...
iter_type put(iter_type __s, ios_base &__io, char_type __fill, const tm *__tm, const _CharT *__beg, const _CharT *__end) const
Format and output a time or date.
_Ios_Fmtflags fmtflags
This is a bitmask type.
char_type widen(char __c) const
Widen char to char_type.
virtual iter_type do_get(iter_type __s, iter_type __end, bool __intl, ios_base &__io, ios_base::iostate &__err, long double &__units) const
Read and parse a monetary value.
const char_type * scan_not(mask __m, const char_type *__lo, const char_type *__hi) const
Find char_type not matching a mask.
static const fmtflags adjustfield
A mask of left|right|internal. Useful for the 2-arg form of setf.
char_type tolower(char_type __c) const
Convert to lowercase.
static const iostate eofbit
Indicates that an input operation reached the end of an input sequence.
virtual iter_type do_get_year(iter_type __beg, iter_type __end, ios_base &__io, ios_base::iostate &__err, tm *__tm) const
Parse input year string.
ISO C++ entities toplevel namespace is std.
_GLIBCXX14_CONSTEXPR const _Tp & min(const _Tp &, const _Tp &)
This does what you think it does.
_CharT char_type
Public typedefs.
static const fmtflags left
Adds fill characters on the right (final positions) of certain generated output. (I....
Basis for explicit traits specializations.
_OutIter iter_type
Public typedefs.
const _CharT * c_str() const noexcept
Return const pointer to null-terminated contents.
static const fmtflags showbase
Generates a prefix indicating the numeric base of generated integer output.
streamsize width() const
Flags access.
virtual iter_type do_put(iter_type __s, bool __intl, ios_base &__io, char_type __fill, long double __units) const
Format and output a monetary value.
static const size_type npos
Value returned by various member functions when they fail.
char narrow(char_type __c, char __dfault) const
Narrow char_type to char.
class time_get_byname [22.2.5.2].
virtual iter_type do_put(iter_type __s, ios_base &__io, char_type __fill, const tm *__tm, char __format, char __mod) const
Format and output a time or date.
virtual iter_type do_get_monthname(iter_type __beg, iter_type __end, ios_base &, ios_base::iostate &__err, tm *__tm) const
Parse input month string.
_Ios_Iostate iostate
This is a bitmask type.
_InIter iter_type
Public typedefs.
static const fmtflags internal
Adds fill characters at a designated internal point in certain generated output, or identical to righ...
iter_type do_get(iter_type __s, iter_type __end, ios_base &__f, ios_base::iostate &__err, tm *__tm, char __format, char __modifier) const
Parse input string according to format.
Container class for localization functionality.The locale class is first a class wrapper for C librar...
void resize(size_type __n, _CharT __c)
Resizes the string to the specified number of characters.
locale getloc() const
Locale access.
virtual iter_type do_get_time(iter_type __beg, iter_type __end, ios_base &__io, ios_base::iostate &__err, tm *__tm) const
Parse input time string.
iter_type get(iter_type __s, iter_type __end, ios_base &__io, ios_base::iostate &__err, tm *__tm, char __format, char __modifier=0) const
Parse input string according to format.
class time_put_byname [22.2.5.4].
static locale::id id
Numpunct facet id.
Primary class template time_get.This facet encapsulates the code to parse and return a date or time f...
_OutIter iter_type
Public typedefs.
_InIter iter_type
Public typedefs.
_CharT char_type
Public typedefs.
const locale & _M_getloc() const
Locale access.
Primary class template ctype facet.This template class defines classification and conversion function...