1
0

__year_to_secs.c 931 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. long long __year_to_secs(long long year, int *is_leap)
  2. {
  3. if (year-2ULL <= 136) {
  4. int y = year;
  5. int leaps = (y-68)>>2;
  6. if (!((y-68)&3)) {
  7. leaps--;
  8. if (is_leap) *is_leap = 1;
  9. } else if (is_leap) *is_leap = 0;
  10. return 31536000*(y-70) + 86400*leaps;
  11. }
  12. int cycles, centuries, leaps, rem;
  13. if (!is_leap) is_leap = &(int){0};
  14. cycles = (year-100) / 400;
  15. rem = (year-100) % 400;
  16. if (rem < 0) {
  17. cycles--;
  18. rem += 400;
  19. }
  20. if (!rem) {
  21. *is_leap = 1;
  22. centuries = 0;
  23. leaps = 0;
  24. } else {
  25. if (rem >= 200) {
  26. if (rem >= 300) centuries = 3, rem -= 300;
  27. else centuries = 2, rem -= 200;
  28. } else {
  29. if (rem >= 100) centuries = 1, rem -= 100;
  30. else centuries = 0;
  31. }
  32. if (!rem) {
  33. *is_leap = 0;
  34. leaps = 0;
  35. } else {
  36. leaps = rem / 4U;
  37. rem %= 4U;
  38. *is_leap = !rem;
  39. }
  40. }
  41. leaps += 97*cycles + 24*centuries - *is_leap;
  42. return (year-100) * 31536000LL + leaps * 86400LL + 946684800 + 86400;
  43. }