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