blob: 06fa6581f38f97595e8e3da0f23422dbe5772746 [file] [log] [blame]
Howard Hinnantc51e1022010-05-11 19:42:16 +00001// -*- C++ -*-
2//===---------------------------- chrono ----------------------------------===//
3//
Chandler Carruthd2012102019-01-19 10:56:40 +00004// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5// See https://llvm.org/LICENSE.txt for license information.
6// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Howard Hinnantc51e1022010-05-11 19:42:16 +00007//
8//===----------------------------------------------------------------------===//
9
10#ifndef _LIBCPP_CHRONO
11#define _LIBCPP_CHRONO
12
13/*
14 chrono synopsis
15
16namespace std
17{
18namespace chrono
19{
20
21template <class ToDuration, class Rep, class Period>
Howard Hinnantcf3143c2012-07-13 19:17:27 +000022constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +000023ToDuration
24duration_cast(const duration<Rep, Period>& fd);
25
26template <class Rep> struct treat_as_floating_point : is_floating_point<Rep> {};
27
Marshall Clowf1bf62f2018-01-02 17:17:01 +000028template <class Rep> inline constexpr bool treat_as_floating_point_v
Marshall Clow59581f02015-11-30 05:39:30 +000029 = treat_as_floating_point<Rep>::value; // C++17
30
Howard Hinnantc51e1022010-05-11 19:42:16 +000031template <class Rep>
32struct duration_values
33{
34public:
Marshall Clowb1296bd2018-11-13 17:22:41 +000035 static constexpr Rep zero(); // noexcept in C++20
36 static constexpr Rep max(); // noexcept in C++20
37 static constexpr Rep min(); // noexcept in C++20
Howard Hinnantc51e1022010-05-11 19:42:16 +000038};
39
40// duration
41
42template <class Rep, class Period = ratio<1>>
43class duration
44{
45 static_assert(!__is_duration<Rep>::value, "A duration representation can not be a duration");
46 static_assert(__is_ratio<Period>::value, "Second template parameter of duration must be a std::ratio");
47 static_assert(Period::num > 0, "duration period must be positive");
48public:
49 typedef Rep rep;
Marshall Clow76200b22017-03-21 18:38:57 +000050 typedef typename _Period::type period;
Howard Hinnantc51e1022010-05-11 19:42:16 +000051
Howard Hinnantcf3143c2012-07-13 19:17:27 +000052 constexpr duration() = default;
Howard Hinnantc51e1022010-05-11 19:42:16 +000053 template <class Rep2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +000054 constexpr explicit duration(const Rep2& r,
Howard Hinnantc51e1022010-05-11 19:42:16 +000055 typename enable_if
56 <
57 is_convertible<Rep2, rep>::value &&
58 (treat_as_floating_point<rep>::value ||
59 !treat_as_floating_point<rep>::value && !treat_as_floating_point<Rep2>::value)
60 >::type* = 0);
61
62 // conversions
63 template <class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +000064 constexpr duration(const duration<Rep2, Period2>& d,
Howard Hinnantc51e1022010-05-11 19:42:16 +000065 typename enable_if
66 <
67 treat_as_floating_point<rep>::value ||
68 ratio_divide<Period2, period>::type::den == 1
69 >::type* = 0);
70
71 // observer
72
Howard Hinnantcf3143c2012-07-13 19:17:27 +000073 constexpr rep count() const;
Howard Hinnantc51e1022010-05-11 19:42:16 +000074
75 // arithmetic
76
Marshall Clow76200b22017-03-21 18:38:57 +000077 constexpr common_type<duration>::type operator+() const;
78 constexpr common_type<duration>::type operator-() const;
Marshall Clowdf247eb2018-08-29 23:02:15 +000079 constexpr duration& operator++(); // constexpr in C++17
80 constexpr duration operator++(int); // constexpr in C++17
81 constexpr duration& operator--(); // constexpr in C++17
82 constexpr duration operator--(int); // constexpr in C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000083
Marshall Clowdf247eb2018-08-29 23:02:15 +000084 constexpr duration& operator+=(const duration& d); // constexpr in C++17
85 constexpr duration& operator-=(const duration& d); // constexpr in C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000086
Marshall Clowdf247eb2018-08-29 23:02:15 +000087 duration& operator*=(const rep& rhs); // constexpr in C++17
88 duration& operator/=(const rep& rhs); // constexpr in C++17
89 duration& operator%=(const rep& rhs); // constexpr in C++17
90 duration& operator%=(const duration& rhs); // constexpr in C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000091
92 // special values
93
Marshall Clowb1296bd2018-11-13 17:22:41 +000094 static constexpr duration zero(); // noexcept in C++20
95 static constexpr duration min(); // noexcept in C++20
96 static constexpr duration max(); // noexcept in C++20
Howard Hinnantc51e1022010-05-11 19:42:16 +000097};
98
99typedef duration<long long, nano> nanoseconds;
100typedef duration<long long, micro> microseconds;
101typedef duration<long long, milli> milliseconds;
102typedef duration<long long > seconds;
103typedef duration< long, ratio< 60> > minutes;
104typedef duration< long, ratio<3600> > hours;
105
106template <class Clock, class Duration = typename Clock::duration>
107class time_point
108{
109public:
110 typedef Clock clock;
111 typedef Duration duration;
112 typedef typename duration::rep rep;
113 typedef typename duration::period period;
114private:
115 duration d_; // exposition only
116
117public:
Marshall Clow5c459c92013-07-31 19:32:19 +0000118 time_point(); // has value "epoch" // constexpr in C++14
119 explicit time_point(const duration& d); // same as time_point() + d // constexpr in C++14
Howard Hinnantc51e1022010-05-11 19:42:16 +0000120
121 // conversions
122 template <class Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +0000123 time_point(const time_point<clock, Duration2>& t); // constexpr in C++14
Howard Hinnantc51e1022010-05-11 19:42:16 +0000124
125 // observer
126
Marshall Clow5c459c92013-07-31 19:32:19 +0000127 duration time_since_epoch() const; // constexpr in C++14
Howard Hinnantc51e1022010-05-11 19:42:16 +0000128
129 // arithmetic
130
Marshall Clowdf247eb2018-08-29 23:02:15 +0000131 time_point& operator+=(const duration& d); // constexpr in C++17
132 time_point& operator-=(const duration& d); // constexpr in C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +0000133
134 // special values
135
Marshall Clowb1296bd2018-11-13 17:22:41 +0000136 static constexpr time_point min(); // noexcept in C++20
137 static constexpr time_point max(); // noexcept in C++20
Howard Hinnantc51e1022010-05-11 19:42:16 +0000138};
139
140} // chrono
141
142// common_type traits
143template <class Rep1, class Period1, class Rep2, class Period2>
144 struct common_type<chrono::duration<Rep1, Period1>, chrono::duration<Rep2, Period2>>;
145
146template <class Clock, class Duration1, class Duration2>
147 struct common_type<chrono::time_point<Clock, Duration1>, chrono::time_point<Clock, Duration2>>;
148
149namespace chrono {
150
Marshall Clow40ca0c12018-07-18 17:37:51 +0000151
152template<class T> struct is_clock; // C++20
153template<class T> inline constexpr bool is_clock_v = is_clock<T>::value; // C++20
154
155
Howard Hinnantc51e1022010-05-11 19:42:16 +0000156// duration arithmetic
157template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000158 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000159 typename common_type<duration<Rep1, Period1>, duration<Rep2, Period2>>::type
160 operator+(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
161template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000162 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000163 typename common_type<duration<Rep1, Period1>, duration<Rep2, Period2>>::type
164 operator-(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
165template <class Rep1, class Period, class Rep2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000166 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000167 duration<typename common_type<Rep1, Rep2>::type, Period>
168 operator*(const duration<Rep1, Period>& d, const Rep2& s);
169template <class Rep1, class Period, class Rep2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000170 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000171 duration<typename common_type<Rep1, Rep2>::type, Period>
172 operator*(const Rep1& s, const duration<Rep2, Period>& d);
173template <class Rep1, class Period, class Rep2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000174 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000175 duration<typename common_type<Rep1, Rep2>::type, Period>
176 operator/(const duration<Rep1, Period>& d, const Rep2& s);
177template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000178 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000179 typename common_type<Rep1, Rep2>::type
180 operator/(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
181
182// duration comparisons
183template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000184 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000185 bool operator==(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
186template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000187 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000188 bool operator!=(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
189template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000190 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000191 bool operator< (const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
192template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000193 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000194 bool operator<=(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
195template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000196 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000197 bool operator> (const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
198template <class Rep1, class Period1, class Rep2, class Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000199 constexpr
Howard Hinnantc51e1022010-05-11 19:42:16 +0000200 bool operator>=(const duration<Rep1, Period1>& lhs, const duration<Rep2, Period2>& rhs);
201
202// duration_cast
203template <class ToDuration, class Rep, class Period>
204 ToDuration duration_cast(const duration<Rep, Period>& d);
205
Marshall Clowf2eabaf2015-11-05 19:33:59 +0000206template <class ToDuration, class Rep, class Period>
207 constexpr ToDuration floor(const duration<Rep, Period>& d); // C++17
208template <class ToDuration, class Rep, class Period>
209 constexpr ToDuration ceil(const duration<Rep, Period>& d); // C++17
210template <class ToDuration, class Rep, class Period>
211 constexpr ToDuration round(const duration<Rep, Period>& d); // C++17
212
Marshall Clow40ca0c12018-07-18 17:37:51 +0000213// duration I/O is elsewhere
214
Marshall Clow5c459c92013-07-31 19:32:19 +0000215// time_point arithmetic (all constexpr in C++14)
Howard Hinnantc51e1022010-05-11 19:42:16 +0000216template <class Clock, class Duration1, class Rep2, class Period2>
217 time_point<Clock, typename common_type<Duration1, duration<Rep2, Period2>>::type>
218 operator+(const time_point<Clock, Duration1>& lhs, const duration<Rep2, Period2>& rhs);
219template <class Rep1, class Period1, class Clock, class Duration2>
220 time_point<Clock, typename common_type<duration<Rep1, Period1>, Duration2>::type>
221 operator+(const duration<Rep1, Period1>& lhs, const time_point<Clock, Duration2>& rhs);
222template <class Clock, class Duration1, class Rep2, class Period2>
223 time_point<Clock, typename common_type<Duration1, duration<Rep2, Period2>>::type>
224 operator-(const time_point<Clock, Duration1>& lhs, const duration<Rep2, Period2>& rhs);
225template <class Clock, class Duration1, class Duration2>
226 typename common_type<Duration1, Duration2>::type
227 operator-(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
228
Marshall Clow5c459c92013-07-31 19:32:19 +0000229// time_point comparisons (all constexpr in C++14)
Howard Hinnantc51e1022010-05-11 19:42:16 +0000230template <class Clock, class Duration1, class Duration2>
231 bool operator==(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
232template <class Clock, class Duration1, class Duration2>
233 bool operator!=(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
234template <class Clock, class Duration1, class Duration2>
235 bool operator< (const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
236template <class Clock, class Duration1, class Duration2>
237 bool operator<=(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
238template <class Clock, class Duration1, class Duration2>
239 bool operator> (const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
240template <class Clock, class Duration1, class Duration2>
241 bool operator>=(const time_point<Clock, Duration1>& lhs, const time_point<Clock, Duration2>& rhs);
242
Marshall Clow5c459c92013-07-31 19:32:19 +0000243// time_point_cast (constexpr in C++14)
Howard Hinnantc51e1022010-05-11 19:42:16 +0000244
245template <class ToDuration, class Clock, class Duration>
246 time_point<Clock, ToDuration> time_point_cast(const time_point<Clock, Duration>& t);
247
Marshall Clowf2eabaf2015-11-05 19:33:59 +0000248template <class ToDuration, class Clock, class Duration>
249 constexpr time_point<Clock, ToDuration>
250 floor(const time_point<Clock, Duration>& tp); // C++17
251
252template <class ToDuration, class Clock, class Duration>
253 constexpr time_point<Clock, ToDuration>
254 ceil(const time_point<Clock, Duration>& tp); // C++17
255
256template <class ToDuration, class Clock, class Duration>
257 constexpr time_point<Clock, ToDuration>
258 round(const time_point<Clock, Duration>& tp); // C++17
259
260template <class Rep, class Period>
261 constexpr duration<Rep, Period> abs(duration<Rep, Period> d); // C++17
Marshall Clow40ca0c12018-07-18 17:37:51 +0000262
Howard Hinnantc51e1022010-05-11 19:42:16 +0000263// Clocks
264
265class system_clock
266{
267public:
268 typedef microseconds duration;
269 typedef duration::rep rep;
270 typedef duration::period period;
271 typedef chrono::time_point<system_clock> time_point;
Marshall Clow5c459c92013-07-31 19:32:19 +0000272 static const bool is_steady = false; // constexpr in C++14
Howard Hinnantc51e1022010-05-11 19:42:16 +0000273
Howard Hinnantaa54ac42011-05-28 18:34:36 +0000274 static time_point now() noexcept;
275 static time_t to_time_t (const time_point& __t) noexcept;
276 static time_point from_time_t(time_t __t) noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000277};
278
Marshall Clow40ca0c12018-07-18 17:37:51 +0000279template <class Duration>
280 using sys_time = time_point<system_clock, Duration>; // C++20
281using sys_seconds = sys_time<seconds>; // C++20
282using sys_days = sys_time<days>; // C++20
283
284class utc_clock; // C++20
285
286template <class Duration>
287 using utc_time = time_point<utc_clock, Duration>; // C++20
288using utc_seconds = utc_time<seconds>; // C++20
289
290class tai_clock; // C++20
291
292template <class Duration>
293 using tai_time = time_point<tai_clock, Duration>; // C++20
294using tai_seconds = tai_time<seconds>; // C++20
295
296class file_clock; // C++20
297
298template<class Duration>
299 using file_time = time_point<file_clock, Duration>; // C++20
300
Howard Hinnantc8dbd222010-11-20 19:16:30 +0000301class steady_clock
Howard Hinnantc51e1022010-05-11 19:42:16 +0000302{
303public:
304 typedef nanoseconds duration;
305 typedef duration::rep rep;
306 typedef duration::period period;
Howard Hinnantc8dbd222010-11-20 19:16:30 +0000307 typedef chrono::time_point<steady_clock, duration> time_point;
Marshall Clow5c459c92013-07-31 19:32:19 +0000308 static const bool is_steady = true; // constexpr in C++14
Howard Hinnantc51e1022010-05-11 19:42:16 +0000309
Howard Hinnantaa54ac42011-05-28 18:34:36 +0000310 static time_point now() noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000311};
312
Howard Hinnantc8dbd222010-11-20 19:16:30 +0000313typedef steady_clock high_resolution_clock;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000314
Marshall Clow40ca0c12018-07-18 17:37:51 +0000315// 25.7.8, local time // C++20
316struct local_t {};
317template<class Duration>
318 using local_time = time_point<local_t, Duration>;
319using local_seconds = local_time<seconds>;
320using local_days = local_time<days>;
321
322// 25.7.9, time_point conversions template<class DestClock, class SourceClock> // C++20
323struct clock_time_conversion;
324
325template<class DestClock, class SourceClock, class Duration>
326 auto clock_cast(const time_point<SourceClock, Duration>& t);
Louis Dionne44bcff92018-08-03 22:36:53 +0000327
Marshall Clow40ca0c12018-07-18 17:37:51 +0000328// 25.8.2, class last_spec // C++20
329struct last_spec;
330
331// 25.8.3, class day // C++20
332
333class day;
334constexpr bool operator==(const day& x, const day& y) noexcept;
335constexpr bool operator!=(const day& x, const day& y) noexcept;
336constexpr bool operator< (const day& x, const day& y) noexcept;
337constexpr bool operator> (const day& x, const day& y) noexcept;
338constexpr bool operator<=(const day& x, const day& y) noexcept;
339constexpr bool operator>=(const day& x, const day& y) noexcept;
340constexpr day operator+(const day& x, const days& y) noexcept;
341constexpr day operator+(const days& x, const day& y) noexcept;
342constexpr day operator-(const day& x, const days& y) noexcept;
343constexpr days operator-(const day& x, const day& y) noexcept;
344
345// 25.8.4, class month // C++20
346class month;
347constexpr bool operator==(const month& x, const month& y) noexcept;
348constexpr bool operator!=(const month& x, const month& y) noexcept;
349constexpr bool operator< (const month& x, const month& y) noexcept;
350constexpr bool operator> (const month& x, const month& y) noexcept;
351constexpr bool operator<=(const month& x, const month& y) noexcept;
352constexpr bool operator>=(const month& x, const month& y) noexcept;
353constexpr month operator+(const month& x, const months& y) noexcept;
354constexpr month operator+(const months& x, const month& y) noexcept;
355constexpr month operator-(const month& x, const months& y) noexcept;
356constexpr months operator-(const month& x, const month& y) noexcept;
357
358// 25.8.5, class year // C++20
359class year;
360constexpr bool operator==(const year& x, const year& y) noexcept;
361constexpr bool operator!=(const year& x, const year& y) noexcept;
362constexpr bool operator< (const year& x, const year& y) noexcept;
363constexpr bool operator> (const year& x, const year& y) noexcept;
364constexpr bool operator<=(const year& x, const year& y) noexcept;
365constexpr bool operator>=(const year& x, const year& y) noexcept;
366constexpr year operator+(const year& x, const years& y) noexcept;
367constexpr year operator+(const years& x, const year& y) noexcept;
368constexpr year operator-(const year& x, const years& y) noexcept;
369constexpr years operator-(const year& x, const year& y) noexcept;
370
371// 25.8.6, class weekday // C++20
372class weekday;
373
374constexpr bool operator==(const weekday& x, const weekday& y) noexcept;
375constexpr bool operator!=(const weekday& x, const weekday& y) noexcept;
376constexpr weekday operator+(const weekday& x, const days& y) noexcept;
377constexpr weekday operator+(const days& x, const weekday& y) noexcept;
378constexpr weekday operator-(const weekday& x, const days& y) noexcept;
379constexpr days operator-(const weekday& x, const weekday& y) noexcept;
380
381// 25.8.7, class weekday_indexed // C++20
382
383class weekday_indexed;
384constexpr bool operator==(const weekday_indexed& x, const weekday_indexed& y) noexcept;
385constexpr bool operator!=(const weekday_indexed& x, const weekday_indexed& y) noexcept;
386
387// 25.8.8, class weekday_last // C++20
388class weekday_last;
389
390constexpr bool operator==(const weekday_last& x, const weekday_last& y) noexcept;
391constexpr bool operator!=(const weekday_last& x, const weekday_last& y) noexcept;
392
393// 25.8.9, class month_day // C++20
394class month_day;
395
396constexpr bool operator==(const month_day& x, const month_day& y) noexcept;
397constexpr bool operator!=(const month_day& x, const month_day& y) noexcept;
398constexpr bool operator< (const month_day& x, const month_day& y) noexcept;
399constexpr bool operator> (const month_day& x, const month_day& y) noexcept;
400constexpr bool operator<=(const month_day& x, const month_day& y) noexcept;
401constexpr bool operator>=(const month_day& x, const month_day& y) noexcept;
402
403
404// 25.8.10, class month_day_last // C++20
405class month_day_last;
406
407constexpr bool operator==(const month_day_last& x, const month_day_last& y) noexcept;
408constexpr bool operator!=(const month_day_last& x, const month_day_last& y) noexcept;
409constexpr bool operator< (const month_day_last& x, const month_day_last& y) noexcept;
410constexpr bool operator> (const month_day_last& x, const month_day_last& y) noexcept;
411constexpr bool operator<=(const month_day_last& x, const month_day_last& y) noexcept;
412constexpr bool operator>=(const month_day_last& x, const month_day_last& y) noexcept;
413
414// 25.8.11, class month_weekday // C++20
415class month_weekday;
416
417constexpr bool operator==(const month_weekday& x, const month_weekday& y) noexcept;
418constexpr bool operator!=(const month_weekday& x, const month_weekday& y) noexcept;
419
420// 25.8.12, class month_weekday_last // C++20
421class month_weekday_last;
422
423constexpr bool operator==(const month_weekday_last& x, const month_weekday_last& y) noexcept;
424constexpr bool operator!=(const month_weekday_last& x, const month_weekday_last& y) noexcept;
425
426
427// 25.8.13, class year_month // C++20
428class year_month;
429
430constexpr bool operator==(const year_month& x, const year_month& y) noexcept;
431constexpr bool operator!=(const year_month& x, const year_month& y) noexcept;
432constexpr bool operator< (const year_month& x, const year_month& y) noexcept;
433constexpr bool operator> (const year_month& x, const year_month& y) noexcept;
434constexpr bool operator<=(const year_month& x, const year_month& y) noexcept;
435constexpr bool operator>=(const year_month& x, const year_month& y) noexcept;
436
437constexpr year_month operator+(const year_month& ym, const months& dm) noexcept;
438constexpr year_month operator+(const months& dm, const year_month& ym) noexcept;
439constexpr year_month operator-(const year_month& ym, const months& dm) noexcept;
440constexpr months operator-(const year_month& x, const year_month& y) noexcept;
441constexpr year_month operator+(const year_month& ym, const years& dy) noexcept;
442constexpr year_month operator+(const years& dy, const year_month& ym) noexcept;
443constexpr year_month operator-(const year_month& ym, const years& dy) noexcept;
444
445// 25.8.14, class year_month_day class // C++20
446year_month_day;
447
448constexpr bool operator==(const year_month_day& x, const year_month_day& y) noexcept;
449constexpr bool operator!=(const year_month_day& x, const year_month_day& y) noexcept;
450constexpr bool operator< (const year_month_day& x, const year_month_day& y) noexcept;
451constexpr bool operator> (const year_month_day& x, const year_month_day& y) noexcept;
452constexpr bool operator<=(const year_month_day& x, const year_month_day& y) noexcept;
453constexpr bool operator>=(const year_month_day& x, const year_month_day& y) noexcept;
454
455constexpr year_month_day operator+(const year_month_day& ymd, const months& dm) noexcept;
456constexpr year_month_day operator+(const months& dm, const year_month_day& ymd) noexcept;
457constexpr year_month_day operator+(const year_month_day& ymd, const years& dy) noexcept;
458constexpr year_month_day operator+(const years& dy, const year_month_day& ymd) noexcept;
459constexpr year_month_day operator-(const year_month_day& ymd, const months& dm) noexcept;
460constexpr year_month_day operator-(const year_month_day& ymd, const years& dy) noexcept;
461
462
463// 25.8.15, class year_month_day_last // C++20
464class year_month_day_last;
465
466constexpr bool operator==(const year_month_day_last& x,
467 const year_month_day_last& y) noexcept;
468constexpr bool operator!=(const year_month_day_last& x,
469 const year_month_day_last& y) noexcept;
470constexpr bool operator< (const year_month_day_last& x,
471 const year_month_day_last& y) noexcept;
472constexpr bool operator> (const year_month_day_last& x,
473 const year_month_day_last& y) noexcept;
474constexpr bool operator<=(const year_month_day_last& x,
475 const year_month_day_last& y) noexcept;
476constexpr bool operator>=(const year_month_day_last& x,
477 const year_month_day_last& y) noexcept;
478
479constexpr year_month_day_last
480 operator+(const year_month_day_last& ymdl, const months& dm) noexcept;
481constexpr year_month_day_last
482 operator+(const months& dm, const year_month_day_last& ymdl) noexcept;
483constexpr year_month_day_last
484 operator+(const year_month_day_last& ymdl, const years& dy) noexcept;
485constexpr year_month_day_last
486 operator+(const years& dy, const year_month_day_last& ymdl) noexcept;
487constexpr year_month_day_last
488 operator-(const year_month_day_last& ymdl, const months& dm) noexcept;
489constexpr year_month_day_last
490 operator-(const year_month_day_last& ymdl, const years& dy) noexcept;
491
492// 25.8.16, class year_month_weekday // C++20
493class year_month_weekday;
494
495constexpr bool operator==(const year_month_weekday& x,
496 const year_month_weekday& y) noexcept;
497constexpr bool operator!=(const year_month_weekday& x,
498 const year_month_weekday& y) noexcept;
499
500constexpr year_month_weekday
501 operator+(const year_month_weekday& ymwd, const months& dm) noexcept;
502constexpr year_month_weekday
503 operator+(const months& dm, const year_month_weekday& ymwd) noexcept;
504constexpr year_month_weekday
505 operator+(const year_month_weekday& ymwd, const years& dy) noexcept;
506constexpr year_month_weekday
507 operator+(const years& dy, const year_month_weekday& ymwd) noexcept;
508constexpr year_month_weekday
509 operator-(const year_month_weekday& ymwd, const months& dm) noexcept;
510constexpr year_month_weekday
511 operator-(const year_month_weekday& ymwd, const years& dy) noexcept;
512
513// 25.8.17, class year_month_weekday_last // C++20
514class year_month_weekday_last;
515
516constexpr bool operator==(const year_month_weekday_last& x,
517 const year_month_weekday_last& y) noexcept;
518constexpr bool operator!=(const year_month_weekday_last& x,
519 const year_month_weekday_last& y) noexcept;
520constexpr year_month_weekday_last
521 operator+(const year_month_weekday_last& ymwdl, const months& dm) noexcept;
522constexpr year_month_weekday_last
523 operator+(const months& dm, const year_month_weekday_last& ymwdl) noexcept;
524constexpr year_month_weekday_last
525 operator+(const year_month_weekday_last& ymwdl, const years& dy) noexcept;
526constexpr year_month_weekday_last
527 operator+(const years& dy, const year_month_weekday_last& ymwdl) noexcept;
528constexpr year_month_weekday_last
529 operator-(const year_month_weekday_last& ymwdl, const months& dm) noexcept;
530constexpr year_month_weekday_last
531 operator-(const year_month_weekday_last& ymwdl, const years& dy) noexcept;
Louis Dionne44bcff92018-08-03 22:36:53 +0000532
Marshall Clow40ca0c12018-07-18 17:37:51 +0000533// 25.8.18, civil calendar conventional syntax operators // C++20
534constexpr year_month
535 operator/(const year& y, const month& m) noexcept;
536constexpr year_month
537 operator/(const year& y, int m) noexcept;
538constexpr month_day
539 operator/(const month& m, const day& d) noexcept;
540constexpr month_day
541 operator/(const month& m, int d) noexcept;
542constexpr month_day
543 operator/(int m, const day& d) noexcept;
544constexpr month_day
545 operator/(const day& d, const month& m) noexcept;
546constexpr month_day
547 operator/(const day& d, int m) noexcept;
548constexpr month_day_last
549 operator/(const month& m, last_spec) noexcept;
550constexpr month_day_last
551 operator/(int m, last_spec) noexcept;
552constexpr month_day_last
553 operator/(last_spec, const month& m) noexcept;
554constexpr month_day_last
555 operator/(last_spec, int m) noexcept;
556constexpr month_weekday
557 operator/(const month& m, const weekday_indexed& wdi) noexcept;
558constexpr month_weekday
559 operator/(int m, const weekday_indexed& wdi) noexcept;
560constexpr month_weekday
561 operator/(const weekday_indexed& wdi, const month& m) noexcept;
562constexpr month_weekday
563 operator/(const weekday_indexed& wdi, int m) noexcept;
564constexpr month_weekday_last
565 operator/(const month& m, const weekday_last& wdl) noexcept;
566constexpr month_weekday_last
567 operator/(int m, const weekday_last& wdl) noexcept;
568constexpr month_weekday_last
569 operator/(const weekday_last& wdl, const month& m) noexcept;
570constexpr month_weekday_last
571 operator/(const weekday_last& wdl, int m) noexcept;
572constexpr year_month_day
573 operator/(const year_month& ym, const day& d) noexcept;
574constexpr year_month_day
575 operator/(const year_month& ym, int d) noexcept;
576constexpr year_month_day
577 operator/(const year& y, const month_day& md) noexcept;
578constexpr year_month_day
579 operator/(int y, const month_day& md) noexcept;
580constexpr year_month_day
581 operator/(const month_day& md, const year& y) noexcept;
582constexpr year_month_day
583 operator/(const month_day& md, int y) noexcept;
584constexpr year_month_day_last
585 operator/(const year_month& ym, last_spec) noexcept;
586constexpr year_month_day_last
587 operator/(const year& y, const month_day_last& mdl) noexcept;
588constexpr year_month_day_last
589 operator/(int y, const month_day_last& mdl) noexcept;
590constexpr year_month_day_last
591 operator/(const month_day_last& mdl, const year& y) noexcept;
592constexpr year_month_day_last
593 operator/(const month_day_last& mdl, int y) noexcept;
594constexpr year_month_weekday
595 operator/(const year_month& ym, const weekday_indexed& wdi) noexcept;
596constexpr year_month_weekday
597 operator/(const year& y, const month_weekday& mwd) noexcept;
598constexpr year_month_weekday
599 operator/(int y, const month_weekday& mwd) noexcept;
600constexpr year_month_weekday
601 operator/(const month_weekday& mwd, const year& y) noexcept;
602constexpr year_month_weekday
603 operator/(const month_weekday& mwd, int y) noexcept;
604constexpr year_month_weekday_last
605 operator/(const year_month& ym, const weekday_last& wdl) noexcept;
606constexpr year_month_weekday_last
607 operator/(const year& y, const month_weekday_last& mwdl) noexcept;
608constexpr year_month_weekday_last
609 operator/(int y, const month_weekday_last& mwdl) noexcept;
610constexpr year_month_weekday_last
611 operator/(const month_weekday_last& mwdl, const year& y) noexcept;
612constexpr year_month_weekday_last
Louis Dionne44bcff92018-08-03 22:36:53 +0000613 operator/(const month_weekday_last& mwdl, int y) noexcept;
Marshall Clow40ca0c12018-07-18 17:37:51 +0000614
615// 25.9, class template time_of_day // C++20
616template<class Duration> class time_of_day;
617
618template<> class time_of_day<hours>;
619template<> class time_of_day<minutes>;
620template<> class time_of_day<seconds>;
621template<class Rep, class Period> class time_of_day<duration<Rep, Period>>;
622
623// 25.10.2, time zone database // C++20
624struct tzdb;
625class tzdb_list;
626
627// 25.10.2.3, time zone database access // C++20
628const tzdb& get_tzdb();
629tzdb_list& get_tzdb_list();
630const time_zone* locate_zone(string_view tz_name);
631const time_zone* current_zone();
632
633// 25.10.2.4, remote time zone database support // C++20
634const tzdb& reload_tzdb();
635string remote_version();
636
637// 25.10.3, exception classes // C++20
638class nonexistent_local_time;
639class ambiguous_local_time;
640
641// 25.10.4, information classes // C++20
642struct sys_info;
643struct local_info;
Louis Dionne44bcff92018-08-03 22:36:53 +0000644
Marshall Clow40ca0c12018-07-18 17:37:51 +0000645// 25.10.5, class time_zone // C++20
646enum class choose {earliest, latest};
647class time_zone;
648bool operator==(const time_zone& x, const time_zone& y) noexcept;
649bool operator!=(const time_zone& x, const time_zone& y) noexcept;
650bool operator<(const time_zone& x, const time_zone& y) noexcept;
651bool operator>(const time_zone& x, const time_zone& y) noexcept;
652bool operator<=(const time_zone& x, const time_zone& y) noexcept;
653bool operator>=(const time_zone& x, const time_zone& y) noexcept;
Louis Dionne44bcff92018-08-03 22:36:53 +0000654
Marshall Clow40ca0c12018-07-18 17:37:51 +0000655// 25.10.6, class template zoned_traits // C++20
656template<class T> struct zoned_traits;
657
658// 25.10.7, class template zoned_time // C++20
659template<class Duration, class TimeZonePtr = const time_zone*> class zoned_time;
660using zoned_seconds = zoned_time<seconds>;
661
662template<class Duration1, class Duration2, class TimeZonePtr>
663 bool operator==(const zoned_time<Duration1, TimeZonePtr>& x,
664 const zoned_time<Duration2, TimeZonePtr>& y);
665template<class Duration1, class Duration2, class TimeZonePtr>
666 bool operator!=(const zoned_time<Duration1, TimeZonePtr>& x,
667 const zoned_time<Duration2, TimeZonePtr>& y);
668
669// 25.10.8, leap second support // C++20
670class leap;
671
672bool operator==(const leap& x, const leap& y);
673bool operator!=(const leap& x, const leap& y);
674bool operator< (const leap& x, const leap& y);
675bool operator> (const leap& x, const leap& y);
676bool operator<=(const leap& x, const leap& y);
677bool operator>=(const leap& x, const leap& y);
678template<class Duration>
679 bool operator==(const leap& x, const sys_time<Duration>& y);
680template<class Duration>
681 bool operator==(const sys_time<Duration>& x, const leap& y);
682template<class Duration>
683 bool operator!=(const leap& x, const sys_time<Duration>& y);
684template<class Duration>
685 bool operator!=(const sys_time<Duration>& x, const leap& y);
686template<class Duration>
687 bool operator< (const leap& x, const sys_time<Duration>& y);
688template<class Duration>
689 bool operator< (const sys_time<Duration>& x, const leap& y);
690template<class Duration>
691 bool operator> (const leap& x, const sys_time<Duration>& y);
692template<class Duration>
693 bool operator> (const sys_time<Duration>& x, const leap& y);
694template<class Duration>
695 bool operator<=(const leap& x, const sys_time<Duration>& y);
696template<class Duration>
697 bool operator<=(const sys_time<Duration>& x, const leap& y);
698template<class Duration>
699 bool operator>=(const leap& x, const sys_time<Duration>& y);
700template<class Duration>
701 bool operator>=(const sys_time<Duration>& x, const leap& y);
702
703// 25.10.9, class link // C++20
704class link;
705bool operator==(const link& x, const link& y);
706bool operator!=(const link& x, const link& y);
707bool operator< (const link& x, const link& y);
708bool operator> (const link& x, const link& y);
709bool operator<=(const link& x, const link& y);
710bool operator>=(const link& x, const link& y);
711
712// 25.11, formatting // C++20
713template<class charT, class Streamable>
714 basic_string<charT>
715 format(const charT* fmt, const Streamable& s);
716
717template<class charT, class Streamable>
718 basic_string<charT>
719 format(const locale& loc, const charT* fmt, const Streamable& s);
720
721template<class charT, class traits, class Alloc, class Streamable>
722 basic_string<charT, traits, Alloc>
723 format(const basic_string<charT, traits, Alloc>& fmt, const Streamable& s);
724
725template<class charT, class traits, class Alloc, class Streamable>
726 basic_string<charT, traits, Alloc>
727 format(const locale& loc, const basic_string<charT, traits, Alloc>& fmt,
Louis Dionne44bcff92018-08-03 22:36:53 +0000728 const Streamable& s);
Marshall Clow40ca0c12018-07-18 17:37:51 +0000729
730// 25.12, parsing // C++20
731template<class charT, class traits, class Alloc, class Parsable>
732unspecified
733 parse(const basic_string<charT, traits, Alloc>& format, Parsable& tp);
734
735template<class charT, class traits, class Alloc, class Parsable>
736unspecified
737 parse(const basic_string<charT, traits, Alloc>& format, Parsable& tp,
738 basic_string<charT, traits, Alloc>& abbrev);
739
740template<class charT, class traits, class Alloc, class Parsable>
741unspecified
742 parse(const basic_string<charT, traits, Alloc>& format, Parsable& tp,
743 minutes& offset);
744
745template<class charT, class traits, class Alloc, class Parsable>
746unspecified
747 parse(const basic_string<charT, traits, Alloc>& format, Parsable& tp,
748 basic_string<charT, traits, Alloc>& abbrev, minutes& offset);
749
Marshall Clow26058352018-10-16 17:27:54 +0000750// calendrical constants
Louis Dionne44bcff92018-08-03 22:36:53 +0000751inline constexpr last_spec last{}; // C++20
Marshall Clow40ca0c12018-07-18 17:37:51 +0000752inline constexpr chrono::weekday Sunday{0}; // C++20
753inline constexpr chrono::weekday Monday{1}; // C++20
754inline constexpr chrono::weekday Tuesday{2}; // C++20
755inline constexpr chrono::weekday Wednesday{3}; // C++20
756inline constexpr chrono::weekday Thursday{4}; // C++20
757inline constexpr chrono::weekday Friday{5}; // C++20
758inline constexpr chrono::weekday Saturday{6}; // C++20
759
760inline constexpr chrono::month January{1}; // C++20
761inline constexpr chrono::month February{2}; // C++20
762inline constexpr chrono::month March{3}; // C++20
763inline constexpr chrono::month April{4}; // C++20
764inline constexpr chrono::month May{5}; // C++20
765inline constexpr chrono::month June{6}; // C++20
766inline constexpr chrono::month July{7}; // C++20
767inline constexpr chrono::month August{8}; // C++20
768inline constexpr chrono::month September{9}; // C++20
769inline constexpr chrono::month October{10}; // C++20
770inline constexpr chrono::month November{11}; // C++20
771inline constexpr chrono::month December{12}; // C++20
Howard Hinnantc51e1022010-05-11 19:42:16 +0000772} // chrono
773
Marshall Clow40ca0c12018-07-18 17:37:51 +0000774inline namespace literals {
775 inline namespace chrono_literals {
Marshall Clow2ac805a2017-08-09 15:42:50 +0000776constexpr chrono::hours operator ""h(unsigned long long); // C++14
777constexpr chrono::duration<unspecified , ratio<3600,1>> operator ""h(long double); // C++14
778constexpr chrono::minutes operator ""min(unsigned long long); // C++14
779constexpr chrono::duration<unspecified , ratio<60,1>> operator ""min(long double); // C++14
780constexpr chrono::seconds operator ""s(unsigned long long); // C++14
781constexpr chrono::duration<unspecified > operator ""s(long double); // C++14
782constexpr chrono::milliseconds operator ""ms(unsigned long long); // C++14
783constexpr chrono::duration<unspecified , milli> operator ""ms(long double); // C++14
784constexpr chrono::microseconds operator ""us(unsigned long long); // C++14
785constexpr chrono::duration<unspecified , micro> operator ""us(long double); // C++14
786constexpr chrono::nanoseconds operator ""ns(unsigned long long); // C++14
787constexpr chrono::duration<unspecified , nano> operator ""ns(long double); // C++14
Marshall Clow40ca0c12018-07-18 17:37:51 +0000788constexpr chrono::day operator ""d(unsigned long long d) noexcept; // C++20
789constexpr chrono::year operator ""y(unsigned long long y) noexcept; // C++20
790} // chrono_literals
791} // literals
Marshall Cloweb41e5c2013-07-24 21:18:14 +0000792
Howard Hinnantc51e1022010-05-11 19:42:16 +0000793} // std
794*/
795
796#include <__config>
797#include <ctime>
798#include <type_traits>
799#include <ratio>
800#include <limits>
Marshall Clow0a1e7502018-09-12 19:41:40 +0000801#include <version>
Howard Hinnantc51e1022010-05-11 19:42:16 +0000802
Howard Hinnantaaaa52b2011-10-17 20:05:10 +0000803#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
Howard Hinnantc51e1022010-05-11 19:42:16 +0000804#pragma GCC system_header
Howard Hinnantaaaa52b2011-10-17 20:05:10 +0000805#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +0000806
Eric Fiselierf4433a32017-05-31 22:07:49 +0000807_LIBCPP_PUSH_MACROS
808#include <__undef_macros>
809
Eric Fiselier4dcc2542018-12-21 04:30:04 +0000810#ifndef _LIBCPP_CXX03_LANG
Eric Fiselier049273c2018-12-21 03:54:57 +0000811_LIBCPP_BEGIN_NAMESPACE_FILESYSTEM
812struct _FilesystemClock;
813_LIBCPP_END_NAMESPACE_FILESYSTEM
Eric Fiselier4dcc2542018-12-21 04:30:04 +0000814#endif // !_LIBCPP_CXX03_LANG
Eric Fiselierf4433a32017-05-31 22:07:49 +0000815
Howard Hinnantc51e1022010-05-11 19:42:16 +0000816_LIBCPP_BEGIN_NAMESPACE_STD
817
818namespace chrono
819{
820
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +0000821template <class _Rep, class _Period = ratio<1> > class _LIBCPP_TEMPLATE_VIS duration;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000822
Howard Hinnantf39463b2010-05-18 17:32:30 +0000823template <class _Tp>
Howard Hinnantc51e1022010-05-11 19:42:16 +0000824struct __is_duration : false_type {};
825
826template <class _Rep, class _Period>
827struct __is_duration<duration<_Rep, _Period> > : true_type {};
828
829template <class _Rep, class _Period>
830struct __is_duration<const duration<_Rep, _Period> > : true_type {};
831
832template <class _Rep, class _Period>
833struct __is_duration<volatile duration<_Rep, _Period> > : true_type {};
834
835template <class _Rep, class _Period>
836struct __is_duration<const volatile duration<_Rep, _Period> > : true_type {};
837
838} // chrono
839
840template <class _Rep1, class _Period1, class _Rep2, class _Period2>
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +0000841struct _LIBCPP_TEMPLATE_VIS common_type<chrono::duration<_Rep1, _Period1>,
Howard Hinnanta37d3cf2013-08-12 18:38:34 +0000842 chrono::duration<_Rep2, _Period2> >
Howard Hinnantc51e1022010-05-11 19:42:16 +0000843{
844 typedef chrono::duration<typename common_type<_Rep1, _Rep2>::type,
845 typename __ratio_gcd<_Period1, _Period2>::type> type;
846};
847
848namespace chrono {
849
850// duration_cast
851
852template <class _FromDuration, class _ToDuration,
853 class _Period = typename ratio_divide<typename _FromDuration::period, typename _ToDuration::period>::type,
854 bool = _Period::num == 1,
855 bool = _Period::den == 1>
856struct __duration_cast;
857
858template <class _FromDuration, class _ToDuration, class _Period>
859struct __duration_cast<_FromDuration, _ToDuration, _Period, true, true>
860{
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000861 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +0000862 _ToDuration operator()(const _FromDuration& __fd) const
863 {
864 return _ToDuration(static_cast<typename _ToDuration::rep>(__fd.count()));
865 }
866};
867
868template <class _FromDuration, class _ToDuration, class _Period>
869struct __duration_cast<_FromDuration, _ToDuration, _Period, true, false>
870{
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000871 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +0000872 _ToDuration operator()(const _FromDuration& __fd) const
873 {
874 typedef typename common_type<typename _ToDuration::rep, typename _FromDuration::rep, intmax_t>::type _Ct;
875 return _ToDuration(static_cast<typename _ToDuration::rep>(
876 static_cast<_Ct>(__fd.count()) / static_cast<_Ct>(_Period::den)));
877 }
878};
879
880template <class _FromDuration, class _ToDuration, class _Period>
881struct __duration_cast<_FromDuration, _ToDuration, _Period, false, true>
882{
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000883 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +0000884 _ToDuration operator()(const _FromDuration& __fd) const
885 {
886 typedef typename common_type<typename _ToDuration::rep, typename _FromDuration::rep, intmax_t>::type _Ct;
887 return _ToDuration(static_cast<typename _ToDuration::rep>(
888 static_cast<_Ct>(__fd.count()) * static_cast<_Ct>(_Period::num)));
889 }
890};
891
892template <class _FromDuration, class _ToDuration, class _Period>
893struct __duration_cast<_FromDuration, _ToDuration, _Period, false, false>
894{
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000895 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +0000896 _ToDuration operator()(const _FromDuration& __fd) const
897 {
898 typedef typename common_type<typename _ToDuration::rep, typename _FromDuration::rep, intmax_t>::type _Ct;
899 return _ToDuration(static_cast<typename _ToDuration::rep>(
900 static_cast<_Ct>(__fd.count()) * static_cast<_Ct>(_Period::num)
901 / static_cast<_Ct>(_Period::den)));
902 }
903};
904
905template <class _ToDuration, class _Rep, class _Period>
906inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +0000907_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +0000908typename enable_if
909<
910 __is_duration<_ToDuration>::value,
911 _ToDuration
912>::type
913duration_cast(const duration<_Rep, _Period>& __fd)
914{
915 return __duration_cast<duration<_Rep, _Period>, _ToDuration>()(__fd);
916}
917
Howard Hinnant874ad9a2010-09-21 21:28:23 +0000918template <class _Rep>
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +0000919struct _LIBCPP_TEMPLATE_VIS treat_as_floating_point : is_floating_point<_Rep> {};
Howard Hinnantc51e1022010-05-11 19:42:16 +0000920
Marshall Clow59581f02015-11-30 05:39:30 +0000921#if _LIBCPP_STD_VER > 14 && !defined(_LIBCPP_HAS_NO_VARIABLE_TEMPLATES)
Marshall Clowf1bf62f2018-01-02 17:17:01 +0000922template <class _Rep>
923_LIBCPP_INLINE_VAR _LIBCPP_CONSTEXPR bool treat_as_floating_point_v
Marshall Clow59581f02015-11-30 05:39:30 +0000924 = treat_as_floating_point<_Rep>::value;
925#endif
926
Howard Hinnantc51e1022010-05-11 19:42:16 +0000927template <class _Rep>
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +0000928struct _LIBCPP_TEMPLATE_VIS duration_values
Howard Hinnantc51e1022010-05-11 19:42:16 +0000929{
930public:
Marshall Clowb1296bd2018-11-13 17:22:41 +0000931 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR _Rep zero() _NOEXCEPT {return _Rep(0);}
932 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR _Rep max() _NOEXCEPT {return numeric_limits<_Rep>::max();}
933 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR _Rep min() _NOEXCEPT {return numeric_limits<_Rep>::lowest();}
Howard Hinnantc51e1022010-05-11 19:42:16 +0000934};
935
Marshall Clowf2eabaf2015-11-05 19:33:59 +0000936#if _LIBCPP_STD_VER > 14
937template <class _ToDuration, class _Rep, class _Period>
938inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
939typename enable_if
940<
941 __is_duration<_ToDuration>::value,
942 _ToDuration
943>::type
944floor(const duration<_Rep, _Period>& __d)
945{
946 _ToDuration __t = duration_cast<_ToDuration>(__d);
947 if (__t > __d)
948 __t = __t - _ToDuration{1};
949 return __t;
950}
951
952template <class _ToDuration, class _Rep, class _Period>
953inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
954typename enable_if
955<
956 __is_duration<_ToDuration>::value,
957 _ToDuration
958>::type
959ceil(const duration<_Rep, _Period>& __d)
960{
961 _ToDuration __t = duration_cast<_ToDuration>(__d);
962 if (__t < __d)
963 __t = __t + _ToDuration{1};
964 return __t;
965}
966
967template <class _ToDuration, class _Rep, class _Period>
968inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
969typename enable_if
970<
971 __is_duration<_ToDuration>::value,
972 _ToDuration
973>::type
974round(const duration<_Rep, _Period>& __d)
975{
976 _ToDuration __lower = floor<_ToDuration>(__d);
977 _ToDuration __upper = __lower + _ToDuration{1};
978 auto __lowerDiff = __d - __lower;
979 auto __upperDiff = __upper - __d;
980 if (__lowerDiff < __upperDiff)
981 return __lower;
982 if (__lowerDiff > __upperDiff)
983 return __upper;
984 return __lower.count() & 1 ? __upper : __lower;
985}
986#endif
987
Howard Hinnantc51e1022010-05-11 19:42:16 +0000988// duration
989
990template <class _Rep, class _Period>
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +0000991class _LIBCPP_TEMPLATE_VIS duration
Howard Hinnantc51e1022010-05-11 19:42:16 +0000992{
993 static_assert(!__is_duration<_Rep>::value, "A duration representation can not be a duration");
994 static_assert(__is_ratio<_Period>::value, "Second template parameter of duration must be a std::ratio");
995 static_assert(_Period::num > 0, "duration period must be positive");
Howard Hinnant0a51e152013-08-31 16:51:56 +0000996
997 template <class _R1, class _R2>
998 struct __no_overflow
999 {
1000 private:
1001 static const intmax_t __gcd_n1_n2 = __static_gcd<_R1::num, _R2::num>::value;
1002 static const intmax_t __gcd_d1_d2 = __static_gcd<_R1::den, _R2::den>::value;
1003 static const intmax_t __n1 = _R1::num / __gcd_n1_n2;
1004 static const intmax_t __d1 = _R1::den / __gcd_d1_d2;
1005 static const intmax_t __n2 = _R2::num / __gcd_n1_n2;
1006 static const intmax_t __d2 = _R2::den / __gcd_d1_d2;
1007 static const intmax_t max = -((intmax_t(1) << (sizeof(intmax_t) * CHAR_BIT - 1)) + 1);
1008
1009 template <intmax_t _Xp, intmax_t _Yp, bool __overflow>
1010 struct __mul // __overflow == false
1011 {
1012 static const intmax_t value = _Xp * _Yp;
1013 };
1014
1015 template <intmax_t _Xp, intmax_t _Yp>
1016 struct __mul<_Xp, _Yp, true>
1017 {
1018 static const intmax_t value = 1;
1019 };
1020
1021 public:
1022 static const bool value = (__n1 <= max / __d2) && (__n2 <= max / __d1);
1023 typedef ratio<__mul<__n1, __d2, !value>::value,
1024 __mul<__n2, __d1, !value>::value> type;
1025 };
Louis Dionne44bcff92018-08-03 22:36:53 +00001026
Howard Hinnantc51e1022010-05-11 19:42:16 +00001027public:
1028 typedef _Rep rep;
Marshall Clow76200b22017-03-21 18:38:57 +00001029 typedef typename _Period::type period;
Howard Hinnantc51e1022010-05-11 19:42:16 +00001030private:
1031 rep __rep_;
1032public:
1033
Marshall Clow5c459c92013-07-31 19:32:19 +00001034 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Eric Fiselier07b2b552016-11-18 06:42:17 +00001035#ifndef _LIBCPP_CXX03_LANG
Marshall Clow5c459c92013-07-31 19:32:19 +00001036 duration() = default;
Marshall Clow3dbcf132013-07-31 19:39:37 +00001037#else
1038 duration() {}
Marshall Clow5c459c92013-07-31 19:32:19 +00001039#endif
1040
Howard Hinnantc51e1022010-05-11 19:42:16 +00001041 template <class _Rep2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001042 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001043 explicit duration(const _Rep2& __r,
1044 typename enable_if
1045 <
1046 is_convertible<_Rep2, rep>::value &&
1047 (treat_as_floating_point<rep>::value ||
1048 !treat_as_floating_point<_Rep2>::value)
1049 >::type* = 0)
1050 : __rep_(__r) {}
1051
1052 // conversions
1053 template <class _Rep2, class _Period2>
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001054 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001055 duration(const duration<_Rep2, _Period2>& __d,
1056 typename enable_if
1057 <
Howard Hinnant0a51e152013-08-31 16:51:56 +00001058 __no_overflow<_Period2, period>::value && (
Howard Hinnantc51e1022010-05-11 19:42:16 +00001059 treat_as_floating_point<rep>::value ||
Howard Hinnant0a51e152013-08-31 16:51:56 +00001060 (__no_overflow<_Period2, period>::type::den == 1 &&
1061 !treat_as_floating_point<_Rep2>::value))
Howard Hinnantc51e1022010-05-11 19:42:16 +00001062 >::type* = 0)
Howard Hinnantb1ad5a82011-06-30 21:18:19 +00001063 : __rep_(_VSTD::chrono::duration_cast<duration>(__d).count()) {}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001064
1065 // observer
1066
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001067 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR rep count() const {return __rep_;}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001068
1069 // arithmetic
1070
Marshall Clow76200b22017-03-21 18:38:57 +00001071 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR typename common_type<duration>::type operator+() const {return typename common_type<duration>::type(*this);}
1072 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR typename common_type<duration>::type operator-() const {return typename common_type<duration>::type(-__rep_);}
Marshall Clow5c87ad02017-01-04 23:03:24 +00001073 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator++() {++__rep_; return *this;}
1074 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration operator++(int) {return duration(__rep_++);}
1075 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator--() {--__rep_; return *this;}
1076 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration operator--(int) {return duration(__rep_--);}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001077
Marshall Clow5c87ad02017-01-04 23:03:24 +00001078 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator+=(const duration& __d) {__rep_ += __d.count(); return *this;}
1079 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator-=(const duration& __d) {__rep_ -= __d.count(); return *this;}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001080
Marshall Clow5c87ad02017-01-04 23:03:24 +00001081 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator*=(const rep& rhs) {__rep_ *= rhs; return *this;}
1082 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator/=(const rep& rhs) {__rep_ /= rhs; return *this;}
1083 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator%=(const rep& rhs) {__rep_ %= rhs; return *this;}
1084 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 duration& operator%=(const duration& rhs) {__rep_ %= rhs.count(); return *this;}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001085
1086 // special values
1087
Marshall Clowb1296bd2018-11-13 17:22:41 +00001088 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR duration zero() _NOEXCEPT {return duration(duration_values<rep>::zero());}
1089 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR duration min() _NOEXCEPT {return duration(duration_values<rep>::min());}
1090 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR duration max() _NOEXCEPT {return duration(duration_values<rep>::max());}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001091};
1092
1093typedef duration<long long, nano> nanoseconds;
1094typedef duration<long long, micro> microseconds;
1095typedef duration<long long, milli> milliseconds;
1096typedef duration<long long > seconds;
1097typedef duration< long, ratio< 60> > minutes;
1098typedef duration< long, ratio<3600> > hours;
Marshall Clow26058352018-10-16 17:27:54 +00001099#if _LIBCPP_STD_VER > 17
1100typedef duration< int, ratio_multiply<ratio<24>, hours::period>> days;
1101typedef duration< int, ratio_multiply<ratio<7>, days::period>> weeks;
1102typedef duration< int, ratio_multiply<ratio<146097, 400>, days::period>> years;
1103typedef duration< int, ratio_divide<years::period, ratio<12>>> months;
1104#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +00001105// Duration ==
1106
1107template <class _LhsDuration, class _RhsDuration>
1108struct __duration_eq
1109{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001110 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnant12967fb2013-06-28 18:09:35 +00001111 bool operator()(const _LhsDuration& __lhs, const _RhsDuration& __rhs) const
Howard Hinnantc51e1022010-05-11 19:42:16 +00001112 {
1113 typedef typename common_type<_LhsDuration, _RhsDuration>::type _Ct;
1114 return _Ct(__lhs).count() == _Ct(__rhs).count();
1115 }
1116};
1117
1118template <class _LhsDuration>
1119struct __duration_eq<_LhsDuration, _LhsDuration>
1120{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001121 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnant12967fb2013-06-28 18:09:35 +00001122 bool operator()(const _LhsDuration& __lhs, const _LhsDuration& __rhs) const
Howard Hinnantc51e1022010-05-11 19:42:16 +00001123 {return __lhs.count() == __rhs.count();}
1124};
1125
1126template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1127inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001128_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001129bool
1130operator==(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1131{
1132 return __duration_eq<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >()(__lhs, __rhs);
1133}
1134
1135// Duration !=
1136
1137template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1138inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001139_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001140bool
1141operator!=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1142{
1143 return !(__lhs == __rhs);
1144}
1145
1146// Duration <
1147
1148template <class _LhsDuration, class _RhsDuration>
1149struct __duration_lt
1150{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001151 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnant12967fb2013-06-28 18:09:35 +00001152 bool operator()(const _LhsDuration& __lhs, const _RhsDuration& __rhs) const
Howard Hinnantc51e1022010-05-11 19:42:16 +00001153 {
1154 typedef typename common_type<_LhsDuration, _RhsDuration>::type _Ct;
1155 return _Ct(__lhs).count() < _Ct(__rhs).count();
1156 }
1157};
1158
1159template <class _LhsDuration>
1160struct __duration_lt<_LhsDuration, _LhsDuration>
1161{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001162 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
Howard Hinnant12967fb2013-06-28 18:09:35 +00001163 bool operator()(const _LhsDuration& __lhs, const _LhsDuration& __rhs) const
Howard Hinnantc51e1022010-05-11 19:42:16 +00001164 {return __lhs.count() < __rhs.count();}
1165};
1166
1167template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1168inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001169_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001170bool
1171operator< (const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1172{
1173 return __duration_lt<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >()(__lhs, __rhs);
1174}
1175
1176// Duration >
1177
1178template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1179inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001180_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001181bool
1182operator> (const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1183{
1184 return __rhs < __lhs;
1185}
1186
1187// Duration <=
1188
1189template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1190inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001191_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001192bool
1193operator<=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1194{
1195 return !(__rhs < __lhs);
1196}
1197
1198// Duration >=
1199
1200template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1201inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001202_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001203bool
1204operator>=(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1205{
1206 return !(__lhs < __rhs);
1207}
1208
1209// Duration +
1210
1211template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1212inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001213_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001214typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type
1215operator+(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1216{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001217 typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Cd;
1218 return _Cd(_Cd(__lhs).count() + _Cd(__rhs).count());
Howard Hinnantc51e1022010-05-11 19:42:16 +00001219}
1220
1221// Duration -
1222
1223template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1224inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001225_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001226typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type
1227operator-(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1228{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001229 typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Cd;
1230 return _Cd(_Cd(__lhs).count() - _Cd(__rhs).count());
Howard Hinnantc51e1022010-05-11 19:42:16 +00001231}
1232
1233// Duration *
1234
1235template <class _Rep1, class _Period, class _Rep2>
1236inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001237_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001238typename enable_if
1239<
1240 is_convertible<_Rep2, typename common_type<_Rep1, _Rep2>::type>::value,
1241 duration<typename common_type<_Rep1, _Rep2>::type, _Period>
1242>::type
1243operator*(const duration<_Rep1, _Period>& __d, const _Rep2& __s)
1244{
1245 typedef typename common_type<_Rep1, _Rep2>::type _Cr;
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001246 typedef duration<_Cr, _Period> _Cd;
1247 return _Cd(_Cd(__d).count() * static_cast<_Cr>(__s));
Howard Hinnantc51e1022010-05-11 19:42:16 +00001248}
1249
1250template <class _Rep1, class _Period, class _Rep2>
1251inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001252_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001253typename enable_if
1254<
1255 is_convertible<_Rep1, typename common_type<_Rep1, _Rep2>::type>::value,
1256 duration<typename common_type<_Rep1, _Rep2>::type, _Period>
1257>::type
1258operator*(const _Rep1& __s, const duration<_Rep2, _Period>& __d)
1259{
1260 return __d * __s;
1261}
1262
1263// Duration /
1264
Howard Hinnantc51e1022010-05-11 19:42:16 +00001265template <class _Rep1, class _Period, class _Rep2>
1266inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001267_LIBCPP_CONSTEXPR
Marshall Clowb8f3cd02019-04-01 16:38:02 +00001268typename enable_if
1269<
1270 !__is_duration<_Rep2>::value &&
1271 is_convertible<_Rep2, typename common_type<_Rep1, _Rep2>::type>::value,
1272 duration<typename common_type<_Rep1, _Rep2>::type, _Period>
1273>::type
Howard Hinnantc51e1022010-05-11 19:42:16 +00001274operator/(const duration<_Rep1, _Period>& __d, const _Rep2& __s)
1275{
1276 typedef typename common_type<_Rep1, _Rep2>::type _Cr;
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001277 typedef duration<_Cr, _Period> _Cd;
1278 return _Cd(_Cd(__d).count() / static_cast<_Cr>(__s));
Howard Hinnantc51e1022010-05-11 19:42:16 +00001279}
1280
1281template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1282inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001283_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001284typename common_type<_Rep1, _Rep2>::type
1285operator/(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1286{
1287 typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Ct;
1288 return _Ct(__lhs).count() / _Ct(__rhs).count();
1289}
1290
1291// Duration %
1292
1293template <class _Rep1, class _Period, class _Rep2>
1294inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001295_LIBCPP_CONSTEXPR
Marshall Clowb8f3cd02019-04-01 16:38:02 +00001296typename enable_if
1297<
1298 !__is_duration<_Rep2>::value &&
1299 is_convertible<_Rep2, typename common_type<_Rep1, _Rep2>::type>::value,
1300 duration<typename common_type<_Rep1, _Rep2>::type, _Period>
1301>::type
Howard Hinnantc51e1022010-05-11 19:42:16 +00001302operator%(const duration<_Rep1, _Period>& __d, const _Rep2& __s)
1303{
1304 typedef typename common_type<_Rep1, _Rep2>::type _Cr;
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001305 typedef duration<_Cr, _Period> _Cd;
1306 return _Cd(_Cd(__d).count() % static_cast<_Cr>(__s));
Howard Hinnantc51e1022010-05-11 19:42:16 +00001307}
1308
1309template <class _Rep1, class _Period1, class _Rep2, class _Period2>
1310inline _LIBCPP_INLINE_VISIBILITY
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001311_LIBCPP_CONSTEXPR
Howard Hinnantc51e1022010-05-11 19:42:16 +00001312typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type
1313operator%(const duration<_Rep1, _Period1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1314{
Howard Hinnantcf3143c2012-07-13 19:17:27 +00001315 typedef typename common_type<_Rep1, _Rep2>::type _Cr;
1316 typedef typename common_type<duration<_Rep1, _Period1>, duration<_Rep2, _Period2> >::type _Cd;
1317 return _Cd(static_cast<_Cr>(_Cd(__lhs).count()) % static_cast<_Cr>(_Cd(__rhs).count()));
Howard Hinnantc51e1022010-05-11 19:42:16 +00001318}
1319
1320//////////////////////////////////////////////////////////
1321///////////////////// time_point /////////////////////////
1322//////////////////////////////////////////////////////////
1323
1324template <class _Clock, class _Duration = typename _Clock::duration>
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +00001325class _LIBCPP_TEMPLATE_VIS time_point
Howard Hinnantc51e1022010-05-11 19:42:16 +00001326{
1327 static_assert(__is_duration<_Duration>::value,
1328 "Second template parameter of time_point must be a std::chrono::duration");
1329public:
1330 typedef _Clock clock;
1331 typedef _Duration duration;
1332 typedef typename duration::rep rep;
1333 typedef typename duration::period period;
1334private:
1335 duration __d_;
1336
1337public:
Marshall Clow5c459c92013-07-31 19:32:19 +00001338 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 time_point() : __d_(duration::zero()) {}
1339 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 explicit time_point(const duration& __d) : __d_(__d) {}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001340
1341 // conversions
1342 template <class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001343 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001344 time_point(const time_point<clock, _Duration2>& t,
1345 typename enable_if
1346 <
1347 is_convertible<_Duration2, duration>::value
1348 >::type* = 0)
1349 : __d_(t.time_since_epoch()) {}
1350
1351 // observer
1352
Marshall Clow5c459c92013-07-31 19:32:19 +00001353 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 duration time_since_epoch() const {return __d_;}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001354
1355 // arithmetic
1356
Marshall Clowdf247eb2018-08-29 23:02:15 +00001357 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 time_point& operator+=(const duration& __d) {__d_ += __d; return *this;}
1358 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 time_point& operator-=(const duration& __d) {__d_ -= __d; return *this;}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001359
1360 // special values
1361
Marshall Clowb1296bd2018-11-13 17:22:41 +00001362 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR time_point min() _NOEXCEPT {return time_point(duration::min());}
1363 _LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR time_point max() _NOEXCEPT {return time_point(duration::max());}
Howard Hinnantc51e1022010-05-11 19:42:16 +00001364};
1365
1366} // chrono
1367
1368template <class _Clock, class _Duration1, class _Duration2>
Eric Fiselierb5eb1bf2017-01-04 23:56:00 +00001369struct _LIBCPP_TEMPLATE_VIS common_type<chrono::time_point<_Clock, _Duration1>,
Howard Hinnanta37d3cf2013-08-12 18:38:34 +00001370 chrono::time_point<_Clock, _Duration2> >
Howard Hinnantc51e1022010-05-11 19:42:16 +00001371{
1372 typedef chrono::time_point<_Clock, typename common_type<_Duration1, _Duration2>::type> type;
1373};
1374
1375namespace chrono {
1376
1377template <class _ToDuration, class _Clock, class _Duration>
Marshall Clow5c459c92013-07-31 19:32:19 +00001378inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001379time_point<_Clock, _ToDuration>
1380time_point_cast(const time_point<_Clock, _Duration>& __t)
1381{
Howard Hinnantb1ad5a82011-06-30 21:18:19 +00001382 return time_point<_Clock, _ToDuration>(_VSTD::chrono::duration_cast<_ToDuration>(__t.time_since_epoch()));
Howard Hinnantc51e1022010-05-11 19:42:16 +00001383}
1384
Marshall Clowf2eabaf2015-11-05 19:33:59 +00001385#if _LIBCPP_STD_VER > 14
1386template <class _ToDuration, class _Clock, class _Duration>
1387inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
1388typename enable_if
1389<
1390 __is_duration<_ToDuration>::value,
1391 time_point<_Clock, _ToDuration>
1392>::type
1393floor(const time_point<_Clock, _Duration>& __t)
1394{
1395 return time_point<_Clock, _ToDuration>{floor<_ToDuration>(__t.time_since_epoch())};
1396}
1397
1398template <class _ToDuration, class _Clock, class _Duration>
1399inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
1400typename enable_if
1401<
1402 __is_duration<_ToDuration>::value,
1403 time_point<_Clock, _ToDuration>
1404>::type
1405ceil(const time_point<_Clock, _Duration>& __t)
1406{
1407 return time_point<_Clock, _ToDuration>{ceil<_ToDuration>(__t.time_since_epoch())};
1408}
1409
1410template <class _ToDuration, class _Clock, class _Duration>
1411inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
1412typename enable_if
1413<
1414 __is_duration<_ToDuration>::value,
1415 time_point<_Clock, _ToDuration>
1416>::type
1417round(const time_point<_Clock, _Duration>& __t)
1418{
1419 return time_point<_Clock, _ToDuration>{round<_ToDuration>(__t.time_since_epoch())};
1420}
1421
1422template <class _Rep, class _Period>
1423inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
1424typename enable_if
1425<
1426 numeric_limits<_Rep>::is_signed,
1427 duration<_Rep, _Period>
1428>::type
1429abs(duration<_Rep, _Period> __d)
1430{
1431 return __d >= __d.zero() ? __d : -__d;
1432}
1433#endif
1434
Howard Hinnantc51e1022010-05-11 19:42:16 +00001435// time_point ==
1436
1437template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001438inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001439bool
1440operator==(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1441{
1442 return __lhs.time_since_epoch() == __rhs.time_since_epoch();
1443}
1444
1445// time_point !=
1446
1447template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001448inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001449bool
1450operator!=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1451{
1452 return !(__lhs == __rhs);
1453}
1454
1455// time_point <
1456
1457template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001458inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001459bool
1460operator<(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1461{
1462 return __lhs.time_since_epoch() < __rhs.time_since_epoch();
1463}
1464
1465// time_point >
1466
1467template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001468inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001469bool
1470operator>(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1471{
1472 return __rhs < __lhs;
1473}
1474
1475// time_point <=
1476
1477template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001478inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001479bool
1480operator<=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1481{
1482 return !(__rhs < __lhs);
1483}
1484
1485// time_point >=
1486
1487template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001488inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001489bool
1490operator>=(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1491{
1492 return !(__lhs < __rhs);
1493}
1494
1495// time_point operator+(time_point x, duration y);
1496
1497template <class _Clock, class _Duration1, class _Rep2, class _Period2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001498inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001499time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type>
1500operator+(const time_point<_Clock, _Duration1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1501{
1502 typedef time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> _Tr;
Marshall Clow5c459c92013-07-31 19:32:19 +00001503 return _Tr (__lhs.time_since_epoch() + __rhs);
Howard Hinnantc51e1022010-05-11 19:42:16 +00001504}
1505
1506// time_point operator+(duration x, time_point y);
1507
1508template <class _Rep1, class _Period1, class _Clock, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001509inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001510time_point<_Clock, typename common_type<duration<_Rep1, _Period1>, _Duration2>::type>
1511operator+(const duration<_Rep1, _Period1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1512{
1513 return __rhs + __lhs;
1514}
1515
1516// time_point operator-(time_point x, duration y);
1517
1518template <class _Clock, class _Duration1, class _Rep2, class _Period2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001519inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001520time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type>
1521operator-(const time_point<_Clock, _Duration1>& __lhs, const duration<_Rep2, _Period2>& __rhs)
1522{
Marshall Clow78dbe462016-11-14 18:22:19 +00001523 typedef time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> _Ret;
1524 return _Ret(__lhs.time_since_epoch() -__rhs);
Howard Hinnantc51e1022010-05-11 19:42:16 +00001525}
1526
1527// duration operator-(time_point x, time_point y);
1528
1529template <class _Clock, class _Duration1, class _Duration2>
Marshall Clow5c459c92013-07-31 19:32:19 +00001530inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
Howard Hinnantc51e1022010-05-11 19:42:16 +00001531typename common_type<_Duration1, _Duration2>::type
1532operator-(const time_point<_Clock, _Duration1>& __lhs, const time_point<_Clock, _Duration2>& __rhs)
1533{
1534 return __lhs.time_since_epoch() - __rhs.time_since_epoch();
1535}
1536
1537//////////////////////////////////////////////////////////
1538/////////////////////// clocks ///////////////////////////
1539//////////////////////////////////////////////////////////
1540
Howard Hinnant8331b762013-03-06 23:30:19 +00001541class _LIBCPP_TYPE_VIS system_clock
Howard Hinnantc51e1022010-05-11 19:42:16 +00001542{
1543public:
1544 typedef microseconds duration;
1545 typedef duration::rep rep;
1546 typedef duration::period period;
1547 typedef chrono::time_point<system_clock> time_point;
Marshall Clow5c459c92013-07-31 19:32:19 +00001548 static _LIBCPP_CONSTEXPR_AFTER_CXX11 const bool is_steady = false;
Howard Hinnantc51e1022010-05-11 19:42:16 +00001549
Howard Hinnantaa54ac42011-05-28 18:34:36 +00001550 static time_point now() _NOEXCEPT;
1551 static time_t to_time_t (const time_point& __t) _NOEXCEPT;
1552 static time_point from_time_t(time_t __t) _NOEXCEPT;
Howard Hinnantc51e1022010-05-11 19:42:16 +00001553};
1554
Jonathan Roelofscce96eb2014-09-02 21:14:38 +00001555#ifndef _LIBCPP_HAS_NO_MONOTONIC_CLOCK
Howard Hinnant8331b762013-03-06 23:30:19 +00001556class _LIBCPP_TYPE_VIS steady_clock
Howard Hinnantc51e1022010-05-11 19:42:16 +00001557{
1558public:
1559 typedef nanoseconds duration;
1560 typedef duration::rep rep;
1561 typedef duration::period period;
Howard Hinnantc8dbd222010-11-20 19:16:30 +00001562 typedef chrono::time_point<steady_clock, duration> time_point;
Marshall Clow5c459c92013-07-31 19:32:19 +00001563 static _LIBCPP_CONSTEXPR_AFTER_CXX11 const bool is_steady = true;
Howard Hinnantc51e1022010-05-11 19:42:16 +00001564
Howard Hinnantaa54ac42011-05-28 18:34:36 +00001565 static time_point now() _NOEXCEPT;
Howard Hinnantc51e1022010-05-11 19:42:16 +00001566};
1567
Howard Hinnantc8dbd222010-11-20 19:16:30 +00001568typedef steady_clock high_resolution_clock;
Jonathan Roelofscce96eb2014-09-02 21:14:38 +00001569#else
1570typedef system_clock high_resolution_clock;
1571#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +00001572
Marshall Clow26058352018-10-16 17:27:54 +00001573#if _LIBCPP_STD_VER > 17
Eric Fiselier049273c2018-12-21 03:54:57 +00001574// [time.clock.file], type file_clock
1575using file_clock = _VSTD_FS::_FilesystemClock;
1576
1577template<class _Duration>
1578using file_time = time_point<file_clock, _Duration>;
Marshall Clow26058352018-10-16 17:27:54 +00001579
Marshall Clow188b3342019-01-11 15:12:04 +00001580
1581template <class _Duration>
1582using sys_time = time_point<system_clock, _Duration>;
1583using sys_seconds = sys_time<seconds>;
1584using sys_days = sys_time<days>;
1585
1586struct local_t {};
1587template<class Duration>
1588using local_time = time_point<local_t, Duration>;
1589using local_seconds = local_time<seconds>;
1590using local_days = local_time<days>;
1591
1592
Eric Fiselier28bc4292019-03-21 01:48:15 +00001593struct last_spec { explicit last_spec() = default; };
Marshall Clow26058352018-10-16 17:27:54 +00001594
Eric Fiselier28bc4292019-03-21 01:48:15 +00001595class day {
Marshall Clow26058352018-10-16 17:27:54 +00001596private:
1597 unsigned char __d;
1598public:
1599 day() = default;
1600 explicit inline constexpr day(unsigned __val) noexcept : __d(static_cast<unsigned char>(__val)) {}
1601 inline constexpr day& operator++() noexcept { ++__d; return *this; }
1602 inline constexpr day operator++(int) noexcept { day __tmp = *this; ++(*this); return __tmp; }
1603 inline constexpr day& operator--() noexcept { --__d; return *this; }
1604 inline constexpr day operator--(int) noexcept { day __tmp = *this; --(*this); return __tmp; }
1605 constexpr day& operator+=(const days& __dd) noexcept;
1606 constexpr day& operator-=(const days& __dd) noexcept;
1607 explicit inline constexpr operator unsigned() const noexcept { return __d; }
1608 inline constexpr bool ok() const noexcept { return __d >= 1 && __d <= 31; }
1609 };
1610
1611
1612inline constexpr
1613bool operator==(const day& __lhs, const day& __rhs) noexcept
1614{ return static_cast<unsigned>(__lhs) == static_cast<unsigned>(__rhs); }
1615
1616inline constexpr
1617bool operator!=(const day& __lhs, const day& __rhs) noexcept
1618{ return !(__lhs == __rhs); }
1619
1620inline constexpr
1621bool operator< (const day& __lhs, const day& __rhs) noexcept
1622{ return static_cast<unsigned>(__lhs) < static_cast<unsigned>(__rhs); }
1623
1624inline constexpr
1625bool operator> (const day& __lhs, const day& __rhs) noexcept
1626{ return __rhs < __lhs; }
1627
1628inline constexpr
1629bool operator<=(const day& __lhs, const day& __rhs) noexcept
1630{ return !(__rhs < __lhs);}
1631
1632inline constexpr
1633bool operator>=(const day& __lhs, const day& __rhs) noexcept
1634{ return !(__lhs < __rhs); }
1635
1636inline constexpr
1637day operator+ (const day& __lhs, const days& __rhs) noexcept
1638{ return day(static_cast<unsigned>(__lhs) + __rhs.count()); }
1639
1640inline constexpr
1641day operator+ (const days& __lhs, const day& __rhs) noexcept
1642{ return __rhs + __lhs; }
1643
1644inline constexpr
1645day operator- (const day& __lhs, const days& __rhs) noexcept
1646{ return __lhs + -__rhs; }
1647
1648inline constexpr
1649days operator-(const day& __lhs, const day& __rhs) noexcept
1650{ return days(static_cast<int>(static_cast<unsigned>(__lhs)) -
1651 static_cast<int>(static_cast<unsigned>(__rhs))); }
1652
1653inline constexpr day& day::operator+=(const days& __dd) noexcept
1654{ *this = *this + __dd; return *this; }
1655
1656inline constexpr day& day::operator-=(const days& __dd) noexcept
1657{ *this = *this - __dd; return *this; }
1658
1659
Eric Fiselier28bc4292019-03-21 01:48:15 +00001660class month {
Marshall Clow26058352018-10-16 17:27:54 +00001661private:
1662 unsigned char __m;
1663public:
1664 month() = default;
1665 explicit inline constexpr month(unsigned __val) noexcept : __m(static_cast<unsigned char>(__val)) {}
1666 inline constexpr month& operator++() noexcept { ++__m; return *this; }
1667 inline constexpr month operator++(int) noexcept { month __tmp = *this; ++(*this); return __tmp; }
1668 inline constexpr month& operator--() noexcept { --__m; return *this; }
1669 inline constexpr month operator--(int) noexcept { month __tmp = *this; --(*this); return __tmp; }
1670 constexpr month& operator+=(const months& __m1) noexcept;
1671 constexpr month& operator-=(const months& __m1) noexcept;
1672 explicit inline constexpr operator unsigned() const noexcept { return __m; }
1673 inline constexpr bool ok() const noexcept { return __m >= 1 && __m <= 12; }
1674};
1675
1676
1677inline constexpr
1678bool operator==(const month& __lhs, const month& __rhs) noexcept
1679{ return static_cast<unsigned>(__lhs) == static_cast<unsigned>(__rhs); }
1680
1681inline constexpr
1682bool operator!=(const month& __lhs, const month& __rhs) noexcept
1683{ return !(__lhs == __rhs); }
1684
1685inline constexpr
1686bool operator< (const month& __lhs, const month& __rhs) noexcept
1687{ return static_cast<unsigned>(__lhs) < static_cast<unsigned>(__rhs); }
1688
1689inline constexpr
1690bool operator> (const month& __lhs, const month& __rhs) noexcept
1691{ return __rhs < __lhs; }
1692
1693inline constexpr
1694bool operator<=(const month& __lhs, const month& __rhs) noexcept
1695{ return !(__rhs < __lhs); }
1696
1697inline constexpr
1698bool operator>=(const month& __lhs, const month& __rhs) noexcept
1699{ return !(__lhs < __rhs); }
1700
1701inline constexpr
1702month operator+ (const month& __lhs, const months& __rhs) noexcept
1703{
1704 auto const __mu = static_cast<long long>(static_cast<unsigned>(__lhs)) + (__rhs.count() - 1);
1705 auto const __yr = (__mu >= 0 ? __mu : __mu - 11) / 12;
1706 return month{static_cast<unsigned>(__mu - __yr * 12 + 1)};
1707}
1708
1709inline constexpr
1710month operator+ (const months& __lhs, const month& __rhs) noexcept
1711{ return __rhs + __lhs; }
1712
1713inline constexpr
1714month operator- (const month& __lhs, const months& __rhs) noexcept
1715{ return __lhs + -__rhs; }
1716
1717inline constexpr
1718months operator-(const month& __lhs, const month& __rhs) noexcept
1719{
1720 auto const __dm = static_cast<unsigned>(__lhs) - static_cast<unsigned>(__rhs);
1721 return months(__dm <= 11 ? __dm : __dm + 12);
1722}
1723
1724inline constexpr month& month::operator+=(const months& __dm) noexcept
1725{ *this = *this + __dm; return *this; }
1726
1727inline constexpr month& month::operator-=(const months& __dm) noexcept
1728{ *this = *this - __dm; return *this; }
1729
1730
Eric Fiselier28bc4292019-03-21 01:48:15 +00001731class year {
Marshall Clow26058352018-10-16 17:27:54 +00001732private:
1733 short __y;
1734public:
1735 year() = default;
1736 explicit inline constexpr year(int __val) noexcept : __y(static_cast<short>(__val)) {}
1737
Eric Fiselierebdb6b42019-02-10 18:29:00 +00001738 inline constexpr year& operator++() noexcept { ++__y; return *this; }
1739 inline constexpr year operator++(int) noexcept { year __tmp = *this; ++(*this); return __tmp; }
1740 inline constexpr year& operator--() noexcept { --__y; return *this; }
1741 inline constexpr year operator--(int) noexcept { year __tmp = *this; --(*this); return __tmp; }
Marshall Clow26058352018-10-16 17:27:54 +00001742 constexpr year& operator+=(const years& __dy) noexcept;
1743 constexpr year& operator-=(const years& __dy) noexcept;
1744 inline constexpr year operator+() const noexcept { return *this; }
Eric Fiselierebdb6b42019-02-10 18:29:00 +00001745 inline constexpr year operator-() const noexcept { return year{-__y}; }
Marshall Clow26058352018-10-16 17:27:54 +00001746
1747 inline constexpr bool is_leap() const noexcept { return __y % 4 == 0 && (__y % 100 != 0 || __y % 400 == 0); }
1748 explicit inline constexpr operator int() const noexcept { return __y; }
1749 constexpr bool ok() const noexcept;
1750 static inline constexpr year min() noexcept { return year{-32767}; }
1751 static inline constexpr year max() noexcept { return year{ 32767}; }
1752};
1753
1754
1755inline constexpr
1756bool operator==(const year& __lhs, const year& __rhs) noexcept
1757{ return static_cast<int>(__lhs) == static_cast<int>(__rhs); }
1758
1759inline constexpr
1760bool operator!=(const year& __lhs, const year& __rhs) noexcept
1761{ return !(__lhs == __rhs); }
1762
1763inline constexpr
1764bool operator< (const year& __lhs, const year& __rhs) noexcept
1765{ return static_cast<int>(__lhs) < static_cast<int>(__rhs); }
1766
1767inline constexpr
1768bool operator> (const year& __lhs, const year& __rhs) noexcept
1769{ return __rhs < __lhs; }
1770
1771inline constexpr
1772bool operator<=(const year& __lhs, const year& __rhs) noexcept
1773{ return !(__rhs < __lhs); }
1774
1775inline constexpr
1776bool operator>=(const year& __lhs, const year& __rhs) noexcept
1777{ return !(__lhs < __rhs); }
1778
1779inline constexpr
1780year operator+ (const year& __lhs, const years& __rhs) noexcept
1781{ return year(static_cast<int>(__lhs) + __rhs.count()); }
1782
1783inline constexpr
1784year operator+ (const years& __lhs, const year& __rhs) noexcept
1785{ return __rhs + __lhs; }
1786
1787inline constexpr
1788year operator- (const year& __lhs, const years& __rhs) noexcept
1789{ return __lhs + -__rhs; }
1790
1791inline constexpr
1792years operator-(const year& __lhs, const year& __rhs) noexcept
1793{ return years{static_cast<int>(__lhs) - static_cast<int>(__rhs)}; }
1794
1795
1796inline constexpr year& year::operator+=(const years& __dy) noexcept
1797{ *this = *this + __dy; return *this; }
1798
1799inline constexpr year& year::operator-=(const years& __dy) noexcept
1800{ *this = *this - __dy; return *this; }
1801
1802inline constexpr bool year::ok() const noexcept
1803{ return static_cast<int>(min()) <= __y && __y <= static_cast<int>(max()); }
1804
Eric Fiselier28bc4292019-03-21 01:48:15 +00001805class weekday_indexed;
1806class weekday_last;
Marshall Clow26058352018-10-16 17:27:54 +00001807
Eric Fiselier28bc4292019-03-21 01:48:15 +00001808class weekday {
Marshall Clow26058352018-10-16 17:27:54 +00001809private:
1810 unsigned char __wd;
1811public:
1812 weekday() = default;
Marshall Clowc0194d52019-07-25 03:26:05 +00001813 inline explicit constexpr weekday(unsigned __val) noexcept : __wd(static_cast<unsigned char>(__val == 7 ? 0 : __val)) {}
Marshall Clow188b3342019-01-11 15:12:04 +00001814 inline constexpr weekday(const sys_days& __sysd) noexcept
1815 : __wd(__weekday_from_days(__sysd.time_since_epoch().count())) {}
1816 inline explicit constexpr weekday(const local_days& __locd) noexcept
1817 : __wd(__weekday_from_days(__locd.time_since_epoch().count())) {}
1818
Marshall Clow26058352018-10-16 17:27:54 +00001819 inline constexpr weekday& operator++() noexcept { __wd = (__wd == 6 ? 0 : __wd + 1); return *this; }
1820 inline constexpr weekday operator++(int) noexcept { weekday __tmp = *this; ++(*this); return __tmp; }
1821 inline constexpr weekday& operator--() noexcept { __wd = (__wd == 0 ? 6 : __wd - 1); return *this; }
1822 inline constexpr weekday operator--(int) noexcept { weekday __tmp = *this; --(*this); return __tmp; }
1823 constexpr weekday& operator+=(const days& __dd) noexcept;
1824 constexpr weekday& operator-=(const days& __dd) noexcept;
Marshall Clowc0194d52019-07-25 03:26:05 +00001825 inline constexpr unsigned c_encoding() const noexcept { return __wd; }
1826 inline constexpr unsigned iso_encoding() const noexcept { return __wd == 0u ? 7 : __wd; }
Marshall Clow26058352018-10-16 17:27:54 +00001827 inline constexpr bool ok() const noexcept { return __wd <= 6; }
Marshall Clow188b3342019-01-11 15:12:04 +00001828 constexpr weekday_indexed operator[](unsigned __index) const noexcept;
1829 constexpr weekday_last operator[](last_spec) const noexcept;
1830
1831 static constexpr unsigned char __weekday_from_days(int __days) noexcept;
Marshall Clow26058352018-10-16 17:27:54 +00001832};
1833
Marshall Clow188b3342019-01-11 15:12:04 +00001834
1835// https://howardhinnant.github.io/date_algorithms.html#weekday_from_days
1836inline constexpr
1837unsigned char weekday::__weekday_from_days(int __days) noexcept
1838{
1839 return static_cast<unsigned char>(
1840 static_cast<unsigned>(__days >= -4 ? (__days+4) % 7 : (__days+5) % 7 + 6)
1841 );
1842}
1843
Marshall Clow26058352018-10-16 17:27:54 +00001844inline constexpr
1845bool operator==(const weekday& __lhs, const weekday& __rhs) noexcept
Marshall Clowc0194d52019-07-25 03:26:05 +00001846{ return __lhs.c_encoding() == __rhs.c_encoding(); }
Marshall Clow26058352018-10-16 17:27:54 +00001847
1848inline constexpr
1849bool operator!=(const weekday& __lhs, const weekday& __rhs) noexcept
1850{ return !(__lhs == __rhs); }
1851
1852inline constexpr
1853bool operator< (const weekday& __lhs, const weekday& __rhs) noexcept
Marshall Clowc0194d52019-07-25 03:26:05 +00001854{ return __lhs.c_encoding() < __rhs.c_encoding(); }
Marshall Clow26058352018-10-16 17:27:54 +00001855
1856inline constexpr
1857bool operator> (const weekday& __lhs, const weekday& __rhs) noexcept
1858{ return __rhs < __lhs; }
1859
1860inline constexpr
1861bool operator<=(const weekday& __lhs, const weekday& __rhs) noexcept
1862{ return !(__rhs < __lhs);}
1863
1864inline constexpr
1865bool operator>=(const weekday& __lhs, const weekday& __rhs) noexcept
1866{ return !(__lhs < __rhs); }
1867
1868constexpr weekday operator+(const weekday& __lhs, const days& __rhs) noexcept
1869{
Marshall Clowc0194d52019-07-25 03:26:05 +00001870 auto const __mu = static_cast<long long>(__lhs.c_encoding()) + __rhs.count();
Marshall Clow26058352018-10-16 17:27:54 +00001871 auto const __yr = (__mu >= 0 ? __mu : __mu - 6) / 7;
1872 return weekday{static_cast<unsigned>(__mu - __yr * 7)};
1873}
1874
1875constexpr weekday operator+(const days& __lhs, const weekday& __rhs) noexcept
1876{ return __rhs + __lhs; }
1877
1878constexpr weekday operator-(const weekday& __lhs, const days& __rhs) noexcept
1879{ return __lhs + -__rhs; }
1880
1881constexpr days operator-(const weekday& __lhs, const weekday& __rhs) noexcept
1882{
Marshall Clowc0194d52019-07-25 03:26:05 +00001883 const int __wdu = __lhs.c_encoding() - __rhs.c_encoding();
Marshall Clow26058352018-10-16 17:27:54 +00001884 const int __wk = (__wdu >= 0 ? __wdu : __wdu-6) / 7;
1885 return days{__wdu - __wk * 7};
1886}
1887
1888inline constexpr weekday& weekday::operator+=(const days& __dd) noexcept
1889{ *this = *this + __dd; return *this; }
1890
1891inline constexpr weekday& weekday::operator-=(const days& __dd) noexcept
1892{ *this = *this - __dd; return *this; }
1893
1894
Eric Fiselier28bc4292019-03-21 01:48:15 +00001895class weekday_indexed {
Marshall Clow26058352018-10-16 17:27:54 +00001896private:
1897 _VSTD::chrono::weekday __wd;
1898 unsigned char __idx;
1899public:
1900 weekday_indexed() = default;
1901 inline constexpr weekday_indexed(const _VSTD::chrono::weekday& __wdval, unsigned __idxval) noexcept
1902 : __wd{__wdval}, __idx(__idxval) {}
1903 inline constexpr _VSTD::chrono::weekday weekday() const noexcept { return __wd; }
1904 inline constexpr unsigned index() const noexcept { return __idx; }
1905 inline constexpr bool ok() const noexcept { return __wd.ok() && __idx >= 1 && __idx <= 5; }
1906};
1907
1908inline constexpr
1909bool operator==(const weekday_indexed& __lhs, const weekday_indexed& __rhs) noexcept
1910{ return __lhs.weekday() == __rhs.weekday() && __lhs.index() == __rhs.index(); }
1911
1912inline constexpr
1913bool operator!=(const weekday_indexed& __lhs, const weekday_indexed& __rhs) noexcept
1914{ return !(__lhs == __rhs); }
1915
1916
Eric Fiselier28bc4292019-03-21 01:48:15 +00001917class weekday_last {
Marshall Clow26058352018-10-16 17:27:54 +00001918private:
1919 _VSTD::chrono::weekday __wd;
1920public:
1921 explicit constexpr weekday_last(const _VSTD::chrono::weekday& __val) noexcept
1922 : __wd{__val} {}
1923 constexpr _VSTD::chrono::weekday weekday() const noexcept { return __wd; }
1924 constexpr bool ok() const noexcept { return __wd.ok(); }
1925};
1926
1927inline constexpr
1928bool operator==(const weekday_last& __lhs, const weekday_last& __rhs) noexcept
1929{ return __lhs.weekday() == __rhs.weekday(); }
1930
1931inline constexpr
1932bool operator!=(const weekday_last& __lhs, const weekday_last& __rhs) noexcept
1933{ return !(__lhs == __rhs); }
1934
1935inline constexpr
1936weekday_indexed weekday::operator[](unsigned __index) const noexcept { return weekday_indexed{*this, __index}; }
1937
Louis Dionne173f29e2019-05-29 16:01:36 +00001938inline constexpr
Marshall Clow26058352018-10-16 17:27:54 +00001939weekday_last weekday::operator[](last_spec) const noexcept { return weekday_last{*this}; }
1940
1941
1942inline constexpr last_spec last{};
1943inline constexpr weekday Sunday{0};
1944inline constexpr weekday Monday{1};
1945inline constexpr weekday Tuesday{2};
1946inline constexpr weekday Wednesday{3};
1947inline constexpr weekday Thursday{4};
1948inline constexpr weekday Friday{5};
1949inline constexpr weekday Saturday{6};
1950
1951inline constexpr month January{1};
1952inline constexpr month February{2};
1953inline constexpr month March{3};
1954inline constexpr month April{4};
1955inline constexpr month May{5};
1956inline constexpr month June{6};
1957inline constexpr month July{7};
1958inline constexpr month August{8};
1959inline constexpr month September{9};
1960inline constexpr month October{10};
1961inline constexpr month November{11};
1962inline constexpr month December{12};
1963
1964
Eric Fiselier28bc4292019-03-21 01:48:15 +00001965class month_day {
Marshall Clow26058352018-10-16 17:27:54 +00001966private:
1967 chrono::month __m;
1968 chrono::day __d;
1969public:
1970 month_day() = default;
1971 constexpr month_day(const chrono::month& __mval, const chrono::day& __dval) noexcept
1972 : __m{__mval}, __d{__dval} {}
1973 inline constexpr chrono::month month() const noexcept { return __m; }
1974 inline constexpr chrono::day day() const noexcept { return __d; }
1975 constexpr bool ok() const noexcept;
1976};
1977
1978inline constexpr
1979bool month_day::ok() const noexcept
1980{
1981 if (!__m.ok()) return false;
1982 const unsigned __dval = static_cast<unsigned>(__d);
1983 if (__dval < 1 || __dval > 31) return false;
1984 if (__dval <= 29) return true;
1985// Now we've got either 30 or 31
1986 const unsigned __mval = static_cast<unsigned>(__m);
1987 if (__mval == 2) return false;
1988 if (__mval == 4 || __mval == 6 || __mval == 9 || __mval == 11)
1989 return __dval == 30;
1990 return true;
1991}
1992
1993inline constexpr
1994bool operator==(const month_day& __lhs, const month_day& __rhs) noexcept
1995{ return __lhs.month() == __rhs.month() && __lhs.day() == __rhs.day(); }
1996
1997inline constexpr
1998bool operator!=(const month_day& __lhs, const month_day& __rhs) noexcept
1999{ return !(__lhs == __rhs); }
2000
2001inline constexpr
2002month_day operator/(const month& __lhs, const day& __rhs) noexcept
2003{ return month_day{__lhs, __rhs}; }
2004
2005constexpr
2006month_day operator/(const day& __lhs, const month& __rhs) noexcept
2007{ return __rhs / __lhs; }
2008
2009inline constexpr
2010month_day operator/(const month& __lhs, int __rhs) noexcept
2011{ return __lhs / day(__rhs); }
2012
2013constexpr
2014month_day operator/(int __lhs, const day& __rhs) noexcept
2015{ return month(__lhs) / __rhs; }
2016
2017constexpr
2018month_day operator/(const day& __lhs, int __rhs) noexcept
2019{ return month(__rhs) / __lhs; }
2020
2021
2022inline constexpr
2023bool operator< (const month_day& __lhs, const month_day& __rhs) noexcept
2024{ return __lhs.month() != __rhs.month() ? __lhs.month() < __rhs.month() : __lhs.day() < __rhs.day(); }
2025
2026inline constexpr
2027bool operator> (const month_day& __lhs, const month_day& __rhs) noexcept
2028{ return __rhs < __lhs; }
2029
2030inline constexpr
2031bool operator<=(const month_day& __lhs, const month_day& __rhs) noexcept
2032{ return !(__rhs < __lhs);}
2033
2034inline constexpr
2035bool operator>=(const month_day& __lhs, const month_day& __rhs) noexcept
2036{ return !(__lhs < __rhs); }
2037
2038
2039
Eric Fiselier28bc4292019-03-21 01:48:15 +00002040class month_day_last {
Marshall Clow26058352018-10-16 17:27:54 +00002041private:
2042 chrono::month __m;
2043public:
2044 explicit constexpr month_day_last(const chrono::month& __val) noexcept
2045 : __m{__val} {}
2046 inline constexpr chrono::month month() const noexcept { return __m; }
2047 inline constexpr bool ok() const noexcept { return __m.ok(); }
2048};
2049
2050inline constexpr
2051bool operator==(const month_day_last& __lhs, const month_day_last& __rhs) noexcept
2052{ return __lhs.month() == __rhs.month(); }
2053
2054inline constexpr
2055bool operator!=(const month_day_last& __lhs, const month_day_last& __rhs) noexcept
2056{ return !(__lhs == __rhs); }
2057
2058inline constexpr
2059bool operator< (const month_day_last& __lhs, const month_day_last& __rhs) noexcept
2060{ return __lhs.month() < __rhs.month(); }
2061
2062inline constexpr
2063bool operator> (const month_day_last& __lhs, const month_day_last& __rhs) noexcept
2064{ return __rhs < __lhs; }
2065
2066inline constexpr
2067bool operator<=(const month_day_last& __lhs, const month_day_last& __rhs) noexcept
2068{ return !(__rhs < __lhs);}
2069
2070inline constexpr
2071bool operator>=(const month_day_last& __lhs, const month_day_last& __rhs) noexcept
2072{ return !(__lhs < __rhs); }
2073
2074inline constexpr
2075month_day_last operator/(const month& __lhs, last_spec) noexcept
2076{ return month_day_last{__lhs}; }
2077
2078inline constexpr
2079month_day_last operator/(last_spec, const month& __rhs) noexcept
2080{ return month_day_last{__rhs}; }
2081
2082inline constexpr
2083month_day_last operator/(int __lhs, last_spec) noexcept
2084{ return month_day_last{month(__lhs)}; }
2085
2086inline constexpr
2087month_day_last operator/(last_spec, int __rhs) noexcept
2088{ return month_day_last{month(__rhs)}; }
2089
2090
Eric Fiselier28bc4292019-03-21 01:48:15 +00002091class month_weekday {
Marshall Clow26058352018-10-16 17:27:54 +00002092private:
2093 chrono::month __m;
2094 chrono::weekday_indexed __wdi;
2095public:
2096 month_weekday() = default;
2097 constexpr month_weekday(const chrono::month& __mval, const chrono::weekday_indexed& __wdival) noexcept
2098 : __m{__mval}, __wdi{__wdival} {}
2099 inline constexpr chrono::month month() const noexcept { return __m; }
2100 inline constexpr chrono::weekday_indexed weekday_indexed() const noexcept { return __wdi; }
2101 inline constexpr bool ok() const noexcept { return __m.ok() && __wdi.ok(); }
2102};
2103
2104inline constexpr
2105bool operator==(const month_weekday& __lhs, const month_weekday& __rhs) noexcept
2106{ return __lhs.month() == __rhs.month() && __lhs.weekday_indexed() == __rhs.weekday_indexed(); }
2107
2108inline constexpr
2109bool operator!=(const month_weekday& __lhs, const month_weekday& __rhs) noexcept
2110{ return !(__lhs == __rhs); }
2111
2112inline constexpr
2113month_weekday operator/(const month& __lhs, const weekday_indexed& __rhs) noexcept
2114{ return month_weekday{__lhs, __rhs}; }
2115
2116inline constexpr
2117month_weekday operator/(int __lhs, const weekday_indexed& __rhs) noexcept
2118{ return month_weekday{month(__lhs), __rhs}; }
2119
2120inline constexpr
2121month_weekday operator/(const weekday_indexed& __lhs, const month& __rhs) noexcept
2122{ return month_weekday{__rhs, __lhs}; }
2123
2124inline constexpr
2125month_weekday operator/(const weekday_indexed& __lhs, int __rhs) noexcept
2126{ return month_weekday{month(__rhs), __lhs}; }
2127
2128
Eric Fiselier28bc4292019-03-21 01:48:15 +00002129class month_weekday_last {
Marshall Clow26058352018-10-16 17:27:54 +00002130 chrono::month __m;
2131 chrono::weekday_last __wdl;
2132 public:
2133 constexpr month_weekday_last(const chrono::month& __mval, const chrono::weekday_last& __wdlval) noexcept
2134 : __m{__mval}, __wdl{__wdlval} {}
2135 inline constexpr chrono::month month() const noexcept { return __m; }
2136 inline constexpr chrono::weekday_last weekday_last() const noexcept { return __wdl; }
2137 inline constexpr bool ok() const noexcept { return __m.ok() && __wdl.ok(); }
2138};
2139
2140inline constexpr
2141bool operator==(const month_weekday_last& __lhs, const month_weekday_last& __rhs) noexcept
2142{ return __lhs.month() == __rhs.month() && __lhs.weekday_last() == __rhs.weekday_last(); }
2143
2144inline constexpr
2145bool operator!=(const month_weekday_last& __lhs, const month_weekday_last& __rhs) noexcept
2146{ return !(__lhs == __rhs); }
2147
2148
2149inline constexpr
2150month_weekday_last operator/(const month& __lhs, const weekday_last& __rhs) noexcept
2151{ return month_weekday_last{__lhs, __rhs}; }
2152
2153inline constexpr
2154month_weekday_last operator/(int __lhs, const weekday_last& __rhs) noexcept
2155{ return month_weekday_last{month(__lhs), __rhs}; }
2156
2157inline constexpr
2158month_weekday_last operator/(const weekday_last& __lhs, const month& __rhs) noexcept
2159{ return month_weekday_last{__rhs, __lhs}; }
2160
2161inline constexpr
2162month_weekday_last operator/(const weekday_last& __lhs, int __rhs) noexcept
2163{ return month_weekday_last{month(__rhs), __lhs}; }
2164
2165
Eric Fiselier28bc4292019-03-21 01:48:15 +00002166class year_month {
Marshall Clow26058352018-10-16 17:27:54 +00002167 chrono::year __y;
2168 chrono::month __m;
2169public:
2170 year_month() = default;
2171 constexpr year_month(const chrono::year& __yval, const chrono::month& __mval) noexcept
2172 : __y{__yval}, __m{__mval} {}
2173 inline constexpr chrono::year year() const noexcept { return __y; }
2174 inline constexpr chrono::month month() const noexcept { return __m; }
2175 inline constexpr year_month& operator+=(const months& __dm) noexcept { this->__m += __dm; return *this; }
2176 inline constexpr year_month& operator-=(const months& __dm) noexcept { this->__m -= __dm; return *this; }
2177 inline constexpr year_month& operator+=(const years& __dy) noexcept { this->__y += __dy; return *this; }
2178 inline constexpr year_month& operator-=(const years& __dy) noexcept { this->__y -= __dy; return *this; }
2179 inline constexpr bool ok() const noexcept { return __y.ok() && __m.ok(); }
2180};
2181
2182inline constexpr
2183year_month operator/(const year& __y, const month& __m) noexcept { return year_month{__y, __m}; }
2184
2185inline constexpr
2186year_month operator/(const year& __y, int __m) noexcept { return year_month{__y, month(__m)}; }
2187
2188inline constexpr
2189bool operator==(const year_month& __lhs, const year_month& __rhs) noexcept
2190{ return __lhs.year() == __rhs.year() && __lhs.month() == __rhs.month(); }
2191
2192inline constexpr
2193bool operator!=(const year_month& __lhs, const year_month& __rhs) noexcept
2194{ return !(__lhs == __rhs); }
2195
2196inline constexpr
2197bool operator< (const year_month& __lhs, const year_month& __rhs) noexcept
2198{ return __lhs.year() != __rhs.year() ? __lhs.year() < __rhs.year() : __lhs.month() < __rhs.month(); }
2199
2200inline constexpr
2201bool operator> (const year_month& __lhs, const year_month& __rhs) noexcept
2202{ return __rhs < __lhs; }
2203
2204inline constexpr
2205bool operator<=(const year_month& __lhs, const year_month& __rhs) noexcept
2206{ return !(__rhs < __lhs);}
2207
2208inline constexpr
2209bool operator>=(const year_month& __lhs, const year_month& __rhs) noexcept
2210{ return !(__lhs < __rhs); }
2211
2212constexpr year_month operator+(const year_month& __lhs, const months& __rhs) noexcept
2213{
2214 int __dmi = static_cast<int>(static_cast<unsigned>(__lhs.month())) - 1 + __rhs.count();
2215 const int __dy = (__dmi >= 0 ? __dmi : __dmi-11) / 12;
2216 __dmi = __dmi - __dy * 12 + 1;
2217 return (__lhs.year() + years(__dy)) / month(static_cast<unsigned>(__dmi));
2218}
2219
2220constexpr year_month operator+(const months& __lhs, const year_month& __rhs) noexcept
2221{ return __rhs + __lhs; }
2222
2223constexpr year_month operator+(const year_month& __lhs, const years& __rhs) noexcept
2224{ return (__lhs.year() + __rhs) / __lhs.month(); }
2225
2226constexpr year_month operator+(const years& __lhs, const year_month& __rhs) noexcept
2227{ return __rhs + __lhs; }
2228
2229constexpr months operator-(const year_month& __lhs, const year_month& __rhs) noexcept
2230{ return (__lhs.year() - __rhs.year()) + months(static_cast<unsigned>(__lhs.month()) - static_cast<unsigned>(__rhs.month())); }
2231
2232constexpr year_month operator-(const year_month& __lhs, const months& __rhs) noexcept
2233{ return __lhs + -__rhs; }
2234
2235constexpr year_month operator-(const year_month& __lhs, const years& __rhs) noexcept
2236{ return __lhs + -__rhs; }
2237
Marshall Clow188b3342019-01-11 15:12:04 +00002238class year_month_day_last;
Marshall Clow26058352018-10-16 17:27:54 +00002239
Eric Fiselier28bc4292019-03-21 01:48:15 +00002240class year_month_day {
Marshall Clow26058352018-10-16 17:27:54 +00002241private:
2242 chrono::year __y;
2243 chrono::month __m;
2244 chrono::day __d;
2245public:
2246 year_month_day() = default;
2247 inline constexpr year_month_day(
2248 const chrono::year& __yval, const chrono::month& __mval, const chrono::day& __dval) noexcept
Louis Dionne173f29e2019-05-29 16:01:36 +00002249 : __y{__yval}, __m{__mval}, __d{__dval} {}
Marshall Clow188b3342019-01-11 15:12:04 +00002250 constexpr year_month_day(const year_month_day_last& __ymdl) noexcept;
2251 inline constexpr year_month_day(const sys_days& __sysd) noexcept
2252 : year_month_day(__from_days(__sysd.time_since_epoch())) {}
2253 inline explicit constexpr year_month_day(const local_days& __locd) noexcept
2254 : year_month_day(__from_days(__locd.time_since_epoch())) {}
2255
Marshall Clow26058352018-10-16 17:27:54 +00002256 constexpr year_month_day& operator+=(const months& __dm) noexcept;
2257 constexpr year_month_day& operator-=(const months& __dm) noexcept;
2258 constexpr year_month_day& operator+=(const years& __dy) noexcept;
2259 constexpr year_month_day& operator-=(const years& __dy) noexcept;
Marshall Clow26058352018-10-16 17:27:54 +00002260
Marshall Clow188b3342019-01-11 15:12:04 +00002261 inline constexpr chrono::year year() const noexcept { return __y; }
2262 inline constexpr chrono::month month() const noexcept { return __m; }
2263 inline constexpr chrono::day day() const noexcept { return __d; }
2264 inline constexpr operator sys_days() const noexcept { return sys_days{__to_days()}; }
2265 inline explicit constexpr operator local_days() const noexcept { return local_days{__to_days()}; }
2266
2267 constexpr bool ok() const noexcept;
2268
2269 static constexpr year_month_day __from_days(days __d) noexcept;
2270 constexpr days __to_days() const noexcept;
Marshall Clow26058352018-10-16 17:27:54 +00002271};
2272
Marshall Clow188b3342019-01-11 15:12:04 +00002273
2274// https://howardhinnant.github.io/date_algorithms.html#civil_from_days
2275inline constexpr
2276year_month_day
2277year_month_day::__from_days(days __d) noexcept
2278{
2279 static_assert(std::numeric_limits<unsigned>::digits >= 18, "");
2280 static_assert(std::numeric_limits<int>::digits >= 20 , "");
2281 const int __z = __d.count() + 719468;
2282 const int __era = (__z >= 0 ? __z : __z - 146096) / 146097;
2283 const unsigned __doe = static_cast<unsigned>(__z - __era * 146097); // [0, 146096]
2284 const unsigned __yoe = (__doe - __doe/1460 + __doe/36524 - __doe/146096) / 365; // [0, 399]
2285 const int __yr = static_cast<int>(__yoe) + __era * 400;
2286 const unsigned __doy = __doe - (365 * __yoe + __yoe/4 - __yoe/100); // [0, 365]
2287 const unsigned __mp = (5 * __doy + 2)/153; // [0, 11]
2288 const unsigned __dy = __doy - (153 * __mp + 2)/5 + 1; // [1, 31]
2289 const unsigned __mth = __mp + (__mp < 10 ? 3 : -9); // [1, 12]
2290 return year_month_day{chrono::year{__yr + (__mth <= 2)}, chrono::month{__mth}, chrono::day{__dy}};
2291}
2292
2293// https://howardhinnant.github.io/date_algorithms.html#days_from_civil
2294inline constexpr days year_month_day::__to_days() const noexcept
2295{
2296 static_assert(std::numeric_limits<unsigned>::digits >= 18, "");
2297 static_assert(std::numeric_limits<int>::digits >= 20 , "");
2298
2299 const int __yr = static_cast<int>(__y) - (__m <= February);
2300 const unsigned __mth = static_cast<unsigned>(__m);
2301 const unsigned __dy = static_cast<unsigned>(__d);
2302
2303 const int __era = (__yr >= 0 ? __yr : __yr - 399) / 400;
2304 const unsigned __yoe = static_cast<unsigned>(__yr - __era * 400); // [0, 399]
2305 const unsigned __doy = (153 * (__mth + (__mth > 2 ? -3 : 9)) + 2) / 5 + __dy-1; // [0, 365]
2306 const unsigned __doe = __yoe * 365 + __yoe/4 - __yoe/100 + __doy; // [0, 146096]
2307 return days{__era * 146097 + static_cast<int>(__doe) - 719468};
2308}
2309
Marshall Clow26058352018-10-16 17:27:54 +00002310inline constexpr
2311bool operator==(const year_month_day& __lhs, const year_month_day& __rhs) noexcept
2312{ return __lhs.year() == __rhs.year() && __lhs.month() == __rhs.month() && __lhs.day() == __rhs.day(); }
2313
2314inline constexpr
2315bool operator!=(const year_month_day& __lhs, const year_month_day& __rhs) noexcept
2316{ return !(__lhs == __rhs); }
2317
2318inline constexpr
2319bool operator< (const year_month_day& __lhs, const year_month_day& __rhs) noexcept
2320{
2321 if (__lhs.year() < __rhs.year()) return true;
2322 if (__lhs.year() > __rhs.year()) return false;
2323 if (__lhs.month() < __rhs.month()) return true;
2324 if (__lhs.month() > __rhs.month()) return false;
2325 return __lhs.day() < __rhs.day();
2326}
2327
2328inline constexpr
2329bool operator> (const year_month_day& __lhs, const year_month_day& __rhs) noexcept
2330{ return __rhs < __lhs; }
2331
2332inline constexpr
2333bool operator<=(const year_month_day& __lhs, const year_month_day& __rhs) noexcept
2334{ return !(__rhs < __lhs);}
2335
2336inline constexpr
2337bool operator>=(const year_month_day& __lhs, const year_month_day& __rhs) noexcept
2338{ return !(__lhs < __rhs); }
2339
2340inline constexpr
2341year_month_day operator/(const year_month& __lhs, const day& __rhs) noexcept
2342{ return year_month_day{__lhs.year(), __lhs.month(), __rhs}; }
2343
2344inline constexpr
2345year_month_day operator/(const year_month& __lhs, int __rhs) noexcept
2346{ return __lhs / day(__rhs); }
2347
2348inline constexpr
2349year_month_day operator/(const year& __lhs, const month_day& __rhs) noexcept
2350{ return __lhs / __rhs.month() / __rhs.day(); }
2351
2352inline constexpr
2353year_month_day operator/(int __lhs, const month_day& __rhs) noexcept
2354{ return year(__lhs) / __rhs; }
2355
2356inline constexpr
2357year_month_day operator/(const month_day& __lhs, const year& __rhs) noexcept
2358{ return __rhs / __lhs; }
2359
2360inline constexpr
2361year_month_day operator/(const month_day& __lhs, int __rhs) noexcept
2362{ return year(__rhs) / __lhs; }
2363
2364
2365inline constexpr
2366year_month_day operator+(const year_month_day& __lhs, const months& __rhs) noexcept
2367{ return (__lhs.year()/__lhs.month() + __rhs)/__lhs.day(); }
2368
2369inline constexpr
2370year_month_day operator+(const months& __lhs, const year_month_day& __rhs) noexcept
2371{ return __rhs + __lhs; }
2372
2373inline constexpr
2374year_month_day operator-(const year_month_day& __lhs, const months& __rhs) noexcept
2375{ return __lhs + -__rhs; }
2376
2377inline constexpr
2378year_month_day operator+(const year_month_day& __lhs, const years& __rhs) noexcept
2379{ return (__lhs.year() + __rhs) / __lhs.month() / __lhs.day(); }
2380
2381inline constexpr
2382year_month_day operator+(const years& __lhs, const year_month_day& __rhs) noexcept
2383{ return __rhs + __lhs; }
2384
2385inline constexpr
2386year_month_day operator-(const year_month_day& __lhs, const years& __rhs) noexcept
2387{ return __lhs + -__rhs; }
2388
2389inline constexpr year_month_day& year_month_day::operator+=(const months& __dm) noexcept { *this = *this + __dm; return *this; }
2390inline constexpr year_month_day& year_month_day::operator-=(const months& __dm) noexcept { *this = *this - __dm; return *this; }
2391inline constexpr year_month_day& year_month_day::operator+=(const years& __dy) noexcept { *this = *this + __dy; return *this; }
2392inline constexpr year_month_day& year_month_day::operator-=(const years& __dy) noexcept { *this = *this - __dy; return *this; }
2393
Eric Fiselier28bc4292019-03-21 01:48:15 +00002394class year_month_day_last {
Marshall Clow26058352018-10-16 17:27:54 +00002395private:
2396 chrono::year __y;
2397 chrono::month_day_last __mdl;
2398public:
2399 constexpr year_month_day_last(const year& __yval, const month_day_last& __mdlval) noexcept
2400 : __y{__yval}, __mdl{__mdlval} {}
2401
2402 constexpr year_month_day_last& operator+=(const months& __m) noexcept;
2403 constexpr year_month_day_last& operator-=(const months& __m) noexcept;
2404 constexpr year_month_day_last& operator+=(const years& __y) noexcept;
2405 constexpr year_month_day_last& operator-=(const years& __y) noexcept;
2406
Marshall Clow188b3342019-01-11 15:12:04 +00002407 inline constexpr chrono::year year() const noexcept { return __y; }
2408 inline constexpr chrono::month month() const noexcept { return __mdl.month(); }
2409 inline constexpr chrono::month_day_last month_day_last() const noexcept { return __mdl; }
2410 constexpr chrono::day day() const noexcept;
2411 inline constexpr operator sys_days() const noexcept { return sys_days{year()/month()/day()}; }
2412 inline explicit constexpr operator local_days() const noexcept { return local_days{year()/month()/day()}; }
2413 inline constexpr bool ok() const noexcept { return __y.ok() && __mdl.ok(); }
Marshall Clow26058352018-10-16 17:27:54 +00002414};
2415
2416inline constexpr
Marshall Clow188b3342019-01-11 15:12:04 +00002417chrono::day year_month_day_last::day() const noexcept
2418{
2419 constexpr chrono::day __d[] =
2420 {
2421 chrono::day(31), chrono::day(28), chrono::day(31),
2422 chrono::day(30), chrono::day(31), chrono::day(30),
2423 chrono::day(31), chrono::day(31), chrono::day(30),
2424 chrono::day(31), chrono::day(30), chrono::day(31)
2425 };
2426 return month() != February || !__y.is_leap() ?
2427 __d[static_cast<unsigned>(month()) - 1] : chrono::day{29};
2428}
2429
2430inline constexpr
Marshall Clow26058352018-10-16 17:27:54 +00002431bool operator==(const year_month_day_last& __lhs, const year_month_day_last& __rhs) noexcept
2432{ return __lhs.year() == __rhs.year() && __lhs.month_day_last() == __rhs.month_day_last(); }
2433
2434inline constexpr
2435bool operator!=(const year_month_day_last& __lhs, const year_month_day_last& __rhs) noexcept
2436{ return !(__lhs == __rhs); }
2437
2438inline constexpr
2439bool operator< (const year_month_day_last& __lhs, const year_month_day_last& __rhs) noexcept
2440{
2441 if (__lhs.year() < __rhs.year()) return true;
2442 if (__lhs.year() > __rhs.year()) return false;
2443 return __lhs.month_day_last() < __rhs.month_day_last();
2444}
2445
2446inline constexpr
2447bool operator> (const year_month_day_last& __lhs, const year_month_day_last& __rhs) noexcept
2448{ return __rhs < __lhs; }
2449
2450inline constexpr
2451bool operator<=(const year_month_day_last& __lhs, const year_month_day_last& __rhs) noexcept
2452{ return !(__rhs < __lhs);}
2453
2454inline constexpr
2455bool operator>=(const year_month_day_last& __lhs, const year_month_day_last& __rhs) noexcept
2456{ return !(__lhs < __rhs); }
2457
2458inline constexpr year_month_day_last operator/(const year_month& __lhs, last_spec) noexcept
2459{ return year_month_day_last{__lhs.year(), month_day_last{__lhs.month()}}; }
2460
2461inline constexpr year_month_day_last operator/(const year& __lhs, const month_day_last& __rhs) noexcept
2462{ return year_month_day_last{__lhs, __rhs}; }
2463
2464inline constexpr year_month_day_last operator/(int __lhs, const month_day_last& __rhs) noexcept
2465{ return year_month_day_last{year{__lhs}, __rhs}; }
2466
2467inline constexpr year_month_day_last operator/(const month_day_last& __lhs, const year& __rhs) noexcept
2468{ return __rhs / __lhs; }
2469
2470inline constexpr year_month_day_last operator/(const month_day_last& __lhs, int __rhs) noexcept
2471{ return year{__rhs} / __lhs; }
2472
2473
2474inline constexpr
2475year_month_day_last operator+(const year_month_day_last& __lhs, const months& __rhs) noexcept
2476{ return (__lhs.year() / __lhs.month() + __rhs) / last; }
2477
2478inline constexpr
2479year_month_day_last operator+(const months& __lhs, const year_month_day_last& __rhs) noexcept
2480{ return __rhs + __lhs; }
2481
2482inline constexpr
2483year_month_day_last operator-(const year_month_day_last& __lhs, const months& __rhs) noexcept
2484{ return __lhs + (-__rhs); }
2485
2486inline constexpr
2487year_month_day_last operator+(const year_month_day_last& __lhs, const years& __rhs) noexcept
2488{ return year_month_day_last{__lhs.year() + __rhs, __lhs.month_day_last()}; }
2489
2490inline constexpr
2491year_month_day_last operator+(const years& __lhs, const year_month_day_last& __rhs) noexcept
2492{ return __rhs + __lhs; }
2493
2494inline constexpr
2495year_month_day_last operator-(const year_month_day_last& __lhs, const years& __rhs) noexcept
2496{ return __lhs + (-__rhs); }
2497
2498inline constexpr year_month_day_last& year_month_day_last::operator+=(const months& __dm) noexcept { *this = *this + __dm; return *this; }
2499inline constexpr year_month_day_last& year_month_day_last::operator-=(const months& __dm) noexcept { *this = *this - __dm; return *this; }
2500inline constexpr year_month_day_last& year_month_day_last::operator+=(const years& __dy) noexcept { *this = *this + __dy; return *this; }
2501inline constexpr year_month_day_last& year_month_day_last::operator-=(const years& __dy) noexcept { *this = *this - __dy; return *this; }
2502
Marshall Clow188b3342019-01-11 15:12:04 +00002503inline constexpr year_month_day::year_month_day(const year_month_day_last& __ymdl) noexcept
Louis Dionne173f29e2019-05-29 16:01:36 +00002504 : __y{__ymdl.year()}, __m{__ymdl.month()}, __d{__ymdl.day()} {}
Marshall Clow188b3342019-01-11 15:12:04 +00002505
2506inline constexpr bool year_month_day::ok() const noexcept
2507{
2508 if (!__y.ok() || !__m.ok()) return false;
2509 return chrono::day{1} <= __d && __d <= (__y / __m / last).day();
2510}
2511
Eric Fiselier28bc4292019-03-21 01:48:15 +00002512class year_month_weekday {
Marshall Clow26058352018-10-16 17:27:54 +00002513 chrono::year __y;
2514 chrono::month __m;
2515 chrono::weekday_indexed __wdi;
2516public:
2517 year_month_weekday() = default;
2518 constexpr year_month_weekday(const chrono::year& __yval, const chrono::month& __mval,
2519 const chrono::weekday_indexed& __wdival) noexcept
2520 : __y{__yval}, __m{__mval}, __wdi{__wdival} {}
Marshall Clow188b3342019-01-11 15:12:04 +00002521 constexpr year_month_weekday(const sys_days& __sysd) noexcept
2522 : year_month_weekday(__from_days(__sysd.time_since_epoch())) {}
2523 inline explicit constexpr year_month_weekday(const local_days& __locd) noexcept
2524 : year_month_weekday(__from_days(__locd.time_since_epoch())) {}
Marshall Clow26058352018-10-16 17:27:54 +00002525 constexpr year_month_weekday& operator+=(const months& m) noexcept;
2526 constexpr year_month_weekday& operator-=(const months& m) noexcept;
2527 constexpr year_month_weekday& operator+=(const years& y) noexcept;
2528 constexpr year_month_weekday& operator-=(const years& y) noexcept;
2529
2530 inline constexpr chrono::year year() const noexcept { return __y; }
2531 inline constexpr chrono::month month() const noexcept { return __m; }
2532 inline constexpr chrono::weekday weekday() const noexcept { return __wdi.weekday(); }
2533 inline constexpr unsigned index() const noexcept { return __wdi.index(); }
2534 inline constexpr chrono::weekday_indexed weekday_indexed() const noexcept { return __wdi; }
2535
Marshall Clow188b3342019-01-11 15:12:04 +00002536 inline constexpr operator sys_days() const noexcept { return sys_days{__to_days()}; }
2537 inline explicit constexpr operator local_days() const noexcept { return local_days{__to_days()}; }
Marshall Clow26058352018-10-16 17:27:54 +00002538 inline constexpr bool ok() const noexcept
2539 {
2540 if (!__y.ok() || !__m.ok() || !__wdi.ok()) return false;
2541 // TODO: make sure it's a valid date
2542 return true;
2543 }
Marshall Clow188b3342019-01-11 15:12:04 +00002544
2545 static constexpr year_month_weekday __from_days(days __d) noexcept;
2546 constexpr days __to_days() const noexcept;
Marshall Clow26058352018-10-16 17:27:54 +00002547};
2548
2549inline constexpr
Marshall Clow188b3342019-01-11 15:12:04 +00002550year_month_weekday year_month_weekday::__from_days(days __d) noexcept
2551{
2552 const sys_days __sysd{__d};
2553 const chrono::weekday __wd = chrono::weekday(__sysd);
2554 const year_month_day __ymd = year_month_day(__sysd);
Louis Dionne173f29e2019-05-29 16:01:36 +00002555 return year_month_weekday{__ymd.year(), __ymd.month(),
Marshall Clow188b3342019-01-11 15:12:04 +00002556 __wd[(static_cast<unsigned>(__ymd.day())-1)/7+1]};
2557}
2558
2559inline constexpr
2560days year_month_weekday::__to_days() const noexcept
2561{
2562 const sys_days __sysd = sys_days(__y/__m/1);
2563 return (__sysd + (__wdi.weekday() - chrono::weekday(__sysd) + days{(__wdi.index()-1)*7}))
2564 .time_since_epoch();
2565}
2566
2567inline constexpr
Marshall Clow26058352018-10-16 17:27:54 +00002568bool operator==(const year_month_weekday& __lhs, const year_month_weekday& __rhs) noexcept
2569{ return __lhs.year() == __rhs.year() && __lhs.month() == __rhs.month() && __lhs.weekday_indexed() == __rhs.weekday_indexed(); }
2570
2571inline constexpr
2572bool operator!=(const year_month_weekday& __lhs, const year_month_weekday& __rhs) noexcept
2573{ return !(__lhs == __rhs); }
2574
2575inline constexpr
2576year_month_weekday operator/(const year_month& __lhs, const weekday_indexed& __rhs) noexcept
2577{ return year_month_weekday{__lhs.year(), __lhs.month(), __rhs}; }
2578
2579inline constexpr
2580year_month_weekday operator/(const year& __lhs, const month_weekday& __rhs) noexcept
2581{ return year_month_weekday{__lhs, __rhs.month(), __rhs.weekday_indexed()}; }
2582
2583inline constexpr
2584year_month_weekday operator/(int __lhs, const month_weekday& __rhs) noexcept
2585{ return year(__lhs) / __rhs; }
2586
2587inline constexpr
2588year_month_weekday operator/(const month_weekday& __lhs, const year& __rhs) noexcept
2589{ return __rhs / __lhs; }
2590
2591inline constexpr
2592year_month_weekday operator/(const month_weekday& __lhs, int __rhs) noexcept
2593{ return year(__rhs) / __lhs; }
2594
2595
2596inline constexpr
2597year_month_weekday operator+(const year_month_weekday& __lhs, const months& __rhs) noexcept
2598{ return (__lhs.year() / __lhs.month() + __rhs) / __lhs.weekday_indexed(); }
2599
2600inline constexpr
2601year_month_weekday operator+(const months& __lhs, const year_month_weekday& __rhs) noexcept
2602{ return __rhs + __lhs; }
2603
2604inline constexpr
2605year_month_weekday operator-(const year_month_weekday& __lhs, const months& __rhs) noexcept
2606{ return __lhs + (-__rhs); }
2607
2608inline constexpr
2609year_month_weekday operator+(const year_month_weekday& __lhs, const years& __rhs) noexcept
2610{ return year_month_weekday{__lhs.year() + __rhs, __lhs.month(), __lhs.weekday_indexed()}; }
2611
2612inline constexpr
2613year_month_weekday operator+(const years& __lhs, const year_month_weekday& __rhs) noexcept
2614{ return __rhs + __lhs; }
2615
2616inline constexpr
2617year_month_weekday operator-(const year_month_weekday& __lhs, const years& __rhs) noexcept
2618{ return __lhs + (-__rhs); }
2619
2620
2621inline constexpr year_month_weekday& year_month_weekday::operator+=(const months& __dm) noexcept { *this = *this + __dm; return *this; }
2622inline constexpr year_month_weekday& year_month_weekday::operator-=(const months& __dm) noexcept { *this = *this - __dm; return *this; }
2623inline constexpr year_month_weekday& year_month_weekday::operator+=(const years& __dy) noexcept { *this = *this + __dy; return *this; }
2624inline constexpr year_month_weekday& year_month_weekday::operator-=(const years& __dy) noexcept { *this = *this - __dy; return *this; }
2625
Eric Fiselier28bc4292019-03-21 01:48:15 +00002626class year_month_weekday_last {
Marshall Clow26058352018-10-16 17:27:54 +00002627private:
2628 chrono::year __y;
2629 chrono::month __m;
2630 chrono::weekday_last __wdl;
2631public:
2632 constexpr year_month_weekday_last(const chrono::year& __yval, const chrono::month& __mval,
2633 const chrono::weekday_last& __wdlval) noexcept
2634 : __y{__yval}, __m{__mval}, __wdl{__wdlval} {}
2635 constexpr year_month_weekday_last& operator+=(const months& __dm) noexcept;
2636 constexpr year_month_weekday_last& operator-=(const months& __dm) noexcept;
2637 constexpr year_month_weekday_last& operator+=(const years& __dy) noexcept;
2638 constexpr year_month_weekday_last& operator-=(const years& __dy) noexcept;
2639
2640 inline constexpr chrono::year year() const noexcept { return __y; }
2641 inline constexpr chrono::month month() const noexcept { return __m; }
2642 inline constexpr chrono::weekday weekday() const noexcept { return __wdl.weekday(); }
2643 inline constexpr chrono::weekday_last weekday_last() const noexcept { return __wdl; }
Marshall Clow188b3342019-01-11 15:12:04 +00002644 inline constexpr operator sys_days() const noexcept { return sys_days{__to_days()}; }
2645 inline explicit constexpr operator local_days() const noexcept { return local_days{__to_days()}; }
Marshall Clow26058352018-10-16 17:27:54 +00002646 inline constexpr bool ok() const noexcept { return __y.ok() && __m.ok() && __wdl.ok(); }
Louis Dionne173f29e2019-05-29 16:01:36 +00002647
Marshall Clow188b3342019-01-11 15:12:04 +00002648 constexpr days __to_days() const noexcept;
Louis Dionne173f29e2019-05-29 16:01:36 +00002649
Marshall Clow26058352018-10-16 17:27:54 +00002650};
2651
2652inline constexpr
Marshall Clow188b3342019-01-11 15:12:04 +00002653days year_month_weekday_last::__to_days() const noexcept
2654{
2655 const sys_days __last = sys_days{__y/__m/last};
2656 return (__last - (chrono::weekday{__last} - __wdl.weekday())).time_since_epoch();
2657
2658}
2659
2660inline constexpr
Marshall Clow26058352018-10-16 17:27:54 +00002661bool operator==(const year_month_weekday_last& __lhs, const year_month_weekday_last& __rhs) noexcept
2662{ return __lhs.year() == __rhs.year() && __lhs.month() == __rhs.month() && __lhs.weekday_last() == __rhs.weekday_last(); }
2663
2664inline constexpr
2665bool operator!=(const year_month_weekday_last& __lhs, const year_month_weekday_last& __rhs) noexcept
2666{ return !(__lhs == __rhs); }
2667
2668
2669inline constexpr
2670year_month_weekday_last operator/(const year_month& __lhs, const weekday_last& __rhs) noexcept
2671{ return year_month_weekday_last{__lhs.year(), __lhs.month(), __rhs}; }
2672
2673inline constexpr
2674year_month_weekday_last operator/(const year& __lhs, const month_weekday_last& __rhs) noexcept
2675{ return year_month_weekday_last{__lhs, __rhs.month(), __rhs.weekday_last()}; }
2676
2677inline constexpr
2678year_month_weekday_last operator/(int __lhs, const month_weekday_last& __rhs) noexcept
2679{ return year(__lhs) / __rhs; }
2680
2681inline constexpr
2682year_month_weekday_last operator/(const month_weekday_last& __lhs, const year& __rhs) noexcept
2683{ return __rhs / __lhs; }
2684
2685inline constexpr
2686year_month_weekday_last operator/(const month_weekday_last& __lhs, int __rhs) noexcept
Louis Dionne173f29e2019-05-29 16:01:36 +00002687{ return year(__rhs) / __lhs; }
Marshall Clow26058352018-10-16 17:27:54 +00002688
2689
2690inline constexpr
2691year_month_weekday_last operator+(const year_month_weekday_last& __lhs, const months& __rhs) noexcept
2692{ return (__lhs.year() / __lhs.month() + __rhs) / __lhs.weekday_last(); }
2693
2694inline constexpr
2695year_month_weekday_last operator+(const months& __lhs, const year_month_weekday_last& __rhs) noexcept
2696{ return __rhs + __lhs; }
2697
2698inline constexpr
2699year_month_weekday_last operator-(const year_month_weekday_last& __lhs, const months& __rhs) noexcept
2700{ return __lhs + (-__rhs); }
2701
2702inline constexpr
2703year_month_weekday_last operator+(const year_month_weekday_last& __lhs, const years& __rhs) noexcept
2704{ return year_month_weekday_last{__lhs.year() + __rhs, __lhs.month(), __lhs.weekday_last()}; }
2705
2706inline constexpr
2707year_month_weekday_last operator+(const years& __lhs, const year_month_weekday_last& __rhs) noexcept
2708{ return __rhs + __lhs; }
2709
2710inline constexpr
2711year_month_weekday_last operator-(const year_month_weekday_last& __lhs, const years& __rhs) noexcept
2712{ return __lhs + (-__rhs); }
2713
2714inline constexpr year_month_weekday_last& year_month_weekday_last::operator+=(const months& __dm) noexcept { *this = *this + __dm; return *this; }
2715inline constexpr year_month_weekday_last& year_month_weekday_last::operator-=(const months& __dm) noexcept { *this = *this - __dm; return *this; }
2716inline constexpr year_month_weekday_last& year_month_weekday_last::operator+=(const years& __dy) noexcept { *this = *this + __dy; return *this; }
2717inline constexpr year_month_weekday_last& year_month_weekday_last::operator-=(const years& __dy) noexcept { *this = *this - __dy; return *this; }
2718
2719#endif // _LIBCPP_STD_VER > 17
Howard Hinnantc51e1022010-05-11 19:42:16 +00002720} // chrono
2721
Marshall Clowac868372013-10-05 21:18:32 +00002722#if _LIBCPP_STD_VER > 11
2723// Suffixes for duration literals [time.duration.literals]
2724inline namespace literals
Louis Dionne44bcff92018-08-03 22:36:53 +00002725{
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002726 inline namespace chrono_literals
2727 {
2728
Marshall Clow2ac805a2017-08-09 15:42:50 +00002729 constexpr chrono::hours operator""h(unsigned long long __h)
Howard Hinnant5c167562013-08-07 19:39:48 +00002730 {
2731 return chrono::hours(static_cast<chrono::hours::rep>(__h));
2732 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002733
Marshall Clow2ac805a2017-08-09 15:42:50 +00002734 constexpr chrono::duration<long double, ratio<3600,1>> operator""h(long double __h)
Howard Hinnant5c167562013-08-07 19:39:48 +00002735 {
2736 return chrono::duration<long double, ratio<3600,1>>(__h);
2737 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002738
2739
Marshall Clow2ac805a2017-08-09 15:42:50 +00002740 constexpr chrono::minutes operator""min(unsigned long long __m)
Howard Hinnant5c167562013-08-07 19:39:48 +00002741 {
2742 return chrono::minutes(static_cast<chrono::minutes::rep>(__m));
2743 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002744
Marshall Clow2ac805a2017-08-09 15:42:50 +00002745 constexpr chrono::duration<long double, ratio<60,1>> operator""min(long double __m)
Howard Hinnant5c167562013-08-07 19:39:48 +00002746 {
2747 return chrono::duration<long double, ratio<60,1>> (__m);
2748 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002749
2750
Marshall Clow2ac805a2017-08-09 15:42:50 +00002751 constexpr chrono::seconds operator""s(unsigned long long __s)
Howard Hinnant5c167562013-08-07 19:39:48 +00002752 {
2753 return chrono::seconds(static_cast<chrono::seconds::rep>(__s));
2754 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002755
Marshall Clow2ac805a2017-08-09 15:42:50 +00002756 constexpr chrono::duration<long double> operator""s(long double __s)
Howard Hinnant5c167562013-08-07 19:39:48 +00002757 {
2758 return chrono::duration<long double> (__s);
2759 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002760
2761
Marshall Clow2ac805a2017-08-09 15:42:50 +00002762 constexpr chrono::milliseconds operator""ms(unsigned long long __ms)
Howard Hinnant5c167562013-08-07 19:39:48 +00002763 {
2764 return chrono::milliseconds(static_cast<chrono::milliseconds::rep>(__ms));
2765 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002766
Marshall Clow2ac805a2017-08-09 15:42:50 +00002767 constexpr chrono::duration<long double, milli> operator""ms(long double __ms)
Howard Hinnant5c167562013-08-07 19:39:48 +00002768 {
2769 return chrono::duration<long double, milli>(__ms);
2770 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002771
2772
Marshall Clow2ac805a2017-08-09 15:42:50 +00002773 constexpr chrono::microseconds operator""us(unsigned long long __us)
Howard Hinnant5c167562013-08-07 19:39:48 +00002774 {
2775 return chrono::microseconds(static_cast<chrono::microseconds::rep>(__us));
2776 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002777
Marshall Clow2ac805a2017-08-09 15:42:50 +00002778 constexpr chrono::duration<long double, micro> operator""us(long double __us)
Howard Hinnant5c167562013-08-07 19:39:48 +00002779 {
2780 return chrono::duration<long double, micro> (__us);
2781 }
Louis Dionne44bcff92018-08-03 22:36:53 +00002782
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002783
Marshall Clow2ac805a2017-08-09 15:42:50 +00002784 constexpr chrono::nanoseconds operator""ns(unsigned long long __ns)
Howard Hinnant5c167562013-08-07 19:39:48 +00002785 {
2786 return chrono::nanoseconds(static_cast<chrono::nanoseconds::rep>(__ns));
2787 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002788
Marshall Clow2ac805a2017-08-09 15:42:50 +00002789 constexpr chrono::duration<long double, nano> operator""ns(long double __ns)
Howard Hinnant5c167562013-08-07 19:39:48 +00002790 {
2791 return chrono::duration<long double, nano> (__ns);
2792 }
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002793
Marshall Clow26058352018-10-16 17:27:54 +00002794#if _LIBCPP_STD_VER > 17 && !defined(_LIBCPP_HAS_NO_CXX20_CHRONO_LITERALS)
2795 constexpr chrono::day operator ""d(unsigned long long __d) noexcept
2796 {
2797 return chrono::day(static_cast<unsigned>(__d));
2798 }
Louis Dionne173f29e2019-05-29 16:01:36 +00002799
Marshall Clow26058352018-10-16 17:27:54 +00002800 constexpr chrono::year operator ""y(unsigned long long __y) noexcept
2801 {
2802 return chrono::year(static_cast<int>(__y));
2803 }
2804#endif
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002805}}
Marshall Clowac868372013-10-05 21:18:32 +00002806
2807namespace chrono { // hoist the literals into namespace std::chrono
2808 using namespace literals::chrono_literals;
2809}
2810
Marshall Cloweb41e5c2013-07-24 21:18:14 +00002811#endif
2812
Howard Hinnantc51e1022010-05-11 19:42:16 +00002813_LIBCPP_END_NAMESPACE_STD
2814
Eric Fiselier049273c2018-12-21 03:54:57 +00002815#ifndef _LIBCPP_CXX03_LANG
2816_LIBCPP_BEGIN_NAMESPACE_FILESYSTEM
2817struct _FilesystemClock {
2818#if !defined(_LIBCPP_HAS_NO_INT128)
2819 typedef __int128_t rep;
2820 typedef nano period;
2821#else
2822 typedef long long rep;
2823 typedef nano period;
2824#endif
2825
2826 typedef chrono::duration<rep, period> duration;
2827 typedef chrono::time_point<_FilesystemClock> time_point;
2828
2829 static _LIBCPP_CONSTEXPR_AFTER_CXX11 const bool is_steady = false;
2830
Louis Dionnef6bf76a2019-03-20 21:18:14 +00002831 _LIBCPP_AVAILABILITY_FILESYSTEM _LIBCPP_FUNC_VIS static time_point now() noexcept;
Eric Fiselier049273c2018-12-21 03:54:57 +00002832
2833 _LIBCPP_INLINE_VISIBILITY
2834 static time_t to_time_t(const time_point& __t) noexcept {
2835 typedef chrono::duration<rep> __secs;
2836 return time_t(
2837 chrono::duration_cast<__secs>(__t.time_since_epoch()).count());
2838 }
2839
2840 _LIBCPP_INLINE_VISIBILITY
2841 static time_point from_time_t(time_t __t) noexcept {
2842 typedef chrono::duration<rep> __secs;
2843 return time_point(__secs(__t));
2844 }
2845};
2846_LIBCPP_END_NAMESPACE_FILESYSTEM
2847#endif // !_LIBCPP_CXX03_LANG
2848
Eric Fiselierf4433a32017-05-31 22:07:49 +00002849_LIBCPP_POP_MACROS
2850
Howard Hinnantc51e1022010-05-11 19:42:16 +00002851#endif // _LIBCPP_CHRONO