30#ifndef _GLIBCXX_CHRONO_IO_H
31#define _GLIBCXX_CHRONO_IO_H 1
34#pragma GCC system_header
37#if __cplusplus >= 202002L
48namespace std _GLIBCXX_VISIBILITY(default)
50_GLIBCXX_BEGIN_NAMESPACE_VERSION
60#define _GLIBCXX_WIDEN_(C, S) ::std::__format::_Widen<C>(S, L##S)
61#define _GLIBCXX_WIDEN(S) _GLIBCXX_WIDEN_(_CharT, S)
63 template<
typename _Period,
typename _CharT>
65 __units_suffix()
noexcept
70#define _GLIBCXX_UNITS_SUFFIX(period, suffix) \
71 if constexpr (is_same_v<_Period, period>) \
72 return _GLIBCXX_WIDEN(suffix); \
75 _GLIBCXX_UNITS_SUFFIX(
atto,
"as")
76 _GLIBCXX_UNITS_SUFFIX(
femto,
"fs")
77 _GLIBCXX_UNITS_SUFFIX(
pico,
"ps")
78 _GLIBCXX_UNITS_SUFFIX(
nano,
"ns")
79 _GLIBCXX_UNITS_SUFFIX(
milli,
"ms")
80#if _GLIBCXX_USE_ALT_MICROSECONDS_SUFFIX
83 _GLIBCXX_UNITS_SUFFIX(
micro,
"\u00b5s")
85 _GLIBCXX_UNITS_SUFFIX(
micro,
"us")
87 _GLIBCXX_UNITS_SUFFIX(
centi,
"cs")
88 _GLIBCXX_UNITS_SUFFIX(
deci,
"ds")
90 _GLIBCXX_UNITS_SUFFIX(
deca,
"das")
91 _GLIBCXX_UNITS_SUFFIX(
hecto,
"hs")
92 _GLIBCXX_UNITS_SUFFIX(
kilo,
"ks")
93 _GLIBCXX_UNITS_SUFFIX(
mega,
"Ms")
94 _GLIBCXX_UNITS_SUFFIX(
giga,
"Gs")
95 _GLIBCXX_UNITS_SUFFIX(
tera,
"Ts")
96 _GLIBCXX_UNITS_SUFFIX(
tera,
"Ts")
97 _GLIBCXX_UNITS_SUFFIX(
peta,
"Ps")
98 _GLIBCXX_UNITS_SUFFIX(
exa,
"Es")
102#undef _GLIBCXX_UNITS_SUFFIX
106 template<
typename _Period,
typename _CharT,
typename _Out>
108 __fmt_units_suffix(_Out __out)
noexcept
110 if (
auto __s = __detail::__units_suffix<_Period, _CharT>(); __s.size())
111 return __format::__write(
std::move(__out), __s);
112 else if constexpr (_Period::den == 1)
113 return std::format_to(
std::move(__out), _GLIBCXX_WIDEN(
"[{}]s"),
114 (uintmax_t)_Period::num);
116 return std::format_to(
std::move(__out), _GLIBCXX_WIDEN(
"[{}/{}]s"),
117 (uintmax_t)_Period::num,
118 (uintmax_t)_Period::den);
127 template<
typename _CharT,
typename _Traits,
128 typename _Rep,
typename _Period>
134 using period =
typename _Period::type;
142 __detail::__fmt_units_suffix<period, _CharT>(_Out(__s));
152 template<
typename _Duration>
153 struct __local_time_fmt
156 const string* _M_abbrev;
162 template<
typename _Duration>
163 using __local_time_fmt_for
164 = __local_time_fmt<common_type_t<_Duration, seconds>>;
177 template<
typename _Duration>
178 inline __detail::__local_time_fmt<_Duration>
180 const string* __abbrev =
nullptr,
181 const seconds* __offset_sec =
nullptr)
182 {
return {__time, __abbrev, __offset_sec}; }
190 [[noreturn,__gnu__::__always_inline__]]
192 __no_timezone_available()
193 { __throw_format_error(
"format error: no timezone available for %Z or %z"); }
195 [[noreturn,__gnu__::__always_inline__]]
197 __not_valid_for_duration()
198 { __throw_format_error(
"format error: chrono-format-spec not valid for "
199 "chrono::duration"); }
201 [[noreturn,__gnu__::__always_inline__]]
203 __invalid_chrono_spec()
204 { __throw_format_error(
"format error: chrono-format-spec not valid for "
207 template<
typename _CharT>
208 struct _ChronoSpec : _Spec<_CharT>
210 basic_string_view<_CharT> _M_chrono_specs;
219 _M_locale_specific() const noexcept
220 {
return this->_M_reserved; }
223 _M_locale_specific(
bool __b)
noexcept
224 { this->_M_reserved = __b; }
231 _Year = 1, _Month = 2, _Day = 4, _Weekday = 8, _TimeOfDay = 16,
233 _Date = _Year | _Month | _Day | _Weekday,
234 _DateTime = _Date | _TimeOfDay,
235 _ZonedDateTime = _DateTime | _TimeZone,
239 constexpr _ChronoParts
240 operator|(_ChronoParts __x, _ChronoParts __y)
noexcept
241 {
return static_cast<_ChronoParts
>((int)__x | (
int)__y); }
243 constexpr _ChronoParts&
244 operator|=(_ChronoParts& __x, _ChronoParts __y)
noexcept
245 {
return __x = __x | __y; }
248 template<
typename _CharT>
249 struct __formatter_chrono
251 using __string_view = basic_string_view<_CharT>;
252 using __string = basic_string<_CharT>;
254 template<
typename _ParseContext>
255 constexpr typename _ParseContext::iterator
256 _M_parse(_ParseContext& __pc, _ChronoParts __parts)
258 auto __first = __pc.
begin();
259 auto __last = __pc.end();
261 _ChronoSpec<_CharT> __spec{};
263 auto __finalize = [
this, &__spec] {
267 auto __finished = [&] {
268 if (__first == __last || *__first ==
'}')
279 __first = __spec._M_parse_fill_and_align(__first, __last);
283 __first = __spec._M_parse_width(__first, __last, __pc);
287 if (__parts & _ChronoParts::_Duration)
289 __first = __spec._M_parse_precision(__first, __last, __pc);
294 __first = __spec._M_parse_locale(__first, __last);
301 __string_view __str(__first, __last - __first);
302 auto __end = __str.find(
'}');
303 if (__end != __str.npos)
305 __str.remove_suffix(__str.length() - __end);
306 __last = __first + __end;
308 if (__str.find(
'{') != __str.npos)
309 __throw_format_error(
"chrono format error: '{' in chrono-specs");
316 const auto __chrono_specs = __first++;
317 if (*__chrono_specs !=
'%')
318 __throw_format_error(
"chrono format error: no '%' at start of "
324 bool __locale_specific =
false;
326 while (__first != __last)
328 enum _Mods { _Mod_none, _Mod_E, _Mod_O, _Mod_E_O };
329 _Mods __allowed_mods = _Mod_none;
331 _CharT __c = *__first++;
337 __locale_specific =
true;
343 __locale_specific =
true;
346 __needed = _DateTime;
347 __allowed_mods = _Mod_E;
348 __locale_specific =
true;
352 __allowed_mods = _Mod_E;
357 __allowed_mods = _Mod_O;
369 __needed = _TimeOfDay;
370 __allowed_mods = _Mod_O;
373 if (!(__parts & _Duration))
378 __allowed_mods = _Mod_O;
381 __needed = _TimeOfDay;
382 __allowed_mods = _Mod_O;
386 __locale_specific =
true;
390 __needed = _TimeOfDay;
394 __needed = _Duration;
397 __needed = _TimeOfDay;
398 __allowed_mods = _Mod_O;
403 __allowed_mods = _Mod_O;
409 __allowed_mods = _Mod_O;
413 __locale_specific =
true;
414 __allowed_mods = _Mod_E;
417 __needed = _TimeOfDay;
418 __locale_specific =
true;
419 __allowed_mods = _Mod_E;
423 __allowed_mods = _Mod_E_O;
427 __allowed_mods = _Mod_E;
430 __needed = _TimeZone;
431 __allowed_mods = _Mod_E_O;
434 __needed = _TimeZone;
442 if (__mod) [[unlikely]]
444 __allowed_mods = _Mod_none;
450 __throw_format_error(
"chrono format error: invalid "
451 " specifier in chrono-specs");
454 if ((__mod ==
'E' && !(__allowed_mods & _Mod_E))
455 || (__mod ==
'O' && !(__allowed_mods & _Mod_O)))
456 __throw_format_error(
"chrono format error: invalid "
457 " modifier in chrono-specs");
458 if (__mod && __c !=
'z')
459 __locale_specific =
true;
462 if ((__parts & __needed) != __needed)
463 __throw_format_error(
"chrono format error: format argument "
464 "does not contain the information "
465 "required by the chrono-specs");
468 size_t __pos = __string_view(__first, __last - __first).find(
'%');
473 if (__pos == __string_view::npos)
479 __first += __pos + 1;
484 if (__conv || __mod != _CharT())
485 __throw_format_error(
"chrono format error: unescaped '%' in "
489 _M_spec._M_chrono_specs
490 = __string_view(__chrono_specs, __first - __chrono_specs);
491 _M_spec._M_locale_specific(__locale_specific);
501 template<
typename _Tp,
typename _FormatContext>
502 typename _FormatContext::iterator
503 _M_format(
const _Tp& __t, _FormatContext& __fc,
504 bool __is_neg =
false)
const
506 auto __first = _M_spec._M_chrono_specs.begin();
507 const auto __last = _M_spec._M_chrono_specs.end();
508 if (__first == __last)
509 return _M_format_to_ostream(__t, __fc, __is_neg);
511#if defined _GLIBCXX_USE_NL_LANGINFO_L && __CHAR_BIT__ == 8
515 if constexpr (is_same_v<_CharT, char>)
516 if constexpr (__unicode::__literal_encoding_is_utf8())
517 if (_M_spec._M_localized && _M_spec._M_locale_specific())
519 extern locale __with_encoding_conversion(
const locale&);
523 locale __loc = __fc.locale();
524 if (__loc != locale::classic())
525 __fc._M_loc = __with_encoding_conversion(__loc);
529 _Sink_iter<_CharT> __out;
530 __format::_Str_sink<_CharT> __sink;
531 bool __write_direct =
false;
532 if constexpr (is_same_v<
typename _FormatContext::iterator,
535 if (_M_spec._M_width_kind == __format::_WP_none)
538 __write_direct =
true;
541 __out = __sink.out();
544 __out = __sink.out();
548 if constexpr (__is_specialization_of<_Tp, chrono::hh_mm_ss>)
549 __is_neg = __t.is_negative();
551 auto __print_sign = [&__is_neg, &__out] {
552 if constexpr (chrono::__is_duration_v<_Tp>
553 || __is_specialization_of<_Tp, chrono::hh_mm_ss>)
556 *__out++ = _S_plus_minus[1];
563 constexpr const _CharT* __literals = _GLIBCXX_WIDEN(
"\n\t%");
570 _CharT __c = *__first++;
575 __out = _M_a_A(__t,
std::move(__out), __fc, __c ==
'A');
580 __out = _M_b_B(__t,
std::move(__out), __fc, __c ==
'B');
586 __out = _M_c_r_x_X(__t,
std::move(__out), __fc, __c, __mod);
591 __out = _M_C_y_Y(__t,
std::move(__out), __fc, __c, __mod);
595 __out = _M_d_e(__t,
std::move(__out), __fc, __c, __mod ==
'O');
598 __out = _M_D(__t,
std::move(__out), __fc);
601 __out = _M_F(__t,
std::move(__out), __fc);
605 __out = _M_g_G(__t,
std::move(__out), __fc, __c ==
'G');
609 __out = _M_H_I(__t, __print_sign(), __fc, __c, __mod ==
'O');
612 __out = _M_j(__t, __print_sign(), __fc);
615 __out = _M_m(__t,
std::move(__out), __fc, __mod ==
'O');
618 __out = _M_M(__t, __print_sign(), __fc, __mod ==
'O');
621 __out = _M_p(__t,
std::move(__out), __fc);
624 __out = _M_q(__t,
std::move(__out), __fc);
628 if constexpr (chrono::__is_duration_v<_Tp>)
631 __out = std::format_to(__print_sign(), _S_empty_spec,
634 __throw_format_error(
"chrono format error: argument is "
639 __out = _M_R_T(__t, __print_sign(), __fc, __c ==
'T');
642 __out = _M_S(__t, __print_sign(), __fc, __mod ==
'O');
646 __out = _M_u_w(__t,
std::move(__out), __fc, __c, __mod ==
'O');
651 __out = _M_U_V_W(__t,
std::move(__out), __fc, __c,
655 __out = _M_z(__t,
std::move(__out), __fc, (
bool)__mod);
658 __out = _M_Z(__t,
std::move(__out), __fc);
661 *__out++ = __literals[0];
664 *__out++ = __literals[1];
667 *__out++ = __literals[2];
679 __string_view __str(__first, __last - __first);
680 size_t __pos = __str.find(
'%');
685 if (__pos == __str.npos)
689 __str.remove_suffix(__str.length() - __pos);
690 __first += __pos + 1;
692 __out = __format::__write(
std::move(__out), __str);
695 while (__first != __last);
697 if constexpr (is_same_v<
typename _FormatContext::iterator,
702 auto __span = __sink.view();
703 __string_view __str(__span.data(), __span.size());
705 if constexpr (__unicode::__literal_encoding_is_unicode<_CharT>())
706 __width = __unicode::__field_width(__str);
708 __width = __str.size();
709 return __format::__write_padded_as_spec(__str, __width,
713 _ChronoSpec<_CharT> _M_spec;
717 template<
typename _FormatContext>
719 _M_locale(_FormatContext& __fc)
const
721 if (!_M_spec._M_localized)
724 return __fc.locale();
732 template<
typename _Tp,
typename _FormatContext>
733 typename _FormatContext::iterator
734 _M_format_to_ostream(
const _Tp& __t, _FormatContext& __fc,
737 using ::std::chrono::__detail::__utc_leap_second;
738 using ::std::chrono::__detail::__local_time_fmt;
740 basic_ostringstream<_CharT> __os;
741 __os.imbue(_M_locale(__fc));
743 if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
746 auto __days = chrono::floor<chrono::days>(__t._M_time);
747 __os << chrono::year_month_day(__days) <<
' '
748 << chrono::hh_mm_ss(__t._M_time - __days);
754 if (!__t._M_abbrev) [[unlikely]]
755 __format::__no_timezone_available();
756 else if constexpr (is_same_v<_CharT, char>)
757 __os <<
' ' << *__t._M_abbrev;
761 for (
char __c : *__t._M_abbrev)
768 if constexpr (__is_specialization_of<_Tp, __utc_leap_second>)
769 __os << __t._M_date <<
' ' << __t._M_time;
770 else if constexpr (chrono::__is_time_point_v<_Tp>)
777 if constexpr (is_convertible_v<_Tp, chrono::sys_days>)
778 __os << _S_date(__t);
780 else if constexpr (is_convertible_v<_Tp, chrono::local_days>)
781 __os << _S_date(__t);
784 auto __days = chrono::floor<chrono::days>(__t);
785 __os << chrono::year_month_day(__days) <<
' '
786 << chrono::hh_mm_ss(__t - __days);
791 if constexpr (chrono::__is_duration_v<_Tp>)
792 if (__is_neg) [[unlikely]]
793 __os << _S_plus_minus[1];
799 return __format::__write_padded_as_spec(__str, __str.size(),
803 static constexpr const _CharT* _S_chars
804 = _GLIBCXX_WIDEN(
"0123456789+-:/ {}");
805 static constexpr const _CharT* _S_plus_minus = _S_chars + 10;
806 static constexpr _CharT _S_colon = _S_chars[12];
807 static constexpr _CharT _S_slash = _S_chars[13];
808 static constexpr _CharT _S_space = _S_chars[14];
809 static constexpr const _CharT* _S_empty_spec = _S_chars + 15;
811 template<
typename _OutIter>
813 _M_write(_OutIter __out,
const locale& __loc, __string_view __s)
const
815#if defined _GLIBCXX_USE_NL_LANGINFO_L && __CHAR_BIT__ == 8
820 if constexpr (is_same_v<_CharT, char>)
821 if constexpr (__unicode::__literal_encoding_is_utf8())
822 if (_M_spec._M_localized && _M_spec._M_locale_specific()
823 && __loc != locale::classic())
826 __locale_encoding_to_utf8(
const locale&, string_view,
void*);
828 __s = __locale_encoding_to_utf8(__loc, __s, &__buf);
831 return __format::__write(
std::move(__out), __s);
834 template<
typename _Tp,
typename _FormatContext>
835 typename _FormatContext::iterator
836 _M_a_A(
const _Tp& __t,
typename _FormatContext::iterator __out,
837 _FormatContext& __ctx,
bool __full)
const
841 chrono::weekday __wd = _S_weekday(__t);
843 __throw_format_error(
"format error: invalid weekday");
845 locale __loc = _M_locale(__ctx);
846 const auto& __tp = use_facet<__timepunct<_CharT>>(__loc);
847 const _CharT* __days[7];
849 __tp._M_days(__days);
851 __tp._M_days_abbreviated(__days);
852 __string_view __str(__days[__wd.c_encoding()]);
853 return _M_write(
std::move(__out), __loc, __str);
856 template<
typename _Tp,
typename _FormatContext>
857 typename _FormatContext::iterator
858 _M_b_B(
const _Tp& __t,
typename _FormatContext::iterator __out,
859 _FormatContext& __ctx,
bool __full)
const
863 chrono::month __m = _S_month(__t);
865 __throw_format_error(
"format error: invalid month");
866 locale __loc = _M_locale(__ctx);
867 const auto& __tp = use_facet<__timepunct<_CharT>>(__loc);
868 const _CharT* __months[12];
870 __tp._M_months(__months);
872 __tp._M_months_abbreviated(__months);
873 __string_view __str(__months[(
unsigned)__m - 1]);
874 return _M_write(
std::move(__out), __loc, __str);
877 template<
typename _Tp,
typename _FormatContext>
878 typename _FormatContext::iterator
879 _M_c_r_x_X(
const _Tp& __t,
typename _FormatContext::iterator __out,
880 _FormatContext& __ctx, _CharT __conv, _CharT __mod)
const
890 using namespace chrono;
891 using ::std::chrono::__detail::__utc_leap_second;
892 using ::std::chrono::__detail::__local_time_fmt;
902#ifdef _GLIBCXX_USE_STRUCT_TM_TM_ZONE
905 if constexpr (__is_time_point_v<_Tp>)
908 if constexpr (!is_same_v<typename _Tp::clock, local_t>)
909 __tm.tm_zone =
const_cast<char*
>(
"UTC");
911 else if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
916 __tm.tm_zone =
const_cast<char*
>(__t._M_abbrev->c_str());
919 __tm.tm_zone =
const_cast<char*
>(
"UTC");
922 if (__conv ==
'c' || __conv ==
'x')
924 auto __d = _S_days(__t);
925 using _TDays =
decltype(__d);
926 const year_month_day __ymd(__d);
927 const auto __y = __ymd.year();
929 __tm.tm_year = (int)__y - 1900;
930 __tm.tm_yday = (__d - _TDays(__y/January/1)).count();
931 __tm.tm_mon = (unsigned)__ymd.month() - 1;
932 __tm.tm_mday = (unsigned)__ymd.day();
933 __tm.tm_wday = weekday(__d).c_encoding();
938 const auto __hms = _S_hms(__t);
939 __tm.tm_hour = __hms.hours().count();
940 __tm.tm_min = __hms.minutes().count();
941 __tm.tm_sec = __hms.seconds().count();
944 return _M_locale_fmt(
std::move(__out), _M_locale(__ctx), __tm,
948 template<
typename _Tp,
typename _FormatContext>
949 typename _FormatContext::iterator
950 _M_C_y_Y(
const _Tp& __t,
typename _FormatContext::iterator __out,
951 _FormatContext& __ctx, _CharT __conv, _CharT __mod = 0)
const
961 chrono::year __y = _S_year(__t);
963 if (__mod && _M_spec._M_localized) [[unlikely]]
964 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
967 __tm.tm_year = (int)__y - 1900;
968 return _M_locale_fmt(
std::move(__out), __loc, __tm,
972 basic_string<_CharT> __s;
974 const bool __is_neg = __yi < 0;
975 __yi = __builtin_abs(__yi);
977 if (__conv ==
'Y' || __conv ==
'C')
979 int __ci = __yi / 100;
980 if (__is_neg) [[unlikely]]
982 __s.assign(1, _S_plus_minus[1]);
984 if (__conv ==
'C' && (__ci * 100) != __yi)
987 if (__ci >= 100) [[unlikely]]
989 __s += std::format(_S_empty_spec, __ci / 100);
992 __s += _S_two_digits(__ci);
995 if (__conv ==
'Y' || __conv ==
'y')
996 __s += _S_two_digits(__yi % 100);
998 return __format::__write(
std::move(__out), __string_view(__s));
1001 template<
typename _Tp,
typename _FormatContext>
1002 typename _FormatContext::iterator
1003 _M_D(
const _Tp& __t,
typename _FormatContext::iterator __out,
1004 _FormatContext&)
const
1006 auto __ymd = _S_date(__t);
1007 basic_string<_CharT> __s;
1008#if ! _GLIBCXX_USE_CXX11_ABI
1011 __s = _S_two_digits((
unsigned)__ymd.month());
1013 __s += _S_two_digits((
unsigned)__ymd.day());
1015 __s += _S_two_digits(__builtin_abs((
int)__ymd.year()) % 100);
1016 return __format::__write(
std::move(__out), __string_view(__s));
1019 template<
typename _Tp,
typename _FormatContext>
1020 typename _FormatContext::iterator
1021 _M_d_e(
const _Tp& __t,
typename _FormatContext::iterator __out,
1022 _FormatContext& __ctx, _CharT __conv,
bool __mod =
false)
const
1029 chrono::day __d = _S_day(__t);
1030 unsigned __i = (unsigned)__d;
1032 if (__mod && _M_spec._M_localized) [[unlikely]]
1033 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1037 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1041 auto __sv = _S_two_digits(__i);
1043 if (__conv == _CharT(
'e') && __i < 10)
1045 __buf[0] = _S_space;
1049 return __format::__write(
std::move(__out), __sv);
1052 template<
typename _Tp,
typename _FormatContext>
1053 typename _FormatContext::iterator
1054 _M_F(
const _Tp& __t,
typename _FormatContext::iterator __out,
1055 _FormatContext&)
const
1057 auto __ymd = _S_date(__t);
1058 auto __s = std::format(_GLIBCXX_WIDEN(
"{:04d}- - "),
1060 auto __sv = _S_two_digits((
unsigned)__ymd.month());
1061 __s[__s.size() - 5] = __sv[0];
1062 __s[__s.size() - 4] = __sv[1];
1063 __sv = _S_two_digits((
unsigned)__ymd.day());
1064 __s[__s.size() - 2] = __sv[0];
1065 __s[__s.size() - 1] = __sv[1];
1067 return __format::__write(
std::move(__out), __sv);
1070 template<
typename _Tp,
typename _FormatContext>
1071 typename _FormatContext::iterator
1072 _M_g_G(
const _Tp& __t,
typename _FormatContext::iterator __out,
1073 _FormatContext& __ctx,
bool __full)
const
1077 using namespace chrono;
1078 auto __d = _S_days(__t);
1080 __d -= (weekday(__d) - Monday) -
days(3);
1082 year __y = year_month_day(__d).year();
1083 return _M_C_y_Y(__y,
std::move(__out), __ctx,
"yY"[__full]);
1086 template<
typename _Tp,
typename _FormatContext>
1087 typename _FormatContext::iterator
1088 _M_H_I(
const _Tp& __t,
typename _FormatContext::iterator __out,
1089 _FormatContext& __ctx, _CharT __conv,
bool __mod =
false)
const
1096 const auto __hms = _S_hms(__t);
1097 int __i = __hms.hours().count();
1099 if (__mod && _M_spec._M_localized) [[unlikely]]
1100 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1104 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1108 if (__conv == _CharT(
'I'))
1115 return __format::__write(
std::move(__out), _S_two_digits(__i));
1118 template<
typename _Tp,
typename _FormatContext>
1119 typename _FormatContext::iterator
1120 _M_j(
const _Tp& __t,
typename _FormatContext::iterator __out,
1121 _FormatContext&)
const
1123 if constexpr (chrono::__is_duration_v<_Tp>)
1126 unsigned __d = chrono::duration_cast<chrono::days>(__t).count();
1127 return std::format_to(
std::move(__out), _S_empty_spec, __d);
1132 using namespace chrono;
1133 auto __day = _S_days(__t);
1134 auto __ymd = _S_date(__t);
1138 if constexpr (is_same_v<
typename decltype(__day)::clock, local_t>)
1139 __d = __day - local_days(__ymd.year()/January/0);
1141 __d = __day - sys_days(__ymd.year()/January/0);
1142 return std::format_to(
std::move(__out), _GLIBCXX_WIDEN(
"{:03d}"),
1147 template<
typename _Tp,
typename _FormatContext>
1148 typename _FormatContext::iterator
1149 _M_m(
const _Tp& __t,
typename _FormatContext::iterator __out,
1150 _FormatContext& __ctx,
bool __mod)
const
1155 auto __m = _S_month(__t);
1156 auto __i = (unsigned)__m;
1158 if (__mod && _M_spec._M_localized) [[unlikely]]
1159 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1162 __tm.tm_mon = __i - 1;
1163 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1167 return __format::__write(
std::move(__out), _S_two_digits(__i));
1170 template<
typename _Tp,
typename _FormatContext>
1171 typename _FormatContext::iterator
1172 _M_M(
const _Tp& __t,
typename _FormatContext::iterator __out,
1173 _FormatContext& __ctx,
bool __mod)
const
1178 auto __m = _S_hms(__t).minutes();
1179 auto __i = __m.count();
1181 if (__mod && _M_spec._M_localized) [[unlikely]]
1182 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1186 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1190 return __format::__write(
std::move(__out), _S_two_digits(__i));
1193 template<
typename _Tp,
typename _FormatContext>
1194 typename _FormatContext::iterator
1195 _M_p(
const _Tp& __t,
typename _FormatContext::iterator __out,
1196 _FormatContext& __ctx)
const
1199 auto __hms = _S_hms(__t);
1200 locale __loc = _M_locale(__ctx);
1201 const auto& __tp = use_facet<__timepunct<_CharT>>(__loc);
1202 const _CharT* __ampm[2];
1203 __tp._M_am_pm(__ampm);
1204 return _M_write(
std::move(__out), __loc,
1205 __ampm[__hms.hours().count() >= 12]);
1208 template<
typename _Tp,
typename _FormatContext>
1209 typename _FormatContext::iterator
1210 _M_q(
const _Tp&,
typename _FormatContext::iterator __out,
1211 _FormatContext&)
const
1214 if constexpr (!chrono::__is_duration_v<_Tp>)
1215 __throw_format_error(
"format error: argument is not a duration");
1218 namespace __d = chrono::__detail;
1219 using period =
typename _Tp::period;
1220 return __d::__fmt_units_suffix<period, _CharT>(
std::move(__out));
1226 template<
typename _Tp,
typename _FormatContext>
1227 typename _FormatContext::iterator
1228 _M_R_T(
const _Tp& __t,
typename _FormatContext::iterator __out,
1229 _FormatContext& __ctx,
bool __secs)
const
1233 auto __hms = _S_hms(__t);
1235 auto __s = std::format(_GLIBCXX_WIDEN(
"{:02d}:00"),
1236 __hms.hours().count());
1237 auto __sv = _S_two_digits(__hms.minutes().count());
1238 __s[__s.size() - 2] = __sv[0];
1239 __s[__s.size() - 1] = __sv[1];
1241 __out = __format::__write(
std::move(__out), __sv);
1244 *__out++ = _S_colon;
1245 __out = _M_S(__hms,
std::move(__out), __ctx);
1250 template<
typename _Tp,
typename _FormatContext>
1251 typename _FormatContext::iterator
1252 _M_S(
const _Tp& __t,
typename _FormatContext::iterator __out,
1253 _FormatContext& __ctx,
bool __mod =
false)
const
1257 auto __hms = _S_hms(__t);
1258 auto __s = __hms.seconds();
1260 if (__mod) [[unlikely]]
1262 if (_M_spec._M_localized)
1263 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1266 __tm.tm_sec = (int)__s.count();
1267 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1272 return __format::__write(
std::move(__out),
1273 _S_two_digits(__s.count()));
1276 if constexpr (__hms.fractional_width == 0)
1277 __out = __format::__write(
std::move(__out),
1278 _S_two_digits(__s.count()));
1281 locale __loc = _M_locale(__ctx);
1282 auto __ss = __hms.subseconds();
1283 using rep =
typename decltype(__ss)::rep;
1284 if constexpr (is_floating_point_v<rep>)
1286 chrono::duration<rep> __fs = __s + __ss;
1287 __out = std::format_to(
std::move(__out), __loc,
1288 _GLIBCXX_WIDEN(
"{:#0{}.{}Lf}"),
1290 3 + __hms.fractional_width,
1291 __hms.fractional_width);
1296 = use_facet<numpunct<_CharT>>(__loc);
1297 __out = __format::__write(
std::move(__out),
1298 _S_two_digits(__s.count()));
1299 *__out++ = __np.decimal_point();
1300 if constexpr (is_integral_v<rep>)
1301 __out = std::format_to(
std::move(__out),
1302 _GLIBCXX_WIDEN(
"{:0{}}"),
1304 __hms.fractional_width);
1307 auto __str = std::format(_S_empty_spec, __ss.count());
1308 __out = std::format_to(
std::move(__out),
1309 _GLIBCXX_WIDEN(
"{:0>{}s}"),
1311 __hms.fractional_width);
1320 template<
typename _Tp,
typename _FormatContext>
1321 typename _FormatContext::iterator
1322 _M_u_w(
const _Tp& __t,
typename _FormatContext::iterator __out,
1323 _FormatContext& __ctx, _CharT __conv,
bool __mod =
false)
const
1330 chrono::weekday __wd = _S_weekday(__t);
1332 if (__mod && _M_spec._M_localized) [[unlikely]]
1333 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1336 __tm.tm_wday = __wd.c_encoding();
1337 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1341 unsigned __wdi = __conv ==
'u' ? __wd.iso_encoding()
1342 : __wd.c_encoding();
1343 const _CharT __d = _S_digit(__wdi);
1344 return __format::__write(
std::move(__out), __string_view(&__d, 1));
1347 template<
typename _Tp,
typename _FormatContext>
1348 typename _FormatContext::iterator
1349 _M_U_V_W(
const _Tp& __t,
typename _FormatContext::iterator __out,
1350 _FormatContext& __ctx, _CharT __conv,
bool __mod =
false)
const
1358 using namespace chrono;
1359 auto __d = _S_days(__t);
1360 using _TDays =
decltype(__d);
1362 if (__mod && _M_spec._M_localized) [[unlikely]]
1363 if (
auto __loc = __ctx.locale(); __loc != locale::classic())
1365 const year_month_day __ymd(__d);
1366 const year __y = __ymd.year();
1368 __tm.tm_year = (int)__y - 1900;
1369 __tm.tm_yday = (__d - _TDays(__y/January/1)).count();
1370 __tm.tm_wday = weekday(__d).c_encoding();
1371 return _M_locale_fmt(
std::move(__out), __loc, __tm,
1379 __d -= (weekday(__d) - Monday) -
days(3);
1382 __first = _TDays(year_month_day(__d).year()/January/1);
1387 if constexpr (
requires { __t.year(); })
1390 __y = year_month_day(__d).year();
1391 const weekday __weekstart = __conv ==
'U' ? Sunday : Monday;
1392 __first = _TDays(__y/January/__weekstart[1]);
1394 auto __weeks = chrono::floor<weeks>(__d - __first);
1395 __string_view __sv = _S_two_digits(__weeks.count() + 1);
1396 return __format::__write(
std::move(__out), __sv);
1399 template<
typename _Tp,
typename _FormatContext>
1400 typename _FormatContext::iterator
1401 _M_z(
const _Tp& __t,
typename _FormatContext::iterator __out,
1402 _FormatContext&,
bool __mod =
false)
const
1404 using ::std::chrono::__detail::__utc_leap_second;
1405 using ::std::chrono::__detail::__local_time_fmt;
1407 auto __utc = __mod ? __string_view(_GLIBCXX_WIDEN(
"+00:00"), 6)
1408 : __string_view(_GLIBCXX_WIDEN(
"+0000"), 5);
1410 if constexpr (chrono::__is_time_point_v<_Tp>)
1412 if constexpr (is_same_v<
typename _Tp::clock,
1413 chrono::system_clock>)
1414 return __format::__write(
std::move(__out), __utc);
1416 else if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
1418 if (__t._M_offset_sec)
1421 basic_string<_CharT> __s;
1422 if (*__t._M_offset_sec != 0s)
1424 chrono:: hh_mm_ss __hms(*__t._M_offset_sec);
1425 __s = _S_plus_minus[__hms.is_negative()];
1426 __s += _S_two_digits(__hms.hours().count());
1429 __s += _S_two_digits(__hms.minutes().count());
1432 return __format::__write(
std::move(__out), __sv);
1435 else if constexpr (__is_specialization_of<_Tp, __utc_leap_second>)
1436 return __format::__write(
std::move(__out), __utc);
1438 __no_timezone_available();
1441 template<
typename _Tp,
typename _FormatContext>
1442 typename _FormatContext::iterator
1443 _M_Z(
const _Tp& __t,
typename _FormatContext::iterator __out,
1444 _FormatContext& __ctx)
const
1446 using ::std::chrono::__detail::__utc_leap_second;
1447 using ::std::chrono::__detail::__local_time_fmt;
1449 __string_view __utc(_GLIBCXX_WIDEN(
"UTC"), 3);
1450 if constexpr (chrono::__is_time_point_v<_Tp>)
1452 if constexpr (is_same_v<
typename _Tp::clock,
1453 chrono::system_clock>)
1454 return __format::__write(
std::move(__out), __utc);
1456 else if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
1460 string_view __sv = *__t._M_abbrev;
1461 if constexpr (is_same_v<_CharT, char>)
1462 return __format::__write(
std::move(__out), __sv);
1466 basic_string<_CharT> __ws(__sv.size(), _CharT());
1467 auto& __ct = use_facet<ctype<_CharT>>(_M_locale(__ctx));
1468 __ct.widen(__sv.begin(), __sv.end(), __ws.data());
1469 __string_view __wsv = __ws;
1470 return __format::__write(
std::move(__out), __wsv);
1474 else if constexpr (__is_specialization_of<_Tp, __utc_leap_second>)
1475 return __format::__write(
std::move(__out), __utc);
1477 __no_timezone_available();
1484 _S_digit(
int __n)
noexcept
1487 return _GLIBCXX_WIDEN(
"0123456789999999")[__n & 0xf];
1491 static basic_string_view<_CharT>
1492 _S_two_digits(
int __n)
noexcept
1495 _GLIBCXX_WIDEN(
"0001020304050607080910111213141516171819"
1496 "2021222324252627282930313233343536373839"
1497 "4041424344454647484950515253545556575859"
1498 "6061626364656667686970717273747576777879"
1499 "8081828384858687888990919293949596979899"
1500 "9999999999999999999999999999999999999999"
1501 "9999999999999999") + 2 * (__n & 0x7f),
1509 template<
typename _Tp>
1510 static decltype(
auto)
1511 _S_hms(
const _Tp& __t)
1513 using ::std::chrono::__detail::__utc_leap_second;
1514 using ::std::chrono::__detail::__local_time_fmt;
1516 if constexpr (__is_specialization_of<_Tp, chrono::hh_mm_ss>)
1518 else if constexpr (__is_specialization_of<_Tp, __utc_leap_second>)
1520 else if constexpr (chrono::__is_duration_v<_Tp>)
1521 return chrono::hh_mm_ss<_Tp>(__t);
1522 else if constexpr (chrono::__is_time_point_v<_Tp>)
1523 return chrono::hh_mm_ss(__t - chrono::floor<chrono::days>(__t));
1524 else if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
1525 return _S_hms(__t._M_time);
1528 __invalid_chrono_spec();
1529 return chrono::hh_mm_ss<chrono::seconds>();
1534 template<
typename _Tp>
1536 _S_days(
const _Tp& __t)
1538 using namespace chrono;
1539 using ::std::chrono::__detail::__utc_leap_second;
1540 using ::std::chrono::__detail::__local_time_fmt;
1542 if constexpr (__is_time_point_v<_Tp>)
1543 return chrono::floor<days>(__t);
1544 else if constexpr (__is_specialization_of<_Tp, __utc_leap_second>)
1546 else if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
1547 return chrono::floor<days>(__t._M_time);
1548 else if constexpr (is_same_v<_Tp, year_month_day>
1549 || is_same_v<_Tp, year_month_day_last>
1550 || is_same_v<_Tp, year_month_weekday>
1551 || is_same_v<_Tp, year_month_weekday_last>)
1552 return sys_days(__t);
1555 if constexpr (__is_duration_v<_Tp>)
1556 __not_valid_for_duration();
1558 __invalid_chrono_spec();
1559 return chrono::sys_days();
1564 template<
typename _Tp>
1565 static chrono::year_month_day
1566 _S_date(
const _Tp& __t)
1568 if constexpr (is_same_v<_Tp, chrono::year_month_day>)
1571 return chrono::year_month_day(_S_days(__t));
1574 template<
typename _Tp>
1576 _S_day(
const _Tp& __t)
1578 using namespace chrono;
1580 if constexpr (is_same_v<_Tp, day>)
1582 else if constexpr (
requires { __t.day(); })
1585 return _S_date(__t).day();
1588 template<
typename _Tp>
1589 static chrono::month
1590 _S_month(
const _Tp& __t)
1592 using namespace chrono;
1594 if constexpr (is_same_v<_Tp, month>)
1596 else if constexpr (
requires { __t.month(); })
1599 return _S_date(__t).month();
1602 template<
typename _Tp>
1604 _S_year(
const _Tp& __t)
1606 using namespace chrono;
1608 if constexpr (is_same_v<_Tp, year>)
1610 else if constexpr (
requires { __t.year(); })
1613 return _S_date(__t).year();
1616 template<
typename _Tp>
1617 static chrono::weekday
1618 _S_weekday(
const _Tp& __t)
1621 using ::std::chrono::__detail::__local_time_fmt;
1623 if constexpr (is_same_v<_Tp, weekday>)
1625 else if constexpr (
requires { __t.weekday(); })
1627 else if constexpr (is_same_v<_Tp, month_weekday>)
1628 return __t.weekday_indexed().weekday();
1629 else if constexpr (is_same_v<_Tp, month_weekday_last>)
1630 return __t.weekday_last().weekday();
1632 return weekday(_S_days(__t));
1636 template<
typename _Tp>
1638 _S_floor_seconds(
const _Tp& __t)
1640 using chrono::__detail::__local_time_fmt;
1641 if constexpr (chrono::__is_time_point_v<_Tp>
1642 || chrono::__is_duration_v<_Tp>)
1644 if constexpr (_Tp::period::den != 1)
1645 return chrono::floor<chrono::seconds>(__t);
1649 else if constexpr (__is_specialization_of<_Tp, chrono::hh_mm_ss>)
1651 if constexpr (_Tp::fractional_width != 0)
1652 return chrono::floor<chrono::seconds>(__t.to_duration());
1656 else if constexpr (__is_specialization_of<_Tp, __local_time_fmt>)
1657 return _S_floor_seconds(__t._M_time);
1664 template<
typename _Iter>
1666 _M_locale_fmt(_Iter __out,
const locale& __loc,
const struct tm& __tm,
1667 char __fmt,
char __mod)
const
1669 basic_ostringstream<_CharT> __os;
1671 const auto& __tp = use_facet<time_put<_CharT>>(__loc);
1672 __tp.put(__os, __os, _S_space, &__tm, __fmt, __mod);
1674 __out = _M_write(
std::move(__out), __loc, __os.view());
1682 template<
typename _Rep,
typename _Period,
typename _CharT>
1683 requires __format::__formattable_impl<_Rep, _CharT>
1684 struct formatter<chrono::duration<_Rep, _Period>, _CharT>
1686 constexpr typename basic_format_parse_context<_CharT>::iterator
1687 parse(basic_format_parse_context<_CharT>& __pc)
1689 using namespace __format;
1690 auto __it = _M_f._M_parse(__pc, _Duration|_TimeOfDay);
1691 if constexpr (!is_floating_point_v<_Rep>)
1692 if (_M_f._M_spec._M_prec_kind != __format::_WP_none)
1693 __throw_format_error(
"format error: invalid precision for duration");
1697 template<
typename _Out>
1698 typename basic_format_context<_Out, _CharT>::iterator
1699 format(
const chrono::duration<_Rep, _Period>& __d,
1700 basic_format_context<_Out, _CharT>& __fc)
const
1702 if constexpr (numeric_limits<_Rep>::is_signed)
1703 if (__d < __d.zero()) [[unlikely]]
1705 if constexpr (is_integral_v<_Rep>)
1709 using _URep = make_unsigned_t<_Rep>;
1710 auto __ucnt = -
static_cast<_URep
>(__d.count());
1711 auto __ud = chrono::duration<_URep, _Period>(__ucnt);
1712 return _M_f._M_format(__ud, __fc,
true);
1715 return _M_f._M_format(-__d, __fc,
true);
1717 return _M_f._M_format(__d, __fc,
false);
1721 __format::__formatter_chrono<_CharT> _M_f;
1724 template<__format::__
char _CharT>
1725 struct formatter<chrono::day, _CharT>
1727 constexpr typename basic_format_parse_context<_CharT>::iterator
1728 parse(basic_format_parse_context<_CharT>& __pc)
1729 {
return _M_f._M_parse(__pc, __format::_Day); }
1731 template<
typename _Out>
1732 typename basic_format_context<_Out, _CharT>::iterator
1733 format(
const chrono::day& __t,
1734 basic_format_context<_Out, _CharT>& __fc)
const
1735 {
return _M_f._M_format(__t, __fc); }
1738 __format::__formatter_chrono<_CharT> _M_f;
1741 template<__format::__
char _CharT>
1742 struct formatter<chrono::month, _CharT>
1744 constexpr typename basic_format_parse_context<_CharT>::iterator
1745 parse(basic_format_parse_context<_CharT>& __pc)
1746 {
return _M_f._M_parse(__pc, __format::_Month); }
1748 template<
typename _Out>
1749 typename basic_format_context<_Out, _CharT>::iterator
1750 format(
const chrono::month& __t,
1751 basic_format_context<_Out, _CharT>& __fc)
const
1752 {
return _M_f._M_format(__t, __fc); }
1755 __format::__formatter_chrono<_CharT> _M_f;
1758 template<__format::__
char _CharT>
1759 struct formatter<chrono::year, _CharT>
1761 constexpr typename basic_format_parse_context<_CharT>::iterator
1762 parse(basic_format_parse_context<_CharT>& __pc)
1763 {
return _M_f._M_parse(__pc, __format::_Year); }
1765 template<
typename _Out>
1766 typename basic_format_context<_Out, _CharT>::iterator
1767 format(
const chrono::year& __t,
1768 basic_format_context<_Out, _CharT>& __fc)
const
1769 {
return _M_f._M_format(__t, __fc); }
1772 __format::__formatter_chrono<_CharT> _M_f;
1775 template<__format::__
char _CharT>
1776 struct formatter<chrono::weekday, _CharT>
1778 constexpr typename basic_format_parse_context<_CharT>::iterator
1779 parse(basic_format_parse_context<_CharT>& __pc)
1780 {
return _M_f._M_parse(__pc, __format::_Weekday); }
1782 template<
typename _Out>
1783 typename basic_format_context<_Out, _CharT>::iterator
1784 format(
const chrono::weekday& __t,
1785 basic_format_context<_Out, _CharT>& __fc)
const
1786 {
return _M_f._M_format(__t, __fc); }
1789 __format::__formatter_chrono<_CharT> _M_f;
1792 template<__format::__
char _CharT>
1793 struct formatter<chrono::weekday_indexed, _CharT>
1795 constexpr typename basic_format_parse_context<_CharT>::iterator
1796 parse(basic_format_parse_context<_CharT>& __pc)
1797 {
return _M_f._M_parse(__pc, __format::_Weekday); }
1799 template<
typename _Out>
1800 typename basic_format_context<_Out, _CharT>::iterator
1801 format(
const chrono::weekday_indexed& __t,
1802 basic_format_context<_Out, _CharT>& __fc)
const
1803 {
return _M_f._M_format(__t, __fc); }
1806 __format::__formatter_chrono<_CharT> _M_f;
1809 template<__format::__
char _CharT>
1810 struct formatter<chrono::weekday_last, _CharT>
1812 constexpr typename basic_format_parse_context<_CharT>::iterator
1813 parse(basic_format_parse_context<_CharT>& __pc)
1814 {
return _M_f._M_parse(__pc, __format::_Weekday); }
1816 template<
typename _Out>
1817 typename basic_format_context<_Out, _CharT>::iterator
1818 format(
const chrono::weekday_last& __t,
1819 basic_format_context<_Out, _CharT>& __fc)
const
1820 {
return _M_f._M_format(__t, __fc); }
1823 __format::__formatter_chrono<_CharT> _M_f;
1826 template<__format::__
char _CharT>
1827 struct formatter<chrono::month_day, _CharT>
1829 constexpr typename basic_format_parse_context<_CharT>::iterator
1830 parse(basic_format_parse_context<_CharT>& __pc)
1831 {
return _M_f._M_parse(__pc, __format::_Month|__format::_Day); }
1833 template<
typename _Out>
1834 typename basic_format_context<_Out, _CharT>::iterator
1835 format(
const chrono::month_day& __t,
1836 basic_format_context<_Out, _CharT>& __fc)
const
1837 {
return _M_f._M_format(__t, __fc); }
1840 __format::__formatter_chrono<_CharT> _M_f;
1843 template<__format::__
char _CharT>
1844 struct formatter<chrono::month_day_last, _CharT>
1846 constexpr typename basic_format_parse_context<_CharT>::iterator
1847 parse(basic_format_parse_context<_CharT>& __pc)
1848 {
return _M_f._M_parse(__pc, __format::_Month); }
1850 template<
typename _Out>
1851 typename basic_format_context<_Out, _CharT>::iterator
1852 format(
const chrono::month_day_last& __t,
1853 basic_format_context<_Out, _CharT>& __fc)
const
1854 {
return _M_f._M_format(__t, __fc); }
1857 __format::__formatter_chrono<_CharT> _M_f;
1860 template<__format::__
char _CharT>
1861 struct formatter<chrono::month_weekday, _CharT>
1863 constexpr typename basic_format_parse_context<_CharT>::iterator
1864 parse(basic_format_parse_context<_CharT>& __pc)
1865 {
return _M_f._M_parse(__pc, __format::_Month|__format::_Weekday); }
1867 template<
typename _Out>
1868 typename basic_format_context<_Out, _CharT>::iterator
1869 format(
const chrono::month_weekday& __t,
1870 basic_format_context<_Out, _CharT>& __fc)
const
1871 {
return _M_f._M_format(__t, __fc); }
1874 __format::__formatter_chrono<_CharT> _M_f;
1877 template<__format::__
char _CharT>
1878 struct formatter<chrono::month_weekday_last, _CharT>
1880 constexpr typename basic_format_parse_context<_CharT>::iterator
1881 parse(basic_format_parse_context<_CharT>& __pc)
1882 {
return _M_f._M_parse(__pc, __format::_Month|__format::_Weekday); }
1884 template<
typename _Out>
1885 typename basic_format_context<_Out, _CharT>::iterator
1886 format(
const chrono::month_weekday_last& __t,
1887 basic_format_context<_Out, _CharT>& __fc)
const
1888 {
return _M_f._M_format(__t, __fc); }
1891 __format::__formatter_chrono<_CharT> _M_f;
1894 template<__format::__
char _CharT>
1895 struct formatter<chrono::year_month, _CharT>
1897 constexpr typename basic_format_parse_context<_CharT>::iterator
1898 parse(basic_format_parse_context<_CharT>& __pc)
1899 {
return _M_f._M_parse(__pc, __format::_Year|__format::_Month); }
1901 template<
typename _Out>
1902 typename basic_format_context<_Out, _CharT>::iterator
1903 format(
const chrono::year_month& __t,
1904 basic_format_context<_Out, _CharT>& __fc)
const
1905 {
return _M_f._M_format(__t, __fc); }
1908 __format::__formatter_chrono<_CharT> _M_f;
1911 template<__format::__
char _CharT>
1912 struct formatter<chrono::year_month_day, _CharT>
1914 constexpr typename basic_format_parse_context<_CharT>::iterator
1915 parse(basic_format_parse_context<_CharT>& __pc)
1916 {
return _M_f._M_parse(__pc, __format::_Date); }
1918 template<
typename _Out>
1919 typename basic_format_context<_Out, _CharT>::iterator
1920 format(
const chrono::year_month_day& __t,
1921 basic_format_context<_Out, _CharT>& __fc)
const
1922 {
return _M_f._M_format(__t, __fc); }
1925 __format::__formatter_chrono<_CharT> _M_f;
1928 template<__format::__
char _CharT>
1929 struct formatter<chrono::year_month_day_last, _CharT>
1931 constexpr typename basic_format_parse_context<_CharT>::iterator
1932 parse(basic_format_parse_context<_CharT>& __pc)
1933 {
return _M_f._M_parse(__pc, __format::_Date); }
1935 template<
typename _Out>
1936 typename basic_format_context<_Out, _CharT>::iterator
1937 format(
const chrono::year_month_day_last& __t,
1938 basic_format_context<_Out, _CharT>& __fc)
const
1939 {
return _M_f._M_format(__t, __fc); }
1942 __format::__formatter_chrono<_CharT> _M_f;
1945 template<__format::__
char _CharT>
1946 struct formatter<chrono::year_month_weekday, _CharT>
1948 constexpr typename basic_format_parse_context<_CharT>::iterator
1949 parse(basic_format_parse_context<_CharT>& __pc)
1950 {
return _M_f._M_parse(__pc, __format::_Date); }
1952 template<
typename _Out>
1953 typename basic_format_context<_Out, _CharT>::iterator
1954 format(
const chrono::year_month_weekday& __t,
1955 basic_format_context<_Out, _CharT>& __fc)
const
1956 {
return _M_f._M_format(__t, __fc); }
1959 __format::__formatter_chrono<_CharT> _M_f;
1962 template<__format::__
char _CharT>
1963 struct formatter<chrono::year_month_weekday_last, _CharT>
1965 constexpr typename basic_format_parse_context<_CharT>::iterator
1966 parse(basic_format_parse_context<_CharT>& __pc)
1967 {
return _M_f._M_parse(__pc, __format::_Date); }
1969 template<
typename _Out>
1970 typename basic_format_context<_Out, _CharT>::iterator
1971 format(
const chrono::year_month_weekday_last& __t,
1972 basic_format_context<_Out, _CharT>& __fc)
const
1973 {
return _M_f._M_format(__t, __fc); }
1976 __format::__formatter_chrono<_CharT> _M_f;
1979 template<
typename _Rep,
typename _Period, __format::__
char _CharT>
1980 struct formatter<chrono::hh_mm_ss<chrono::duration<_Rep, _Period>>, _CharT>
1982 constexpr typename basic_format_parse_context<_CharT>::iterator
1983 parse(basic_format_parse_context<_CharT>& __pc)
1984 {
return _M_f._M_parse(__pc, __format::_TimeOfDay); }
1986 template<
typename _Out>
1987 typename basic_format_context<_Out, _CharT>::iterator
1988 format(
const chrono::hh_mm_ss<chrono::duration<_Rep, _Period>>& __t,
1989 basic_format_context<_Out, _CharT>& __fc)
const
1990 {
return _M_f._M_format(__t, __fc); }
1993 __format::__formatter_chrono<_CharT> _M_f;
1996#if _GLIBCXX_USE_CXX11_ABI || ! _GLIBCXX_USE_DUAL_ABI
1997 template<__format::__
char _CharT>
1998 struct formatter<chrono::sys_info, _CharT>
2000 constexpr typename basic_format_parse_context<_CharT>::iterator
2001 parse(basic_format_parse_context<_CharT>& __pc)
2002 {
return _M_f._M_parse(__pc, __format::_ChronoParts{}); }
2004 template<
typename _Out>
2005 typename basic_format_context<_Out, _CharT>::iterator
2006 format(
const chrono::sys_info& __i,
2007 basic_format_context<_Out, _CharT>& __fc)
const
2008 {
return _M_f._M_format(__i, __fc); }
2011 __format::__formatter_chrono<_CharT> _M_f;
2014 template<__format::__
char _CharT>
2015 struct formatter<chrono::local_info, _CharT>
2017 constexpr typename basic_format_parse_context<_CharT>::iterator
2018 parse(basic_format_parse_context<_CharT>& __pc)
2019 {
return _M_f._M_parse(__pc, __format::_ChronoParts{}); }
2021 template<
typename _Out>
2022 typename basic_format_context<_Out, _CharT>::iterator
2023 format(
const chrono::local_info& __i,
2024 basic_format_context<_Out, _CharT>& __fc)
const
2025 {
return _M_f._M_format(__i, __fc); }
2028 __format::__formatter_chrono<_CharT> _M_f;
2032 template<
typename _Duration, __format::__
char _CharT>
2033 struct formatter<chrono::sys_time<_Duration>, _CharT>
2035 constexpr typename basic_format_parse_context<_CharT>::iterator
2036 parse(basic_format_parse_context<_CharT>& __pc)
2038 auto __next = _M_f._M_parse(__pc, __format::_ZonedDateTime);
2039 if constexpr (!__stream_insertable)
2040 if (_M_f._M_spec._M_chrono_specs.empty())
2041 __format::__invalid_chrono_spec();
2045 template<
typename _Out>
2046 typename basic_format_context<_Out, _CharT>::iterator
2047 format(
const chrono::sys_time<_Duration>& __t,
2048 basic_format_context<_Out, _CharT>& __fc)
const
2049 {
return _M_f._M_format(__t, __fc); }
2052 static constexpr bool __stream_insertable
2053 =
requires (basic_ostream<_CharT>& __os,
2054 chrono::sys_time<_Duration> __t) { __os << __t; };
2056 __format::__formatter_chrono<_CharT> _M_f;
2059 template<
typename _Duration, __format::__
char _CharT>
2060 struct formatter<chrono::utc_time<_Duration>, _CharT>
2061 : __format::__formatter_chrono<_CharT>
2063 constexpr typename basic_format_parse_context<_CharT>::iterator
2064 parse(basic_format_parse_context<_CharT>& __pc)
2065 {
return _M_f._M_parse(__pc, __format::_ZonedDateTime); }
2067 template<
typename _Out>
2068 typename basic_format_context<_Out, _CharT>::iterator
2069 format(
const chrono::utc_time<_Duration>& __t,
2070 basic_format_context<_Out, _CharT>& __fc)
const
2075 using chrono::__detail::__utc_leap_second;
2076 using chrono::seconds;
2077 using chrono::sys_time;
2078 using _CDur = common_type_t<_Duration, seconds>;
2079 const auto __li = chrono::get_leap_second_info(__t);
2080 sys_time<_CDur> __s{__t.time_since_epoch() - __li.elapsed};
2081 if (!__li.is_leap_second) [[likely]]
2082 return _M_f._M_format(__s, __fc);
2084 return _M_f._M_format(__utc_leap_second(__s), __fc);
2088 friend formatter<chrono::__detail::__utc_leap_second<_Duration>, _CharT>;
2090 __format::__formatter_chrono<_CharT> _M_f;
2093 template<
typename _Duration, __format::__
char _CharT>
2094 struct formatter<chrono::tai_time<_Duration>, _CharT>
2095 : __format::__formatter_chrono<_CharT>
2097 constexpr typename basic_format_parse_context<_CharT>::iterator
2098 parse(basic_format_parse_context<_CharT>& __pc)
2099 {
return _M_f._M_parse(__pc, __format::_ZonedDateTime); }
2101 template<
typename _Out>
2102 typename basic_format_context<_Out, _CharT>::iterator
2103 format(
const chrono::tai_time<_Duration>& __t,
2104 basic_format_context<_Out, _CharT>& __fc)
const
2111 constexpr chrono::days __tai_offset = chrono::days(4383);
2112 using _CDur = common_type_t<_Duration, chrono::days>;
2113 chrono::local_time<_CDur> __lt(__t.time_since_epoch() - __tai_offset);
2114 const string __abbrev(
"TAI", 3);
2115 const chrono::seconds __off = 0s;
2116 const auto __lf = chrono::local_time_format(__lt, &__abbrev, &__off);
2117 return _M_f._M_format(__lf, __fc);
2121 __format::__formatter_chrono<_CharT> _M_f;
2124 template<
typename _Duration, __format::__
char _CharT>
2125 struct formatter<chrono::gps_time<_Duration>, _CharT>
2126 : __format::__formatter_chrono<_CharT>
2128 constexpr typename basic_format_parse_context<_CharT>::iterator
2129 parse(basic_format_parse_context<_CharT>& __pc)
2130 {
return _M_f._M_parse(__pc, __format::_ZonedDateTime); }
2132 template<
typename _Out>
2133 typename basic_format_context<_Out, _CharT>::iterator
2134 format(
const chrono::gps_time<_Duration>& __t,
2135 basic_format_context<_Out, _CharT>& __fc)
const
2142 constexpr chrono::days __gps_offset = chrono::days(3657);
2143 using _CDur = common_type_t<_Duration, chrono::days>;
2144 chrono::local_time<_CDur> __lt(__t.time_since_epoch() + __gps_offset);
2145 const string __abbrev(
"GPS", 3);
2146 const chrono::seconds __off = 0s;
2147 const auto __lf = chrono::local_time_format(__lt, &__abbrev, &__off);
2148 return _M_f._M_format(__lf, __fc);
2152 __format::__formatter_chrono<_CharT> _M_f;
2155 template<
typename _Duration, __format::__
char _CharT>
2156 struct formatter<chrono::file_time<_Duration>, _CharT>
2158 constexpr typename basic_format_parse_context<_CharT>::iterator
2159 parse(basic_format_parse_context<_CharT>& __pc)
2160 {
return _M_f._M_parse(__pc, __format::_ZonedDateTime); }
2162 template<
typename _Out>
2163 typename basic_format_context<_Out, _CharT>::iterator
2164 format(
const chrono::file_time<_Duration>& __t,
2165 basic_format_context<_Out, _CharT>& __fc)
const
2167 using namespace chrono;
2168 return _M_f._M_format(chrono::clock_cast<system_clock>(__t), __fc);
2172 __format::__formatter_chrono<_CharT> _M_f;
2175 template<
typename _Duration, __format::__
char _CharT>
2176 struct formatter<chrono::local_time<_Duration>, _CharT>
2178 constexpr typename basic_format_parse_context<_CharT>::iterator
2179 parse(basic_format_parse_context<_CharT>& __pc)
2180 {
return _M_f._M_parse(__pc, __format::_DateTime); }
2182 template<
typename _Out>
2183 typename basic_format_context<_Out, _CharT>::iterator
2184 format(
const chrono::local_time<_Duration>& __t,
2185 basic_format_context<_Out, _CharT>& __fc)
const
2186 {
return _M_f._M_format(__t, __fc); }
2189 __format::__formatter_chrono<_CharT> _M_f;
2192 template<
typename _Duration, __format::__
char _CharT>
2193 struct formatter<chrono::__detail::__local_time_fmt<_Duration>, _CharT>
2195 constexpr typename basic_format_parse_context<_CharT>::iterator
2196 parse(basic_format_parse_context<_CharT>& __pc)
2197 {
return _M_f._M_parse(__pc, __format::_ZonedDateTime); }
2199 template<
typename _Out>
2200 typename basic_format_context<_Out, _CharT>::iterator
2201 format(
const chrono::__detail::__local_time_fmt<_Duration>& __t,
2202 basic_format_context<_Out, _CharT>& __fc)
const
2203 {
return _M_f._M_format(__t, __fc,
true); }
2206 __format::__formatter_chrono<_CharT> _M_f;
2209#if _GLIBCXX_USE_CXX11_ABI || ! _GLIBCXX_USE_DUAL_ABI
2210 template<
typename _Duration,
typename _TimeZonePtr, __format::__
char _CharT>
2211 struct formatter<chrono::zoned_time<_Duration, _TimeZonePtr>, _CharT>
2212 : formatter<chrono::__detail::__local_time_fmt_for<_Duration>, _CharT>
2214 template<
typename _Out>
2215 typename basic_format_context<_Out, _CharT>::iterator
2216 format(
const chrono::zoned_time<_Duration, _TimeZonePtr>& __tp,
2217 basic_format_context<_Out, _CharT>& __fc)
const
2219 using _Ltf = chrono::__detail::__local_time_fmt_for<_Duration>;
2220 using _Base = formatter<_Ltf, _CharT>;
2221 const chrono::sys_info __info = __tp.get_info();
2222 const auto __lf = chrono::local_time_format(__tp.get_local_time(),
2225 return _Base::format(__lf, __fc);
2231 template<
typename _Duration, __format::__
char _CharT>
2232 struct formatter<chrono::__detail::__utc_leap_second<_Duration>, _CharT>
2233 : formatter<chrono::utc_time<_Duration>, _CharT>
2235 template<
typename _Out>
2236 typename basic_format_context<_Out, _CharT>::iterator
2237 format(
const chrono::__detail::__utc_leap_second<_Duration>& __t,
2238 basic_format_context<_Out, _CharT>& __fc)
const
2239 {
return this->_M_f._M_format(__t, __fc); }
2250 template<
typename _Duration = seconds>
2253 static_assert(is_same_v<common_type_t<_Duration, seconds>, _Duration>);
2256 _Parser(__format::_ChronoParts __need) : _M_need(__need) { }
2258 _Parser(_Parser&&) =
delete;
2259 void operator=(_Parser&&) =
delete;
2261 _Duration _M_time{};
2262 sys_days _M_sys_days{};
2263 year_month_day _M_ymd{};
2265 __format::_ChronoParts _M_need;
2266 unsigned _M_is_leap_second : 1 {};
2267 unsigned _M_reserved : 15 {};
2269 template<
typename _CharT,
typename _Traits,
typename _Alloc>
2270 basic_istream<_CharT, _Traits>&
2271 operator()(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2272 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2273 minutes* __offset =
nullptr);
2278 template<
typename _CharT,
typename _Traits>
2279 static int_least32_t
2280 _S_read_unsigned(basic_istream<_CharT, _Traits>& __is,
2281 ios_base::iostate& __err,
int __n)
2283 int_least32_t __val = _S_try_read_digit(__is, __err);
2284 if (__val == -1) [[unlikely]]
2285 __err |= ios_base::failbit;
2290 for (
int __i = 1; __i < __n1; ++__i)
2291 if (
auto __dig = _S_try_read_digit(__is, __err); __dig != -1)
2297 while (__n1++ < __n) [[unlikely]]
2298 if (
auto __dig = _S_try_read_digit(__is, __err); __dig != -1)
2300 if (__builtin_mul_overflow(__val, 10, &__val)
2301 || __builtin_add_overflow(__val, __dig, &__val))
2303 __err |= ios_base::failbit;
2313 template<
typename _CharT,
typename _Traits>
2314 static int_least32_t
2315 _S_read_signed(basic_istream<_CharT, _Traits>& __is,
2316 ios_base::iostate& __err,
int __n)
2318 auto __sign = __is.peek();
2319 if (__sign ==
'-' || __sign ==
'+')
2321 int_least32_t __val = _S_read_unsigned(__is, __err, __n);
2322 if (__err & ios_base::failbit)
2324 if (__sign ==
'-') [[unlikely]]
2332 template<
typename _CharT,
typename _Traits>
2333 static int_least32_t
2334 _S_try_read_digit(basic_istream<_CharT, _Traits>& __is,
2335 ios_base::iostate& __err)
2337 int_least32_t __val = -1;
2338 auto __i = __is.peek();
2339 if (!_Traits::eq_int_type(__i, _Traits::eof())) [[likely]]
2341 _CharT __c = _Traits::to_char_type(__i);
2342 if (_CharT(
'0') <= __c && __c <= _CharT(
'9')) [[likely]]
2345 __val = __c - _CharT(
'0');
2349 __err |= ios_base::eofbit;
2355 template<
typename _CharT,
typename _Traits>
2357 _S_read_chr(basic_istream<_CharT, _Traits>& __is,
2358 ios_base::iostate& __err, _CharT __c)
2360 auto __i = __is.peek();
2361 if (_Traits::eq_int_type(__i, _Traits::eof()))
2362 __err |= ios_base::eofbit;
2363 else if (_Traits::to_char_type(__i) == __c) [[likely]]
2368 __err |= ios_base::failbit;
2373 template<
typename _Duration>
2374 using _Parser_t = _Parser<common_type_t<_Duration, seconds>>;
2376 template<
typename _Duration>
2380 if constexpr (_Duration::period::den == 1)
2382 switch (_Duration::period::num)
2384 case minutes::period::num:
2385 case hours::period::num:
2386 case days::period::num:
2387 case weeks::period::num:
2388 case years::period::num:
2405 template<
typename _ToDur,
typename _Tp>
2407 __round(
const _Tp& __t)
2409 if constexpr (__is_duration_v<_Tp>)
2411 if constexpr (treat_as_floating_point_v<typename _Tp::rep>)
2412 return chrono::duration_cast<_ToDur>(__t);
2413 else if constexpr (__detail::__use_floor<_ToDur>())
2414 return chrono::floor<_ToDur>(__t);
2416 return chrono::round<_ToDur>(__t);
2420 static_assert(__is_time_point_v<_Tp>);
2421 using _Tpt = time_point<typename _Tp::clock, _ToDur>;
2422 return _Tpt(__detail::__round<_ToDur>(__t.time_since_epoch()));
2429 template<
typename _CharT,
typename _Traits,
typename _Rep,
typename _Period,
2430 typename _Alloc = allocator<_CharT>>
2431 inline basic_istream<_CharT, _Traits>&
2432 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2433 duration<_Rep, _Period>& __d,
2434 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2435 minutes* __offset =
nullptr)
2437 auto __need = __format::_ChronoParts::_TimeOfDay;
2438 __detail::_Parser_t<duration<_Rep, _Period>> __p(__need);
2439 if (__p(__is, __fmt, __abbrev, __offset))
2440 __d = __detail::__round<duration<_Rep, _Period>>(__p._M_time);
2444 template<
typename _CharT,
typename _Traits>
2445 inline basic_ostream<_CharT, _Traits>&
2446 operator<<(basic_ostream<_CharT, _Traits>& __os,
const day& __d)
2448 using _Ctx = __format::__format_context<_CharT>;
2449 using _Str = basic_string_view<_CharT>;
2450 _Str __s = _GLIBCXX_WIDEN(
"{:02d} is not a valid day");
2452 __s = __s.substr(0, 6);
2453 auto __u = (unsigned)__d;
2454 __os << std::vformat(__s, make_format_args<_Ctx>(__u));
2458 template<
typename _CharT,
typename _Traits,
2459 typename _Alloc = allocator<_CharT>>
2460 inline basic_istream<_CharT, _Traits>&
2461 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2463 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2464 minutes* __offset =
nullptr)
2466 __detail::_Parser<> __p(__format::_ChronoParts::_Day);
2467 if (__p(__is, __fmt, __abbrev, __offset))
2468 __d = __p._M_ymd.day();
2472 template<
typename _CharT,
typename _Traits>
2473 inline basic_ostream<_CharT, _Traits>&
2474 operator<<(basic_ostream<_CharT, _Traits>& __os,
const month& __m)
2476 using _Ctx = __format::__format_context<_CharT>;
2477 using _Str = basic_string_view<_CharT>;
2478 _Str __s = _GLIBCXX_WIDEN(
"{:L%b}{} is not a valid month");
2480 __os << std::vformat(__os.getloc(), __s.substr(0, 6),
2481 make_format_args<_Ctx>(__m));
2484 auto __u = (unsigned)__m;
2485 __os << std::vformat(__s.substr(6), make_format_args<_Ctx>(__u));
2490 template<
typename _CharT,
typename _Traits,
2491 typename _Alloc = allocator<_CharT>>
2492 inline basic_istream<_CharT, _Traits>&
2493 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2495 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2496 minutes* __offset =
nullptr)
2498 __detail::_Parser<> __p(__format::_ChronoParts::_Month);
2499 if (__p(__is, __fmt, __abbrev, __offset))
2500 __m = __p._M_ymd.month();
2504 template<
typename _CharT,
typename _Traits>
2505 inline basic_ostream<_CharT, _Traits>&
2506 operator<<(basic_ostream<_CharT, _Traits>& __os,
const year& __y)
2508 using _Ctx = __format::__format_context<_CharT>;
2509 using _Str = basic_string_view<_CharT>;
2510 _Str __s = _GLIBCXX_WIDEN(
"-{:04d} is not a valid year");
2512 __s = __s.substr(0, 7);
2514 if (__i >= 0) [[likely]]
2515 __s.remove_prefix(1);
2518 __os << std::vformat(__s, make_format_args<_Ctx>(__i));
2522 template<
typename _CharT,
typename _Traits,
2523 typename _Alloc = allocator<_CharT>>
2524 inline basic_istream<_CharT, _Traits>&
2525 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2527 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2528 minutes* __offset =
nullptr)
2530 __detail::_Parser<> __p(__format::_ChronoParts::_Year);
2531 if (__p(__is, __fmt, __abbrev, __offset))
2532 __y = __p._M_ymd.year();
2536 template<
typename _CharT,
typename _Traits>
2537 inline basic_ostream<_CharT, _Traits>&
2538 operator<<(basic_ostream<_CharT, _Traits>& __os,
const weekday& __wd)
2540 using _Ctx = __format::__format_context<_CharT>;
2541 using _Str = basic_string_view<_CharT>;
2542 _Str __s = _GLIBCXX_WIDEN(
"{:L%a}{} is not a valid weekday");
2544 __os << std::vformat(__os.getloc(), __s.substr(0, 6),
2545 make_format_args<_Ctx>(__wd));
2548 auto __c = __wd.c_encoding();
2549 __os << std::vformat(__s.substr(6), make_format_args<_Ctx>(__c));
2554 template<
typename _CharT,
typename _Traits,
2555 typename _Alloc = allocator<_CharT>>
2556 inline basic_istream<_CharT, _Traits>&
2557 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2559 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2560 minutes* __offset =
nullptr)
2562 __detail::_Parser<> __p(__format::_ChronoParts::_Weekday);
2563 if (__p(__is, __fmt, __abbrev, __offset))
2568 template<
typename _CharT,
typename _Traits>
2569 inline basic_ostream<_CharT, _Traits>&
2570 operator<<(basic_ostream<_CharT, _Traits>& __os,
2571 const weekday_indexed& __wdi)
2576 basic_stringstream<_CharT> __os2;
2577 __os2.imbue(__os.getloc());
2578 __os2 << __wdi.weekday();
2579 const auto __i = __wdi.index();
2580 basic_string_view<_CharT> __s
2581 = _GLIBCXX_WIDEN(
"[ is not a valid index]");
2583 __os2 << std::format(_GLIBCXX_WIDEN(
"{}"), __i);
2584 if (__i >= 1 && __i <= 5)
2585 __os2 << __s.back();
2587 __os2 << __s.substr(1);
2588 __os << __os2.view();
2592 template<
typename _CharT,
typename _Traits>
2593 inline basic_ostream<_CharT, _Traits>&
2594 operator<<(basic_ostream<_CharT, _Traits>& __os,
2595 const weekday_last& __wdl)
2598 basic_stringstream<_CharT> __os2;
2599 __os2.imbue(__os.getloc());
2600 __os2 << __wdl.weekday() << _GLIBCXX_WIDEN(
"[last]");
2601 __os << __os2.view();
2605 template<
typename _CharT,
typename _Traits>
2606 inline basic_ostream<_CharT, _Traits>&
2607 operator<<(basic_ostream<_CharT, _Traits>& __os,
const month_day& __md)
2610 basic_stringstream<_CharT> __os2;
2611 __os2.imbue(__os.getloc());
2612 __os2 << __md.month();
2613 if constexpr (is_same_v<_CharT, char>)
2617 __os2 << __md.day();
2618 __os << __os2.view();
2622 template<
typename _CharT,
typename _Traits,
2623 typename _Alloc = allocator<_CharT>>
2624 inline basic_istream<_CharT, _Traits>&
2625 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2627 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2628 minutes* __offset =
nullptr)
2630 using __format::_ChronoParts;
2631 auto __need = _ChronoParts::_Month | _ChronoParts::_Day;
2632 __detail::_Parser<> __p(__need);
2633 if (__p(__is, __fmt, __abbrev, __offset))
2634 __md = month_day(__p._M_ymd.month(), __p._M_ymd.day());
2638 template<
typename _CharT,
typename _Traits>
2639 inline basic_ostream<_CharT, _Traits>&
2640 operator<<(basic_ostream<_CharT, _Traits>& __os,
2641 const month_day_last& __mdl)
2644 basic_stringstream<_CharT> __os2;
2645 __os2.imbue(__os.getloc());
2646 __os2 << __mdl.month() << _GLIBCXX_WIDEN(
"/last");
2647 __os << __os2.view();
2651 template<
typename _CharT,
typename _Traits>
2652 inline basic_ostream<_CharT, _Traits>&
2653 operator<<(basic_ostream<_CharT, _Traits>& __os,
2654 const month_weekday& __mwd)
2657 basic_stringstream<_CharT> __os2;
2658 __os2.imbue(__os.getloc());
2659 __os2 << __mwd.month();
2660 if constexpr (is_same_v<_CharT, char>)
2664 __os2 << __mwd.weekday_indexed();
2665 __os << __os2.view();
2669 template<
typename _CharT,
typename _Traits>
2670 inline basic_ostream<_CharT, _Traits>&
2671 operator<<(basic_ostream<_CharT, _Traits>& __os,
2672 const month_weekday_last& __mwdl)
2675 basic_stringstream<_CharT> __os2;
2676 __os2.imbue(__os.getloc());
2677 __os2 << __mwdl.month();
2678 if constexpr (is_same_v<_CharT, char>)
2682 __os2 << __mwdl.weekday_last();
2683 __os << __os2.view();
2687 template<
typename _CharT,
typename _Traits>
2688 inline basic_ostream<_CharT, _Traits>&
2689 operator<<(basic_ostream<_CharT, _Traits>& __os,
const year_month& __ym)
2692 basic_stringstream<_CharT> __os2;
2693 __os2.imbue(__os.getloc());
2694 __os2 << __ym.year();
2695 if constexpr (is_same_v<_CharT, char>)
2699 __os2 << __ym.month();
2700 __os << __os2.view();
2704 template<
typename _CharT,
typename _Traits,
2705 typename _Alloc = allocator<_CharT>>
2706 inline basic_istream<_CharT, _Traits>&
2707 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2709 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2710 minutes* __offset =
nullptr)
2712 using __format::_ChronoParts;
2713 auto __need = _ChronoParts::_Year | _ChronoParts::_Month;
2714 __detail::_Parser<> __p(__need);
2715 if (__p(__is, __fmt, __abbrev, __offset))
2716 __ym = year_month(__p._M_ymd.year(), __p._M_ymd.month());
2720 template<
typename _CharT,
typename _Traits>
2721 inline basic_ostream<_CharT, _Traits>&
2722 operator<<(basic_ostream<_CharT, _Traits>& __os,
2723 const year_month_day& __ymd)
2725 using _Ctx = __format::__format_context<_CharT>;
2726 using _Str = basic_string_view<_CharT>;
2727 _Str __s = _GLIBCXX_WIDEN(
"{:%F} is not a valid date");
2728 __os << std::vformat(__ymd.ok() ? __s.substr(0, 5) : __s,
2729 make_format_args<_Ctx>(__ymd));
2733 template<
typename _CharT,
typename _Traits,
2734 typename _Alloc = allocator<_CharT>>
2735 inline basic_istream<_CharT, _Traits>&
2737 year_month_day& __ymd,
2741 using __format::_ChronoParts;
2742 auto __need = _ChronoParts::_Year | _ChronoParts::_Month
2743 | _ChronoParts::_Day;
2744 __detail::_Parser<> __p(__need);
2745 if (__p(__is, __fmt, __abbrev, __offset))
2750 template<
typename _CharT,
typename _Traits>
2753 const year_month_day_last& __ymdl)
2758 __os2 << __ymdl.year();
2759 if constexpr (is_same_v<_CharT, char>)
2763 __os2 << __ymdl.month_day_last();
2764 __os << __os2.view();
2768 template<
typename _CharT,
typename _Traits>
2769 inline basic_ostream<_CharT, _Traits>&
2770 operator<<(basic_ostream<_CharT, _Traits>& __os,
2771 const year_month_weekday& __ymwd)
2775 basic_stringstream<_CharT> __os2;
2776 __os2.
imbue(__os.getloc());
2778 if constexpr (is_same_v<_CharT, char>)
2782 __os2 << __ymwd.year() << __slash << __ymwd.month() << __slash
2783 << __ymwd.weekday_indexed();
2784 __os << __os2.view();
2788 template<
typename _CharT,
typename _Traits>
2789 inline basic_ostream<_CharT, _Traits>&
2790 operator<<(basic_ostream<_CharT, _Traits>& __os,
2791 const year_month_weekday_last& __ymwdl)
2795 basic_stringstream<_CharT> __os2;
2796 __os2.imbue(__os.getloc());
2798 if constexpr (is_same_v<_CharT, char>)
2802 __os2 << __ymwdl.year() << __slash << __ymwdl.month() << __slash
2803 << __ymwdl.weekday_last();
2804 __os << __os2.view();
2808 template<
typename _CharT,
typename _Traits,
typename _Duration>
2809 inline basic_ostream<_CharT, _Traits>&
2810 operator<<(basic_ostream<_CharT, _Traits>& __os,
2811 const hh_mm_ss<_Duration>& __hms)
2813 return __os << format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%T}"), __hms);
2816#if _GLIBCXX_USE_CXX11_ABI || ! _GLIBCXX_USE_DUAL_ABI
2818 template<
typename _CharT,
typename _Traits>
2819 basic_ostream<_CharT, _Traits>&
2820 operator<<(basic_ostream<_CharT, _Traits>& __os,
const sys_info& __i)
2822 __os <<
'[' << __i.begin <<
',' << __i.end
2823 <<
',' << hh_mm_ss(__i.offset) <<
',' << __i.save
2824 <<
',' << __i.abbrev <<
']';
2829 template<
typename _CharT,
typename _Traits>
2830 basic_ostream<_CharT, _Traits>&
2831 operator<<(basic_ostream<_CharT, _Traits>& __os,
const local_info& __li)
2834 if (__li.result == local_info::unique)
2838 if (__li.result == local_info::nonexistent)
2839 __os <<
"nonexistent";
2841 __os <<
"ambiguous";
2842 __os <<
" local time between " << __li.first;
2843 __os <<
" and " << __li.second;
2849 template<
typename _CharT,
typename _Traits,
typename _Duration,
2850 typename _TimeZonePtr>
2851 inline basic_ostream<_CharT, _Traits>&
2852 operator<<(basic_ostream<_CharT, _Traits>& __os,
2853 const zoned_time<_Duration, _TimeZonePtr>& __t)
2855 __os << format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%F %T %Z}"), __t);
2860 template<
typename _CharT,
typename _Traits,
typename _Duration>
2861 requires (!treat_as_floating_point_v<typename _Duration::rep>)
2862 && ratio_less_v<typename _Duration::period, days::period>
2863 inline basic_ostream<_CharT, _Traits>&
2864 operator<<(basic_ostream<_CharT, _Traits>& __os,
2865 const sys_time<_Duration>& __tp)
2867 __os << std::format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%F %T}"), __tp);
2871 template<
typename _CharT,
typename _Traits>
2872 inline basic_ostream<_CharT, _Traits>&
2873 operator<<(basic_ostream<_CharT, _Traits>& __os,
const sys_days& __dp)
2875 __os << year_month_day{__dp};
2879 template<
typename _CharT,
typename _Traits,
typename _Duration,
2880 typename _Alloc = allocator<_CharT>>
2881 basic_istream<_CharT, _Traits>&
2882 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2883 sys_time<_Duration>& __tp,
2884 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2885 minutes* __offset =
nullptr)
2890 using __format::_ChronoParts;
2891 auto __need = _ChronoParts::_Year | _ChronoParts::_Month
2892 | _ChronoParts::_Day | _ChronoParts::_TimeOfDay;
2893 __detail::_Parser_t<_Duration> __p(__need);
2894 if (__p(__is, __fmt, __abbrev, __offset))
2896 if (__p._M_is_leap_second)
2897 __is.setstate(ios_base::failbit);
2900 auto __st = __p._M_sys_days + __p._M_time - *__offset;
2901 __tp = __detail::__round<_Duration>(__st);
2907 template<
typename _CharT,
typename _Traits,
typename _Duration>
2908 inline basic_ostream<_CharT, _Traits>&
2909 operator<<(basic_ostream<_CharT, _Traits>& __os,
2910 const utc_time<_Duration>& __t)
2912 __os << std::format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%F %T}"), __t);
2916 template<
typename _CharT,
typename _Traits,
typename _Duration,
2917 typename _Alloc = allocator<_CharT>>
2918 inline basic_istream<_CharT, _Traits>&
2919 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2920 utc_time<_Duration>& __tp,
2921 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2922 minutes* __offset =
nullptr)
2927 using __format::_ChronoParts;
2928 auto __need = _ChronoParts::_Year | _ChronoParts::_Month
2929 | _ChronoParts::_Day | _ChronoParts::_TimeOfDay;
2930 __detail::_Parser_t<_Duration> __p(__need);
2931 if (__p(__is, __fmt, __abbrev, __offset))
2935 auto __ut = utc_clock::from_sys(__p._M_sys_days) + __p._M_time
2937 __tp = __detail::__round<_Duration>(__ut);
2942 template<
typename _CharT,
typename _Traits,
typename _Duration>
2943 inline basic_ostream<_CharT, _Traits>&
2944 operator<<(basic_ostream<_CharT, _Traits>& __os,
2945 const tai_time<_Duration>& __t)
2947 __os << std::format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%F %T}"), __t);
2951 template<
typename _CharT,
typename _Traits,
typename _Duration,
2952 typename _Alloc = allocator<_CharT>>
2953 inline basic_istream<_CharT, _Traits>&
2954 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2955 tai_time<_Duration>& __tp,
2956 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2957 minutes* __offset =
nullptr)
2962 using __format::_ChronoParts;
2963 auto __need = _ChronoParts::_Year | _ChronoParts::_Month
2964 | _ChronoParts::_Day | _ChronoParts::_TimeOfDay;
2965 __detail::_Parser_t<_Duration> __p(__need);
2966 if (__p(__is, __fmt, __abbrev, __offset))
2968 if (__p._M_is_leap_second)
2969 __is.setstate(ios_base::failbit);
2972 constexpr sys_days __epoch(-
days(4383));
2973 auto __d = __p._M_sys_days - __epoch + __p._M_time - *__offset;
2974 tai_time<common_type_t<_Duration, seconds>> __tt(__d);
2975 __tp = __detail::__round<_Duration>(__tt);
2981 template<
typename _CharT,
typename _Traits,
typename _Duration>
2982 inline basic_ostream<_CharT, _Traits>&
2983 operator<<(basic_ostream<_CharT, _Traits>& __os,
2984 const gps_time<_Duration>& __t)
2986 __os << std::format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%F %T}"), __t);
2990 template<
typename _CharT,
typename _Traits,
typename _Duration,
2991 typename _Alloc = allocator<_CharT>>
2992 inline basic_istream<_CharT, _Traits>&
2993 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
2994 gps_time<_Duration>& __tp,
2995 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
2996 minutes* __offset =
nullptr)
3001 using __format::_ChronoParts;
3002 auto __need = _ChronoParts::_Year | _ChronoParts::_Month
3003 | _ChronoParts::_Day | _ChronoParts::_TimeOfDay;
3004 __detail::_Parser_t<_Duration> __p(__need);
3005 if (__p(__is, __fmt, __abbrev, __offset))
3007 if (__p._M_is_leap_second)
3008 __is.setstate(ios_base::failbit);
3011 constexpr sys_days __epoch(
days(3657));
3012 auto __d = __p._M_sys_days - __epoch + __p._M_time - *__offset;
3013 gps_time<common_type_t<_Duration, seconds>> __gt(__d);
3014 __tp = __detail::__round<_Duration>(__gt);
3020 template<
typename _CharT,
typename _Traits,
typename _Duration>
3021 inline basic_ostream<_CharT, _Traits>&
3022 operator<<(basic_ostream<_CharT, _Traits>& __os,
3023 const file_time<_Duration>& __t)
3025 __os << std::format(__os.getloc(), _GLIBCXX_WIDEN(
"{:L%F %T}"), __t);
3029 template<
typename _CharT,
typename _Traits,
typename _Duration,
3030 typename _Alloc = allocator<_CharT>>
3031 inline basic_istream<_CharT, _Traits>&
3032 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
3033 file_time<_Duration>& __tp,
3034 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
3035 minutes* __offset =
nullptr)
3037 sys_time<_Duration> __st;
3038 if (chrono::from_stream(__is, __fmt, __st, __abbrev, __offset))
3039 __tp = __detail::__round<_Duration>(file_clock::from_sys(__st));
3043 template<
typename _CharT,
typename _Traits,
typename _Duration>
3044 inline basic_ostream<_CharT, _Traits>&
3045 operator<<(basic_ostream<_CharT, _Traits>& __os,
3046 const local_time<_Duration>& __lt)
3048 __os << sys_time<_Duration>{__lt.time_since_epoch()};
3052 template<
typename _CharT,
typename _Traits,
typename _Duration,
3053 typename _Alloc = allocator<_CharT>>
3054 basic_istream<_CharT, _Traits>&
3055 from_stream(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
3056 local_time<_Duration>& __tp,
3057 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
3058 minutes* __offset =
nullptr)
3060 using __format::_ChronoParts;
3061 auto __need = _ChronoParts::_Year | _ChronoParts::_Month
3062 | _ChronoParts::_Day | _ChronoParts::_TimeOfDay;
3063 __detail::_Parser_t<_Duration> __p(__need);
3064 if (__p(__is, __fmt, __abbrev, __offset))
3066 days __d = __p._M_sys_days.time_since_epoch();
3067 auto __t = local_days(__d) + __p._M_time;
3068 __tp = __detail::__round<_Duration>(__t);
3079 void from_stream() =
delete;
3081 template<
typename _Parsable,
typename _CharT,
3083 typename... _OptArgs>
3084 concept __parsable =
requires (basic_istream<_CharT, _Traits>& __is,
3085 const _CharT* __fmt, _Parsable& __tp,
3086 _OptArgs*... __args)
3087 { from_stream(__is, __fmt, __tp, __args...); };
3089 template<
typename _Parsable,
typename _CharT,
3090 typename _Traits = char_traits<_CharT>,
3091 typename _Alloc = allocator<_CharT>>
3095 using __string_type = basic_string<_CharT, _Traits, _Alloc>;
3098 _Parse(
const _CharT* __fmt, _Parsable& __tp,
3099 basic_string<_CharT, _Traits, _Alloc>* __abbrev =
nullptr,
3100 minutes* __offset =
nullptr)
3102 _M_abbrev(__abbrev), _M_offset(__offset)
3105 _Parse(_Parse&&) =
delete;
3106 _Parse& operator=(_Parse&&) =
delete;
3109 using __stream_type = basic_istream<_CharT, _Traits>;
3111 const _CharT*
const _M_fmt;
3112 _Parsable*
const _M_tp;
3113 __string_type*
const _M_abbrev;
3116 friend __stream_type&
3117 operator>>(__stream_type& __is, _Parse&& __p)
3120 from_stream(__is, __p._M_fmt, *__p._M_tp, __p._M_abbrev,
3122 else if (__p._M_abbrev)
3123 from_stream(__is, __p._M_fmt, *__p._M_tp, __p._M_abbrev);
3125 from_stream(__is, __p._M_fmt, *__p._M_tp);
3129 friend void operator>>(__stream_type&, _Parse&) =
delete;
3130 friend void operator>>(__stream_type&,
const _Parse&) =
delete;
3134 template<
typename _CharT, __detail::__parsable<_CharT> _Parsable>
3135 [[nodiscard, __gnu__::__access__(__read_only__, 1)]]
3137 parse(
const _CharT* __fmt, _Parsable& __tp)
3138 {
return __detail::_Parse<_Parsable, _CharT>(__fmt, __tp); }
3140 template<
typename _CharT,
typename _Traits,
typename _Alloc,
3141 __detail::__parsable<_CharT, _Traits> _Parsable>
3144 parse(
const basic_string<_CharT, _Traits, _Alloc>& __fmt, _Parsable& __tp)
3146 return __detail::_Parse<_Parsable, _CharT, _Traits>(__fmt.c_str(), __tp);
3149 template<
typename _CharT,
typename _Traits,
typename _Alloc,
3150 typename _StrT = basic_string<_CharT, _Traits, _Alloc>,
3151 __detail::__parsable<_CharT, _Traits, _StrT> _Parsable>
3152 [[nodiscard, __gnu__::__access__(__read_only__, 1)]]
3154 parse(
const _CharT* __fmt, _Parsable& __tp,
3155 basic_string<_CharT, _Traits, _Alloc>& __abbrev)
3158 return __detail::_Parse<_Parsable, _CharT, _Traits, _Alloc>(__fmt, __tp,
3162 template<
typename _CharT,
typename _Traits,
typename _Alloc,
3163 typename _StrT = basic_string<_CharT, _Traits, _Alloc>,
3164 __detail::__parsable<_CharT, _Traits, _StrT> _Parsable>
3167 parse(
const basic_string<_CharT, _Traits, _Alloc>& __fmt, _Parsable& __tp,
3168 basic_string<_CharT, _Traits, _Alloc>& __abbrev)
3171 return __detail::_Parse<_Parsable, _CharT, _Traits, _Alloc>(__fmt.c_str(),
3175 template<
typename _CharT,
typename _Traits =
char_traits<_CharT>,
3176 typename _StrT = basic_
string<_CharT, _Traits>,
3177 __detail::__parsable<_CharT, _Traits, _StrT, minutes> _Parsable>
3178 [[nodiscard, __gnu__::__access__(__read_only__, 1)]]
3180 parse(
const _CharT* __fmt, _Parsable& __tp, minutes& __offset)
3182 return __detail::_Parse<_Parsable, _CharT>(__fmt, __tp,
nullptr,
3186 template<
typename _CharT,
typename _Traits,
typename _Alloc,
3187 typename _StrT = basic_string<_CharT, _Traits>,
3188 __detail::__parsable<_CharT, _Traits, _StrT, minutes> _Parsable>
3191 parse(
const basic_string<_CharT, _Traits, _Alloc>& __fmt, _Parsable& __tp,
3194 return __detail::_Parse<_Parsable, _CharT, _Traits, _Alloc>(__fmt.c_str(),
3199 template<
typename _CharT,
typename _Traits,
typename _Alloc,
3200 typename _StrT = basic_string<_CharT, _Traits, _Alloc>,
3201 __detail::__parsable<_CharT, _Traits, _StrT, minutes> _Parsable>
3202 [[nodiscard, __gnu__::__access__(__read_only__, 1)]]
3204 parse(
const _CharT* __fmt, _Parsable& __tp,
3205 basic_string<_CharT, _Traits, _Alloc>& __abbrev, minutes& __offset)
3208 return __detail::_Parse<_Parsable, _CharT, _Traits, _Alloc>(__fmt, __tp,
3213 template<
typename _CharT,
typename _Traits,
typename _Alloc,
3214 typename _StrT = basic_string<_CharT, _Traits, _Alloc>,
3215 __detail::__parsable<_CharT, _Traits, _StrT, minutes> _Parsable>
3218 parse(
const basic_string<_CharT, _Traits, _Alloc>& __fmt, _Parsable& __tp,
3219 basic_string<_CharT, _Traits, _Alloc>& __abbrev, minutes& __offset)
3222 return __detail::_Parse<_Parsable, _CharT, _Traits, _Alloc>(__fmt.c_str(),
3228 template<
typename _Duration>
3229 template<
typename _CharT,
typename _Traits,
typename _Alloc>
3230 basic_istream<_CharT, _Traits>&
3231 __detail::_Parser<_Duration>::
3232 operator()(basic_istream<_CharT, _Traits>& __is,
const _CharT* __fmt,
3233 basic_string<_CharT, _Traits, _Alloc>* __abbrev,
3236 using sentry =
typename basic_istream<_CharT, _Traits>::sentry;
3237 ios_base::iostate __err = ios_base::goodbit;
3238 if (sentry __cerb(__is,
true); __cerb)
3240 locale __loc = __is.getloc();
3241 auto& __tmget = std::use_facet<std::time_get<_CharT>>(__loc);
3242 auto& __tmpunct = std::use_facet<std::__timepunct<_CharT>>(__loc);
3245 struct _Stream_state
3248 _Stream_state(basic_istream<_CharT, _Traits>& __i)
3250 _M_flags(__i.flags(ios_base::
skipws | ios_base::
dec)),
3256 _M_is.flags(_M_flags);
3260 _Stream_state(_Stream_state&&) =
delete;
3262 basic_istream<_CharT, _Traits>& _M_is;
3263 ios_base::fmtflags _M_flags;
3267 auto __is_failed = [](ios_base::iostate __e) {
3268 return static_cast<bool>(__e & ios_base::failbit);
3273 auto __read_unsigned = [&] (
int __n) {
3274 return _S_read_unsigned(__is, __err, __n);
3279 auto __read_signed = [&] (
int __n) {
3280 return _S_read_signed(__is, __err, __n);
3284 auto __read_chr = [&__is, &__err] (_CharT __c) {
3285 return _S_read_chr(__is, __err, __c);
3288 using __format::_ChronoParts;
3289 _ChronoParts __parts{};
3291 const year __bad_y = --year::min();
3292 const month __bad_mon(255);
3293 const day __bad_day(255);
3294 const weekday __bad_wday(255);
3295 const hours __bad_h(-1);
3296 const minutes __bad_min(-9999);
3299 year __y = __bad_y, __yy = __bad_y;
3300 year __iso_y = __bad_y, __iso_yy = __bad_y;
3301 month __m = __bad_mon;
3302 day __d = __bad_day;
3303 weekday __wday = __bad_wday;
3304 hours __h = __bad_h, __h12 = __bad_h;
3306 _Duration __s = __bad_sec;
3308 int __iso_wk = -1, __sunday_wk = -1, __monday_wk = -1;
3310 int __dayofyear = -1;
3312 minutes __tz_offset = __bad_min;
3313 basic_string<_CharT, _Traits> __tz_abbr;
3315 if ((_M_need & _ChronoParts::_TimeOfDay)
3316 && (_M_need & _ChronoParts::_Year))
3322 __parts = _ChronoParts::_TimeOfDay;
3329 bool __is_flag =
false;
3331 constexpr bool __is_floating
3332 = treat_as_floating_point_v<typename _Duration::rep>;
3351 _CharT __c = *__fmt++;
3358 else if (!__read_chr(__c)) [[unlikely]]
3369 if (__mod || __num) [[unlikely]]
3370 __err = ios_base::failbit;
3374 __tmget.get(__is, {}, __is, __err, &__tm,
3376 if (!__is_failed(__err))
3377 __wday = weekday(__tm.tm_wday);
3379 __parts |= _ChronoParts::_Weekday;
3385 if (__mod || __num) [[unlikely]]
3386 __err = ios_base::failbit;
3393 __tmget.get(__is, {}, __is, __err, &__tm,
3395 if (!__is_failed(__err))
3396 __m = month(__tm.tm_mon + 1);
3398 __parts |= _ChronoParts::_Month;
3402 if (__mod ==
'O' || __num) [[unlikely]]
3403 __err |= ios_base::failbit;
3407 __tmget.get(__is, {}, __is, __err, &__tm,
3408 __fmt - 2 - (__mod ==
'E'), __fmt);
3409 if (!__is_failed(__err))
3411 __y = year(__tm.tm_year + 1900);
3412 __m = month(__tm.tm_mon + 1);
3413 __d = day(__tm.tm_mday);
3414 __h =
hours(__tm.tm_hour);
3419 __parts |= _ChronoParts::_DateTime;
3423 if (!__mod) [[likely]]
3425 auto __v = __read_signed(__num ? __num : 2);
3426 if (!__is_failed(__err))
3428 int __cmin = (int)year::min() / 100;
3429 int __cmax = (int)year::max() / 100;
3430 if (__cmin <= __v && __v <= __cmax)
3431 __century = __v * 100;
3436 else if (__mod ==
'E')
3439 __tmget.get(__is, {}, __is, __err, &__tm,
3441 if (!__is_failed(__err))
3442 __century = __tm.tm_year;
3445 __err |= ios_base::failbit;
3451 if (!__mod) [[likely]]
3453 auto __v = __read_unsigned(__num ? __num : 2);
3454 if (!__is_failed(__err))
3457 else if (__mod ==
'O')
3460 __tmget.get(__is, {}, __is, __err, &__tm,
3462 if (!__is_failed(__err))
3463 __d = day(__tm.tm_mday);
3466 __err |= ios_base::failbit;
3467 __parts |= _ChronoParts::_Day;
3471 if (__mod || __num) [[unlikely]]
3472 __err |= ios_base::failbit;
3475 auto __month = __read_unsigned(2);
3477 auto __day = __read_unsigned(2);
3479 auto __year = __read_unsigned(2);
3480 if (__is_failed(__err))
3482 __y = year(__year + 1900 + 100 *
int(__year < 69));
3483 __m = month(__month);
3485 if (!year_month_day(__y, __m, __d).ok())
3487 __y = __yy = __iso_y = __iso_yy = __bad_y;
3493 __parts |= _ChronoParts::_Date;
3497 if (__mod) [[unlikely]]
3498 __err |= ios_base::failbit;
3501 auto __year = __read_signed(__num ? __num : 4);
3503 auto __month = __read_unsigned(2);
3505 auto __day = __read_unsigned(2);
3506 if (__is_failed(__err))
3509 __m = month(__month);
3511 if (!year_month_day(__y, __m, __d).ok())
3513 __y = __yy = __iso_y = __iso_yy = __bad_y;
3519 __parts |= _ChronoParts::_Date;
3523 if (__mod) [[unlikely]]
3524 __err |= ios_base::failbit;
3527 auto __val = __read_unsigned(__num ? __num : 2);
3528 if (__val >= 0 && __val <= 99)
3530 __iso_yy = year(__val);
3531 if (__century == -1)
3535 __iso_yy = __iso_y = __y = __yy = __bad_y;
3537 __parts |= _ChronoParts::_Year;
3541 if (__mod) [[unlikely]]
3542 __err |= ios_base::failbit;
3544 __iso_y = year(__read_unsigned(__num ? __num : 4));
3545 __parts |= _ChronoParts::_Year;
3550 if (__mod ==
'E') [[unlikely]]
3551 __err |= ios_base::failbit;
3552 else if (__mod ==
'O')
3557 __tmget.get(__is, {}, __is, __err, &__tm,
3559 if (!__is_failed(__err))
3563 __h12 =
hours(__tm.tm_hour);
3567 __h =
hours(__tm.tm_hour);
3571 __err |= ios_base::failbit;
3576 auto __val = __read_unsigned(__num ? __num : 2);
3577 if (__c ==
'I' && __val >= 1 && __val <= 12)
3579 __h12 =
hours(__val);
3582 else if (__c ==
'H' && __val >= 0 && __val <= 23)
3589 if (_M_need & _ChronoParts::_TimeOfDay)
3590 __err |= ios_base::failbit;
3594 __parts |= _ChronoParts::_TimeOfDay;
3598 if (__mod) [[unlikely]]
3599 __err |= ios_base::failbit;
3600 else if (_M_need == _ChronoParts::_TimeOfDay)
3602 auto __val = __read_signed(__num ? __num : 3);
3603 if (!__is_failed(__err))
3606 __parts |= _ChronoParts::_TimeOfDay;
3611 __dayofyear = __read_unsigned(__num ? __num : 3);
3618 if (__mod ==
'E') [[unlikely]]
3619 __err |= ios_base::failbit;
3620 else if (__mod ==
'O')
3623 __tmget.get(__is, {}, __is, __err, &__tm,
3625 if (!__is_failed(__err))
3626 __m = month(__tm.tm_mon + 1);
3630 auto __val = __read_unsigned(__num ? __num : 2);
3631 if (__val >= 1 && __val <= 12)
3636 __parts |= _ChronoParts::_Month;
3640 if (__mod ==
'E') [[unlikely]]
3641 __err |= ios_base::failbit;
3642 else if (__mod ==
'O')
3645 __tmget.get(__is, {}, __is, __err, &__tm,
3647 if (!__is_failed(__err))
3652 auto __val = __read_unsigned(__num ? __num : 2);
3653 if (0 <= __val && __val < 60)
3657 if (_M_need & _ChronoParts::_TimeOfDay)
3658 __err |= ios_base::failbit;
3662 __parts |= _ChronoParts::_TimeOfDay;
3667 __err |= ios_base::failbit;
3672 const _CharT* __ampms[2];
3673 __tmpunct._M_am_pm(__ampms);
3674 int __n = 0, __which = 3;
3675 while (__which != 0)
3677 auto __i = __is.peek();
3678 if (_Traits::eq_int_type(__i, _Traits::eof()))
3680 __err |= ios_base::eofbit | ios_base::failbit;
3688 else if (__ampms[0][__n + 1] == _CharT())
3699 else if (__ampms[1][__n + 1] == _CharT())
3710 if (__which == 0 || __which == 3)
3711 __err |= ios_base::failbit;
3719 __err |= ios_base::failbit;
3723 __tmget.get(__is, {}, __is, __err, &__tm,
3725 if (!__is_failed(__err))
3727 __h =
hours(__tm.tm_hour);
3732 __parts |= _ChronoParts::_TimeOfDay;
3737 if (__mod || __num) [[unlikely]]
3739 __err |= ios_base::failbit;
3744 auto __val = __read_unsigned(2);
3745 if (__val == -1 || __val > 23) [[unlikely]]
3747 if (_M_need & _ChronoParts::_TimeOfDay)
3748 __err |= ios_base::failbit;
3751 if (!__read_chr(
':')) [[unlikely]]
3755 __val = __read_unsigned(2);
3756 if (__val == -1 || __val > 60) [[unlikely]]
3758 if (_M_need & _ChronoParts::_TimeOfDay)
3759 __err |= ios_base::failbit;
3766 __parts |= _ChronoParts::_TimeOfDay;
3769 else if (!__read_chr(
':')) [[unlikely]]
3775 if (__mod ==
'E') [[unlikely]]
3776 __err |= ios_base::failbit;
3777 else if (__mod ==
'O')
3780 __tmget.get(__is, {}, __is, __err, &__tm,
3782 if (!__is_failed(__err))
3785 else if constexpr (_Duration::period::den == 1
3788 auto __val = __read_unsigned(__num ? __num : 2);
3789 if (0 <= __val && __val <= 59) [[likely]]
3793 if (_M_need & _ChronoParts::_TimeOfDay)
3794 __err |= ios_base::failbit;
3801 auto __digit = _S_try_read_digit(__is, __err);
3804 __buf.put(
'0' + __digit);
3805 __digit = _S_try_read_digit(__is, __err);
3807 __buf.put(
'0' + __digit);
3810 auto __i = __is.peek();
3811 if (_Traits::eq_int_type(__i, _Traits::eof()))
3812 __err |= ios_base::eofbit;
3816 if (__loc != locale::classic())
3818 auto& __np = use_facet<numpunct<_CharT>>(__loc);
3819 __dp = __np.decimal_point();
3821 _CharT __c = _Traits::to_char_type(__i);
3827 = hh_mm_ss<_Duration>::fractional_width;
3830 __digit = _S_try_read_digit(__is, __err);
3832 __buf.put(
'0' + __digit);
3840 if (!__is_failed(__err)) [[likely]]
3842 long double __val{};
3843#if __cpp_lib_to_chars
3845 auto __first = __str.data();
3846 auto __last = __first + __str.size();
3850 if ((
bool)ec || ptr != __last) [[unlikely]]
3851 __err |= ios_base::failbit;
3857 duration<long double> __fs(__val);
3858 if constexpr (__is_floating)
3861 __s = chrono::round<_Duration>(__fs);
3865 __parts |= _ChronoParts::_TimeOfDay;
3870 if (__mod ==
'E') [[unlikely]]
3871 __err |= ios_base::failbit;
3872 else if (__mod ==
'O')
3877 __tmget.get(__is, {}, __is, __err, &__tm,
3879 if (!__is_failed(__err))
3880 __wday = weekday(__tm.tm_wday);
3883 __err |= ios_base::failbit;
3887 const int __lo = __c ==
'u' ? 1 : 0;
3888 const int __hi = __lo + 6;
3889 auto __val = __read_unsigned(__num ? __num : 1);
3890 if (__lo <= __val && __val <= __hi)
3891 __wday = weekday(__val);
3894 __wday = __bad_wday;
3898 __parts |= _ChronoParts::_Weekday;
3904 if (__mod ==
'E') [[unlikely]]
3905 __err |= ios_base::failbit;
3906 else if (__mod ==
'O')
3908 if (__c ==
'V') [[unlikely]]
3909 __err |= ios_base::failbit;
3918 const int __lo = __c ==
'V' ? 1 : 0;
3919 const int __hi = 53;
3920 auto __val = __read_unsigned(__num ? __num : 2);
3921 if (__lo <= __val && __val <= __hi)
3926 __sunday_wk = __val;
3932 __monday_wk = __val;
3937 __iso_wk = __sunday_wk = __monday_wk = -1;
3943 if (__mod ==
'O' || __num) [[unlikely]]
3944 __err |= ios_base::failbit;
3948 __tmget.get(__is, {}, __is, __err, &__tm,
3949 __fmt - 2 - (__mod ==
'E'), __fmt);
3950 if (!__is_failed(__err))
3952 __y = year(__tm.tm_year + 1900);
3953 __m = month(__tm.tm_mon + 1);
3954 __d = day(__tm.tm_mday);
3957 __parts |= _ChronoParts::_Date;
3961 if (__mod ==
'O' || __num) [[unlikely]]
3962 __err |= ios_base::failbit;
3966 __tmget.get(__is, {}, __is, __err, &__tm,
3967 __fmt - 2 - (__mod ==
'E'), __fmt);
3968 if (!__is_failed(__err))
3970 __h =
hours(__tm.tm_hour);
3975 __parts |= _ChronoParts::_TimeOfDay;
3979 if (__mod) [[unlikely]]
3982 __tmget.get(__is, {}, __is, __err, &__tm,
3984 if (!__is_failed(__err))
3986 int __cent = __tm.tm_year < 2000 ? 1900 : 2000;
3987 __yy = year(__tm.tm_year - __cent);
3988 if (__century == -1)
3994 auto __val = __read_unsigned(__num ? __num : 2);
3995 if (__val >= 0 && __val <= 99)
3998 if (__century == -1)
3999 __century = __val < 69 ? 2000 : 1900;
4002 __y = __yy = __iso_yy = __iso_y = __bad_y;
4004 __parts |= _ChronoParts::_Year;
4008 if (__mod ==
'O') [[unlikely]]
4009 __err |= ios_base::failbit;
4010 else if (__mod ==
'E')
4013 __tmget.get(__is, {}, __is, __err, &__tm,
4015 if (!__is_failed(__err))
4016 __y = year(__tm.tm_year);
4020 auto __val = __read_unsigned(__num ? __num : 4);
4021 if (!__is_failed(__err))
4024 __parts |= _ChronoParts::_Year;
4028 if (__num) [[unlikely]]
4029 __err |= ios_base::failbit;
4035 auto __i = __is.peek();
4036 if (_Traits::eq_int_type(__i, _Traits::eof()))
4038 __err |= ios_base::eofbit | ios_base::failbit;
4041 _CharT __ic = _Traits::to_char_type(__i);
4042 const bool __neg = __ic == _CharT(
'-');
4043 if (__ic == _CharT(
'-') || __ic == _CharT(
'+'))
4050 __hh = __read_unsigned(2);
4055 __hh = 10 * _S_try_read_digit(__is, __err);
4056 __hh += _S_try_read_digit(__is, __err);
4059 if (__is_failed(__err))
4063 if (_Traits::eq_int_type(__i, _Traits::eof()))
4065 __err |= ios_base::eofbit;
4066 __tz_offset =
minutes(__hh * (__neg ? -60 : 60));
4069 __ic = _Traits::to_char_type(__i);
4071 bool __read_mm =
false;
4074 if (__ic == _GLIBCXX_WIDEN(
":")[0])
4081 else if (_CharT(
'0') <= __ic && __ic <= _CharT(
'9'))
4087 int_least32_t __mm = 0;
4090 __mm = 10 * _S_try_read_digit(__is, __err);
4091 __mm += _S_try_read_digit(__is, __err);
4094 if (!__is_failed(__err))
4096 auto __z = __hh * 60 + __mm;
4097 __tz_offset =
minutes(__neg ? -__z : __z);
4103 if (__mod || __num) [[unlikely]]
4104 __err |= ios_base::failbit;
4107 basic_string_view<_CharT> __x = _GLIBCXX_WIDEN(
"_/-+");
4111 auto __i = __is.peek();
4112 if (!_Traits::eq_int_type(__i, _Traits::eof()))
4114 _CharT __a = _Traits::to_char_type(__i);
4116 || __x.find(__a) != __x.npos)
4118 __tz_abbr.push_back(__a);
4124 __err |= ios_base::eofbit;
4127 if (__tz_abbr.empty())
4128 __err |= ios_base::failbit;
4133 if (__mod || __num) [[unlikely]]
4134 __err |= ios_base::failbit;
4137 _CharT __i = __is.peek();
4138 if (_Traits::eq_int_type(__i, _Traits::eof()))
4139 __err |= ios_base::eofbit | ios_base::failbit;
4140 else if (
std::isspace(_Traits::to_char_type(__i), __loc))
4143 __err |= ios_base::failbit;
4148 if (__mod || __num) [[unlikely]]
4149 __err |= ios_base::failbit;
4152 _CharT __i = __is.peek();
4153 if (_Traits::eq_int_type(__i, _Traits::eof()))
4154 __err |= ios_base::eofbit;
4155 else if (
std::isspace(_Traits::to_char_type(__i), __loc))
4161 if (__mod || __num) [[unlikely]]
4162 __err |= ios_base::failbit;
4169 if (__mod || __num) [[unlikely]]
4171 __err |= ios_base::failbit;
4178 if (_CharT(
'1') <= __c && __c <= _CharT(
'9'))
4180 if (!__mod) [[likely]]
4183 auto __end = __fmt + _Traits::length(__fmt);
4185 = __format::__parse_integer(__fmt - 1, __end);
4186 if (__ptr) [[likely]]
4194 __err |= ios_base::failbit;
4197 if (__is_failed(__err)) [[unlikely]]
4207 if (__yy != __bad_y && __y == __bad_y)
4208 __y =
years(__century) + __yy;
4209 if (__iso_yy != __bad_y && __iso_y == __bad_y)
4210 __iso_y =
years(__century) + __iso_yy;
4213 bool __can_use_doy =
false;
4214 bool __can_use_iso_wk =
false;
4215 bool __can_use_sun_wk =
false;
4216 bool __can_use_mon_wk =
false;
4219 if (__y != __bad_y && __dayofyear >= 0)
4221 __can_use_doy =
true;
4222 __parts |= _ChronoParts::_Date;
4224 else if (__y != __bad_y && __wday != __bad_wday && __sunday_wk >= 0)
4226 __can_use_sun_wk =
true;
4227 __parts |= _ChronoParts::_Date;
4229 else if (__y != __bad_y && __wday != __bad_wday && __monday_wk >= 0)
4231 __can_use_mon_wk =
true;
4232 __parts |= _ChronoParts::_Date;
4234 else if (__iso_y != __bad_y && __wday != __bad_wday && __iso_wk > 0)
4237 __can_use_iso_wk =
true;
4238 __parts |= _ChronoParts::_Date;
4241 if (__is_failed(__err)) [[unlikely]]
4243 else if (__is_flag) [[unlikely]]
4244 __err |= ios_base::failbit;
4245 else if ((_M_need & __parts) == _M_need) [[likely]]
4267 const bool __need_wday = _M_need & _ChronoParts::_Weekday;
4271 const bool __need_time = _M_need & _ChronoParts::_TimeOfDay;
4273 if (__need_wday && __wday != __bad_wday)
4275 else if (_M_need & _ChronoParts::_Date)
4279 const bool __need_ymd = !__need_wday && !__need_time;
4281 if ((_M_need & _ChronoParts::_Year && __y == __bad_y)
4282 || (_M_need & _ChronoParts::_Month && __m == __bad_mon)
4283 || (_M_need & _ChronoParts::_Day && __d == __bad_day))
4290 if ((0 < __dayofyear && __dayofyear <= 365)
4291 || (__dayofyear == 366 && __y.is_leap()))
4294 _M_sys_days = sys_days(__y/January/1)
4295 +
days(__dayofyear - 1);
4297 _M_ymd = year_month_day(_M_sys_days);
4300 __err |= ios_base::failbit;
4302 else if (__can_use_iso_wk)
4310 const sys_days __jan4(__iso_y/January/4);
4311 weekday __wd1(__jan4 -
days(3));
4312 if (__wd1 != Thursday)
4313 if (__wd1 != Wednesday || !__iso_y.is_leap())
4314 __err |= ios_base::failbit;
4317 if (!__is_failed(__err)) [[likely]]
4320 sys_days __w(Thursday[1]/January/__iso_y);
4322 __w -= Thursday - Monday;
4324 __w += __wday - Monday;
4328 _M_ymd = year_month_day(_M_sys_days);
4331 else if (__can_use_sun_wk)
4334 sys_days __wk1(__y/January/Sunday[1]);
4335 _M_sys_days = __wk1 +
weeks(__sunday_wk - 1)
4336 +
days(__wday.c_encoding());
4337 _M_ymd = year_month_day(_M_sys_days);
4338 if (_M_ymd.year() != __y) [[unlikely]]
4339 __err |= ios_base::failbit;
4341 else if (__can_use_mon_wk)
4344 sys_days __wk1(__y/January/Monday[1]);
4345 _M_sys_days = __wk1 +
weeks(__monday_wk - 1)
4346 +
days(__wday.c_encoding() - 1);
4347 _M_ymd = year_month_day(_M_sys_days);
4348 if (_M_ymd.year() != __y) [[unlikely]]
4349 __err |= ios_base::failbit;
4352 __err |= ios_base::failbit;
4360 if (_M_need & _ChronoParts::_Year)
4362 if (!__y.ok()) [[unlikely]]
4363 __err |= ios_base::failbit;
4365 else if (__y == __bad_y)
4368 if (_M_need & _ChronoParts::_Month)
4370 if (!__m.ok()) [[unlikely]]
4371 __err |= ios_base::failbit;
4373 else if (__m == __bad_mon)
4376 if (_M_need & _ChronoParts::_Day)
4378 if (__d < day(1) || __d > (__y/__m/last).day())
4379 __err |= ios_base::failbit;
4381 else if (__d == __bad_day)
4384 if (year_month_day __ymd(__y, __m, __d); __ymd.ok())
4387 if (__need_wday || __need_time)
4388 _M_sys_days = sys_days(_M_ymd);
4391 __err |= ios_base::failbit;
4395 _M_wd = weekday(_M_sys_days);
4401 if (__h == __bad_h && __h12 != __bad_h)
4405 else if (__ampm == 2)
4406 __h = __h12 ==
hours(12) ? __h12 : __h12 +
hours(12);
4408 __err |= ios_base::failbit;
4411 auto __t = _M_time.zero();
4420 if (__min != __bad_min)
4426 if (__s != __bad_sec)
4430 _M_is_leap_second = __s >=
seconds(60);
4436 __err |= ios_base::failbit;
4439 if (!__is_failed(__err)) [[likely]]
4441 if (__offset && __tz_offset != __bad_min)
4442 *__offset = __tz_offset;
4443 if (__abbrev && !__tz_abbr.empty())
4448 __err |= ios_base::failbit;
4451 __is.setstate(__err);
4455#undef _GLIBCXX_WIDEN
4460_GLIBCXX_END_NAMESPACE_VERSION
__detail::__local_time_fmt< _Duration > local_time_format(local_time< _Duration > __time, const string *__abbrev=nullptr, const seconds *__offset_sec=nullptr)
duration< int64_t > seconds
seconds
duration< int64_t, ratio< 604800 > > weeks
weeks
duration< int64_t, ratio< 3600 > > hours
hours
duration< int64_t, ratio< 86400 > > days
days
basic_ostream< _CharT, _Traits > & operator<<(std::basic_ostream< _CharT, _Traits > &__os, const duration< _Rep, _Period > &__d)
duration< int64_t, ratio< 60 > > minutes
minutes
duration< int64_t, ratio< 31556952 > > years
years
basic_stringstream< char > stringstream
Class for char mixed input and output memory streams.
constexpr std::remove_reference< _Tp >::type && move(_Tp &&__t) noexcept
Convert a value to an rvalue.
constexpr _Tp * __addressof(_Tp &__r) noexcept
Same as C++11 std::addressof.
constexpr const _Tp & min(const _Tp &, const _Tp &)
This does what you think it does.
ISO C++ entities toplevel namespace is std.
ptrdiff_t streamsize
Integral type for I/O operation counts and buffer sizes.
chars_format
floating-point format for primitive numerical conversion
bool isspace(_CharT __c, const locale &__loc)
Convenience interface to ctype.is(ctype_base::space, __c).
_CharT toupper(_CharT __c, const locale &__loc)
Convenience interface to ctype.toupper(__c).
bool isalnum(_CharT __c, const locale &__loc)
Convenience interface to ctype.is(ctype_base::alnum, __c).
ios_base & dec(ios_base &__base)
Calls base.setf(ios_base::dec, ios_base::basefield).
ios_base & skipws(ios_base &__base)
Calls base.setf(ios_base::skipws).
std::basic_istream< _CharT, _Traits > & operator>>(std::basic_istream< _CharT, _Traits > &__is, bitset< _Nb > &__x)
Global I/O operators for bitsets.
std::basic_ostream< _CharT, _Traits > & operator<<(std::basic_ostream< _CharT, _Traits > &__os, const bitset< _Nb > &__x)
Global I/O operators for bitsets.
constexpr bitset< _Nb > operator|(const bitset< _Nb > &__x, const bitset< _Nb > &__y) noexcept
Global bitwise operations on bitsets.
basic_istream< _CharT, _Traits > & ws(basic_istream< _CharT, _Traits > &__is)
Quick and easy way to eat whitespace.
constexpr from_chars_result from_chars(const char *__first, const char *__last, _Tp &__value, int __base=10)
std::from_chars for integral types.
ISO C++ 2011 namespace for date and time utilities.
locale imbue(const locale &__loc)
Moves to a new locale.
Template class basic_istream.
Template class basic_ostream.
Controlling output for std::string.
Controlling input and output for std::string.
Provides output iterator semantics for streambufs.
Provides compile-time rational arithmetic.
A non-owning reference to a string.
Basis for explicit traits specializations.
chrono::duration represents a distance between two points in time
chrono::time_point represents a point in time as measured by a clock
Managing sequences of characters and character-like objects.
streamsize precision() const
Flags access.
fmtflags flags() const
Access to format flags.
locale getloc() const
Locale access.
Container class for localization functionality.
static const locale & classic()
Return reference to the C locale.