tzfile.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. #ifndef TZFILE_H
  2. #define TZFILE_H
  3. /*
  4. ** This file is in the public domain, so clarified as of
  5. ** 1996-06-05 by Arthur David Olson.
  6. */
  7. /*
  8. ** This header is for use ONLY with the time conversion code.
  9. ** There is no guarantee that it will remain unchanged,
  10. ** or that it will remain at all.
  11. ** Do NOT copy it to any system include directory.
  12. ** Thank you!
  13. */
  14. /*
  15. ** ID
  16. */
  17. #ifndef lint
  18. #ifndef NOID
  19. static char __attribute__((unused)) tzfilehid[] = "@(#)tzfile.h 8.1";
  20. #endif /* !defined NOID */
  21. #endif /* !defined lint */
  22. /*
  23. ** Information about time zone files.
  24. */
  25. #ifndef TZDIR
  26. #ifdef SOLARIS
  27. #define TZDIR "/usr/share/lib/zoneinfo"
  28. #else
  29. #define TZDIR "/usr/share/zoneinfo"
  30. #endif /* defined SOLARIS */
  31. #endif /* !defined TZDIR */
  32. #ifndef TZDEFAULT
  33. #define TZDEFAULT "localtime"
  34. #endif /* !defined TZDEFAULT */
  35. #ifndef TZDEFRULES
  36. #define TZDEFRULES "posixrules"
  37. #endif /* !defined TZDEFRULES */
  38. /*
  39. ** Each file begins with. . .
  40. */
  41. #define TZ_MAGIC "TZif"
  42. struct tzhead {
  43. char tzh_magic[4]; /* TZ_MAGIC */
  44. char tzh_version[1]; /* '\0' or '2' as of 2005 */
  45. char tzh_reserved[15]; /* reserved--must be zero */
  46. char tzh_ttisgmtcnt[4]; /* coded number of trans. time flags */
  47. char tzh_ttisstdcnt[4]; /* coded number of trans. time flags */
  48. char tzh_leapcnt[4]; /* coded number of leap seconds */
  49. char tzh_timecnt[4]; /* coded number of transition times */
  50. char tzh_typecnt[4]; /* coded number of local time types */
  51. char tzh_charcnt[4]; /* coded number of abbr. chars */
  52. };
  53. /*
  54. ** . . .followed by. . .
  55. **
  56. ** tzh_timecnt (char [4])s coded transition times a la time(2)
  57. ** tzh_timecnt (unsigned char)s types of local time starting at above
  58. ** tzh_typecnt repetitions of
  59. ** one (char [4]) coded UTC offset in seconds
  60. ** one (unsigned char) used to set tm_isdst
  61. ** one (unsigned char) that's an abbreviation list index
  62. ** tzh_charcnt (char)s '\0'-terminated zone abbreviations
  63. ** tzh_leapcnt repetitions of
  64. ** one (char [4]) coded leap second transition times
  65. ** one (char [4]) total correction after above
  66. ** tzh_ttisstdcnt (char)s indexed by type; if TRUE, transition
  67. ** time is standard time, if FALSE,
  68. ** transition time is wall clock time
  69. ** if absent, transition times are
  70. ** assumed to be wall clock time
  71. ** tzh_ttisgmtcnt (char)s indexed by type; if TRUE, transition
  72. ** time is UTC, if FALSE,
  73. ** transition time is local time
  74. ** if absent, transition times are
  75. ** assumed to be local time
  76. */
  77. /*
  78. ** If tzh_version is '2' or greater, the above is followed by a second instance
  79. ** of tzhead and a second instance of the data in which each coded transition
  80. ** time uses 8 rather than 4 chars,
  81. ** then a POSIX-TZ-environment-variable-style string for use in handling
  82. ** instants after the last transition time stored in the file
  83. ** (with nothing between the newlines if there is no POSIX representation for
  84. ** such instants).
  85. */
  86. /*
  87. ** In the current implementation, "tzset()" refuses to deal with files that
  88. ** exceed any of the limits below.
  89. */
  90. #ifndef TZ_MAX_TIMES
  91. #define TZ_MAX_TIMES 1200
  92. #endif /* !defined TZ_MAX_TIMES */
  93. #ifndef TZ_MAX_TYPES
  94. #ifndef NOSOLAR
  95. #define TZ_MAX_TYPES 256 /* Limited by what (unsigned char)'s can hold */
  96. #endif /* !defined NOSOLAR */
  97. #ifdef NOSOLAR
  98. /*
  99. ** Must be at least 14 for Europe/Riga as of Jan 12 1995,
  100. ** as noted by Earl Chew.
  101. */
  102. #define TZ_MAX_TYPES 20 /* Maximum number of local time types */
  103. #endif /* !defined NOSOLAR */
  104. #endif /* !defined TZ_MAX_TYPES */
  105. #ifndef TZ_MAX_CHARS
  106. #define TZ_MAX_CHARS 50 /* Maximum number of abbreviation characters */
  107. /* (limited by what unsigned chars can hold) */
  108. #endif /* !defined TZ_MAX_CHARS */
  109. #ifndef TZ_MAX_LEAPS
  110. #define TZ_MAX_LEAPS 50 /* Maximum number of leap second corrections */
  111. #endif /* !defined TZ_MAX_LEAPS */
  112. #define SECSPERMIN 60
  113. #define MINSPERHOUR 60
  114. #define HOURSPERDAY 24
  115. #define DAYSPERWEEK 7
  116. #define DAYSPERNYEAR 365
  117. #define DAYSPERLYEAR 366
  118. #define SECSPERHOUR (SECSPERMIN * MINSPERHOUR)
  119. #define SECSPERDAY ((long) SECSPERHOUR * HOURSPERDAY)
  120. #define MONSPERYEAR 12
  121. #define TM_SUNDAY 0
  122. #define TM_MONDAY 1
  123. #define TM_TUESDAY 2
  124. #define TM_WEDNESDAY 3
  125. #define TM_THURSDAY 4
  126. #define TM_FRIDAY 5
  127. #define TM_SATURDAY 6
  128. #define TM_JANUARY 0
  129. #define TM_FEBRUARY 1
  130. #define TM_MARCH 2
  131. #define TM_APRIL 3
  132. #define TM_MAY 4
  133. #define TM_JUNE 5
  134. #define TM_JULY 6
  135. #define TM_AUGUST 7
  136. #define TM_SEPTEMBER 8
  137. #define TM_OCTOBER 9
  138. #define TM_NOVEMBER 10
  139. #define TM_DECEMBER 11
  140. #define TM_YEAR_BASE 1900
  141. #define EPOCH_YEAR 1970
  142. #define EPOCH_WDAY TM_THURSDAY
  143. #define isleap(y) (((y) % 4) == 0 && (((y) % 100) != 0 || ((y) % 400) == 0))
  144. /*
  145. ** Since everything in isleap is modulo 400 (or a factor of 400), we know that
  146. ** isleap(y) == isleap(y % 400)
  147. ** and so
  148. ** isleap(a + b) == isleap((a + b) % 400)
  149. ** or
  150. ** isleap(a + b) == isleap(a % 400 + b % 400)
  151. ** This is true even if % means modulo rather than Fortran remainder
  152. ** (which is allowed by C89 but not C99).
  153. ** We use this to avoid addition overflow problems.
  154. */
  155. #define isleap_sum(a, b) isleap((a) % 400 + (b) % 400)
  156. #endif /* !defined TZFILE_H */