51 constexpr int64_t BIAS_292277022000 = 9223371890843040000LL;
52 constexpr int64_t BIAS_2000 = 946684800LL;
55 int64_t secs = -((
static_cast<int64_t
>(
ts) - BIAS_2000) - BIAS_292277022000);
59 y -= n_400_years * 400LL;
63 y -= n_100_years * 100LL;
82 date_time.year = y - 1;
87 constexpr int JAN_AND_FEB_DAY_LEAP_YEAR = 60 - 1;
88 constexpr int TABLE_MONTH_OF_YEAR[] = {
89 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
90 2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,
91 3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,
92 4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,
93 5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,
94 6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,
95 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,
96 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,
97 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,
98 10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,
99 11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,
100 12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,
102 constexpr int TABLE_DAY_OF_YEAR[] = {
103 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
104 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,
105 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
106 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,
107 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
108 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,
109 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
110 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
111 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,
112 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
113 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,
114 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
118 const int prev_days =
days - 1;
119 date_time.day =
days == JAN_AND_FEB_DAY_LEAP_YEAR ? (TABLE_DAY_OF_YEAR[prev_days] + 1) :
120 (
days > JAN_AND_FEB_DAY_LEAP_YEAR ? TABLE_DAY_OF_YEAR[prev_days] : TABLE_DAY_OF_YEAR[
days]);
121 date_time.mon =
days >= JAN_AND_FEB_DAY_LEAP_YEAR ? TABLE_MONTH_OF_YEAR[prev_days] : TABLE_MONTH_OF_YEAR[
days];
123 date_time.day = TABLE_DAY_OF_YEAR[
days];
124 date_time.mon = TABLE_MONTH_OF_YEAR[
days];
128 date_time.hour =
static_cast<decltype(date_time.hour)
>(day_secs /
SEC_PER_HOUR);
130 date_time.min =
static_cast<decltype(date_time.min)
>(min_secs /
SEC_PER_MIN);
131 date_time.sec =
static_cast<decltype(date_time.sec)
>(min_secs - date_time.min *
SEC_PER_MIN);
132# ifdef TIME_SHIELD_CPP17
133 if TIME_SHIELD_IF_CONSTEXPR (std::is_floating_point<T2>::value) {
134 date_time.ms =
static_cast<int>(std::round(std::fmod(
static_cast<double>(
ts),
static_cast<double>(
MS_PER_SEC))));
135 }
else date_time.ms = 0;
137 if (std::is_floating_point<T2>::value) {
138 date_time.ms =
static_cast<int>(std::round(std::fmod(
static_cast<double>(
ts),
static_cast<double>(
MS_PER_SEC))));
139 }
else date_time.ms = 0;