1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- 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;
- }
|