blob: e0e1cca7649f689fb639104afd67651f7cbf498c [file] [log] [blame]
long long __year_to_secs(long long year, int* is_leap) {
if (year - 2ULL <= 136) {
int y = year;
int leaps = (y - 68) >> 2;
if (!((y - 68) & 3)) {
leaps--;
if (is_leap)
*is_leap = 1;
} else if (is_leap)
*is_leap = 0;
return 31536000 * (y - 70) + 86400 * leaps;
}
int cycles, centuries, leaps, rem;
if (!is_leap)
is_leap = &(int){0};
cycles = (year - 100) / 400;
rem = (year - 100) % 400;
if (rem < 0) {
cycles--;
rem += 400;
}
if (!rem) {
*is_leap = 1;
centuries = 0;
leaps = 0;
} else {
if (rem >= 200) {
if (rem >= 300)
centuries = 3, rem -= 300;
else
centuries = 2, rem -= 200;
} else {
if (rem >= 100)
centuries = 1, rem -= 100;
else
centuries = 0;
}
if (!rem) {
*is_leap = 0;
leaps = 0;
} else {
leaps = rem / 4U;
rem %= 4U;
*is_leap = !rem;
}
}
leaps += 97 * cycles + 24 * centuries - *is_leap;
return (year - 100) * 31536000LL + leaps * 86400LL + 946684800 + 86400;
}