tzfile.h revision 1.2
1/* 2 * Copyright (c) 1988 Regents of the University of California. 3 * All rights reserved. 4 * 5 * This code is derived from software contributed to Berkeley by 6 * Arthur David Olson of the National Cancer Institute. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by the University of 19 * California, Berkeley and its contributors. 20 * 4. Neither the name of the University nor the names of its contributors 21 * may be used to endorse or promote products derived from this software 22 * without specific prior written permission. 23 * 24 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 25 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34 * SUCH DAMAGE. 35 * 36 * from: @(#)tzfile.h 5.10 (Berkeley) 4/3/91 37 * $Id: tzfile.h,v 1.2 1993/08/01 18:45:09 mycroft Exp $ 38 */ 39 40#ifndef _TZFILE_H_ 41#define _TZFILE_H_ 42 43/* 44 * Information about time zone files. 45 */ 46 /* Time zone object file directory */ 47#define TZDIR "/usr/share/zoneinfo" 48#define TZDEFAULT "/etc/localtime" 49#define TZDEFRULES "posixrules" 50 51/* 52** Each file begins with. . . 53*/ 54 55struct tzhead { 56 char tzh_reserved[24]; /* reserved for future use */ 57 char tzh_ttisstdcnt[4]; /* coded number of trans. time flags */ 58 char tzh_leapcnt[4]; /* coded number of leap seconds */ 59 char tzh_timecnt[4]; /* coded number of transition times */ 60 char tzh_typecnt[4]; /* coded number of local time types */ 61 char tzh_charcnt[4]; /* coded number of abbr. chars */ 62}; 63 64/* 65** . . .followed by. . . 66** 67** tzh_timecnt (char [4])s coded transition times a la time(2) 68** tzh_timecnt (unsigned char)s types of local time starting at above 69** tzh_typecnt repetitions of 70** one (char [4]) coded GMT offset in seconds 71** one (unsigned char) used to set tm_isdst 72** one (unsigned char) that's an abbreviation list index 73** tzh_charcnt (char)s '\0'-terminated zone abbreviations 74** tzh_leapcnt repetitions of 75** one (char [4]) coded leap second transition times 76** one (char [4]) total correction after above 77** tzh_ttisstdcnt (char)s indexed by type; if TRUE, transition 78** time is standard time, if FALSE, 79** transition time is wall clock time 80** if absent, transition times are 81** assumed to be wall clock time 82*/ 83 84/* 85** In the current implementation, "tzset()" refuses to deal with files that 86** exceed any of the limits below. 87*/ 88 89/* 90** The TZ_MAX_TIMES value below is enough to handle a bit more than a 91** year's worth of solar time (corrected daily to the nearest second) or 92** 138 years of Pacific Presidential Election time 93** (where there are three time zone transitions every fourth year). 94*/ 95#define TZ_MAX_TIMES 370 96 97#define NOSOLAR /* 4BSD doesn't currently handle solar time */ 98 99#ifndef NOSOLAR 100#define TZ_MAX_TYPES 256 /* Limited by what (unsigned char)'s can hold */ 101#else 102#define TZ_MAX_TYPES 10 /* Maximum number of local time types */ 103#endif 104 105#define TZ_MAX_CHARS 50 /* Maximum number of abbreviation characters */ 106 107#define TZ_MAX_LEAPS 50 /* Maximum number of leap second corrections */ 108 109#define SECSPERMIN 60 110#define MINSPERHOUR 60 111#define HOURSPERDAY 24 112#define DAYSPERWEEK 7 113#define DAYSPERNYEAR 365 114#define DAYSPERLYEAR 366 115#define SECSPERHOUR (SECSPERMIN * MINSPERHOUR) 116#define SECSPERDAY ((long) SECSPERHOUR * HOURSPERDAY) 117#define MONSPERYEAR 12 118 119#define TM_SUNDAY 0 120#define TM_MONDAY 1 121#define TM_TUESDAY 2 122#define TM_WEDNESDAY 3 123#define TM_THURSDAY 4 124#define TM_FRIDAY 5 125#define TM_SATURDAY 6 126 127#define TM_JANUARY 0 128#define TM_FEBRUARY 1 129#define TM_MARCH 2 130#define TM_APRIL 3 131#define TM_MAY 4 132#define TM_JUNE 5 133#define TM_JULY 6 134#define TM_AUGUST 7 135#define TM_SEPTEMBER 8 136#define TM_OCTOBER 9 137#define TM_NOVEMBER 10 138#define TM_DECEMBER 11 139 140#define TM_YEAR_BASE 1900 141 142#define EPOCH_YEAR 1970 143#define EPOCH_WDAY TM_THURSDAY 144 145/* 146** Accurate only for the past couple of centuries; 147** that will probably do. 148*/ 149 150#define isleap(y) (((y) % 4) == 0 && ((y) % 100) != 0 || ((y) % 400) == 0) 151 152#endif /* !_TZFILE_H_ */ 153