Formerly ../time/sys/time.h.~16~
[kopensolaris-gnu/glibc.git] / time / tzfile.h
1 #ifndef TZFILE_H
2
3 #define TZFILE_H
4
5 /*
6 ** This header is for use ONLY with the time conversion code.
7 ** There is no guarantee that it will remain unchanged,
8 ** or that it will remain at all.
9 ** Do NOT copy it to any system include directory.
10 ** Thank you!
11 */
12
13 /*
14 ** ID
15 */
16
17 #ifndef lint
18 #ifndef NOID
19 static char     tzfilehid[] = "@(#)tzfile.h     7.4";
20 #endif /* !defined NOID */
21 #endif /* !defined lint */
22
23 /*
24 ** Information about time zone files.
25 */
26
27 #ifndef TZDIR
28 #define TZDIR   "/usr/local/etc/zoneinfo" /* Time zone object file directory */
29 #endif /* !defined TZDIR */
30
31 #ifndef TZDEFAULT
32 #define TZDEFAULT       "localtime"
33 #endif /* !defined TZDEFAULT */
34
35 #ifndef TZDEFRULES
36 #define TZDEFRULES      "posixrules"
37 #endif /* !defined TZDEFRULES */
38
39 /*
40 ** Each file begins with. . .
41 */
42
43 struct tzhead {
44         char    tzh_reserved[24];       /* reserved for future use */
45         char    tzh_ttisstdcnt[4];      /* coded number of trans. time flags */
46         char    tzh_leapcnt[4];         /* coded number of leap seconds */
47         char    tzh_timecnt[4];         /* coded number of transition times */
48         char    tzh_typecnt[4];         /* coded number of local time types */
49         char    tzh_charcnt[4];         /* coded number of abbr. chars */
50 };
51
52 /*
53 ** . . .followed by. . .
54 **
55 **      tzh_timecnt (char [4])s         coded transition times a la time(2)
56 **      tzh_timecnt (unsigned char)s    types of local time starting at above
57 **      tzh_typecnt repetitions of
58 **              one (char [4])          coded GMT offset in seconds
59 **              one (unsigned char)     used to set tm_isdst
60 **              one (unsigned char)     that's an abbreviation list index
61 **      tzh_charcnt (char)s             '\0'-terminated zone abbreviations
62 **      tzh_leapcnt repetitions of
63 **              one (char [4])          coded leap second transition times
64 **              one (char [4])          total correction after above
65 **      tzh_ttisstdcnt (char)s          indexed by type; if TRUE, transition
66 **                                      time is standard time, if FALSE,
67 **                                      transition time is wall clock time
68 **                                      if absent, transition times are
69 **                                      assumed to be wall clock time
70 */
71
72 /*
73 ** In the current implementation, "tzset()" refuses to deal with files that
74 ** exceed any of the limits below.
75 */
76
77 #ifndef TZ_MAX_TIMES
78 /*
79 ** The TZ_MAX_TIMES value below is enough to handle a bit more than a
80 ** year's worth of solar time (corrected daily to the nearest second) or
81 ** 138 years of Pacific Presidential Election time
82 ** (where there are three time zone transitions every fourth year).
83 */
84 #define TZ_MAX_TIMES    370
85 #endif /* !defined TZ_MAX_TIMES */
86
87 #ifndef TZ_MAX_TYPES
88 #ifndef NOSOLAR
89 #define TZ_MAX_TYPES    256 /* Limited by what (unsigned char)'s can hold */
90 #endif /* !defined NOSOLAR */
91 #ifdef NOSOLAR
92 #define TZ_MAX_TYPES    10      /* Maximum number of local time types */
93 #endif /* !defined NOSOLAR */
94 #endif /* !defined TZ_MAX_TYPES */
95
96 #ifndef TZ_MAX_CHARS
97 #define TZ_MAX_CHARS    50      /* Maximum number of abbreviation characters */
98                                 /* (limited by what unsigned chars can hold) */
99 #endif /* !defined TZ_MAX_CHARS */
100
101 #ifndef TZ_MAX_LEAPS
102 #define TZ_MAX_LEAPS    50      /* Maximum number of leap second corrections */
103 #endif /* !defined TZ_MAX_LEAPS */
104
105 #define SECSPERMIN      60
106 #define MINSPERHOUR     60
107 #define HOURSPERDAY     24
108 #define DAYSPERWEEK     7
109 #define DAYSPERNYEAR    365
110 #define DAYSPERLYEAR    366
111 #define SECSPERHOUR     (SECSPERMIN * MINSPERHOUR)
112 #define SECSPERDAY      ((long) SECSPERHOUR * HOURSPERDAY)
113 #define MONSPERYEAR     12
114
115 #define TM_SUNDAY       0
116 #define TM_MONDAY       1
117 #define TM_TUESDAY      2
118 #define TM_WEDNESDAY    3
119 #define TM_THURSDAY     4
120 #define TM_FRIDAY       5
121 #define TM_SATURDAY     6
122
123 #define TM_JANUARY      0
124 #define TM_FEBRUARY     1
125 #define TM_MARCH        2
126 #define TM_APRIL        3
127 #define TM_MAY          4
128 #define TM_JUNE         5
129 #define TM_JULY         6
130 #define TM_AUGUST       7
131 #define TM_SEPTEMBER    8
132 #define TM_OCTOBER      9
133 #define TM_NOVEMBER     10
134 #define TM_DECEMBER     11
135
136 #define TM_YEAR_BASE    1900
137
138 #define EPOCH_YEAR      1970
139 #define EPOCH_WDAY      TM_THURSDAY
140
141 /*
142 ** Accurate only for the past couple of centuries;
143 ** that will probably do.
144 */
145
146 #define isleap(y) ((((y) % 4) == 0 && ((y) % 100) != 0) || ((y) % 400) == 0)
147
148 #ifndef USG
149
150 /*
151 ** Use of the underscored variants may cause problems if you move your code to
152 ** certain System-V-based systems; for maximum portability, use the
153 ** underscore-free variants.  The underscored variants are provided for
154 ** backward compatibility only; they may disappear from future versions of
155 ** this file.
156 */
157
158 #define SECS_PER_MIN    SECSPERMIN
159 #define MINS_PER_HOUR   MINSPERHOUR
160 #define HOURS_PER_DAY   HOURSPERDAY
161 #define DAYS_PER_WEEK   DAYSPERWEEK
162 #define DAYS_PER_NYEAR  DAYSPERNYEAR
163 #define DAYS_PER_LYEAR  DAYSPERLYEAR
164 #define SECS_PER_HOUR   SECSPERHOUR
165 #define SECS_PER_DAY    SECSPERDAY
166 #define MONS_PER_YEAR   MONSPERYEAR
167
168 #endif /* !defined USG */
169
170 #endif /* !defined TZFILE_H */