compat_timezone.c revision 1.1 1 1.1 christos /* $NetBSD: compat_timezone.c,v 1.1 2005/09/13 01:44:09 christos Exp $ */
2 1.1 christos
3 1.1 christos /*
4 1.1 christos * Copyright (c) 1987, 1993
5 1.1 christos * The Regents of the University of California. All rights reserved.
6 1.1 christos *
7 1.1 christos * Redistribution and use in source and binary forms, with or without
8 1.1 christos * modification, are permitted provided that the following conditions
9 1.1 christos * are met:
10 1.1 christos * 1. Redistributions of source code must retain the above copyright
11 1.1 christos * notice, this list of conditions and the following disclaimer.
12 1.1 christos * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 christos * notice, this list of conditions and the following disclaimer in the
14 1.1 christos * documentation and/or other materials provided with the distribution.
15 1.1 christos * 3. Neither the name of the University nor the names of its contributors
16 1.1 christos * may be used to endorse or promote products derived from this software
17 1.1 christos * without specific prior written permission.
18 1.1 christos *
19 1.1 christos * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 1.1 christos * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 1.1 christos * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 1.1 christos * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 1.1 christos * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 1.1 christos * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 1.1 christos * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 1.1 christos * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 1.1 christos * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 1.1 christos * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 1.1 christos * SUCH DAMAGE.
30 1.1 christos */
31 1.1 christos
32 1.1 christos #include <sys/cdefs.h>
33 1.1 christos #if defined(LIBC_SCCS) && !defined(lint)
34 1.1 christos #if 0
35 1.1 christos static char sccsid[] = "@(#)timezone.c 8.1 (Berkeley) 6/4/93";
36 1.1 christos #else
37 1.1 christos __RCSID("$NetBSD: compat_timezone.c,v 1.1 2005/09/13 01:44:09 christos Exp $");
38 1.1 christos #endif
39 1.1 christos #endif /* LIBC_SCCS and not lint */
40 1.1 christos
41 1.1 christos #define __LIBC12_SOURCE__
42 1.1 christos
43 1.1 christos #include "namespace.h"
44 1.1 christos #include <sys/types.h>
45 1.1 christos #include <time.h>
46 1.1 christos #include <compat/include/time.h>
47 1.1 christos #include <stdio.h>
48 1.1 christos #include <stdlib.h>
49 1.1 christos #include <string.h>
50 1.1 christos #include <tzfile.h>
51 1.1 christos
52 1.1 christos __warn_references(timezone,
53 1.1 christos "warning: reference to compatibility timezone; include <time.h> to generate correct reference")
54 1.1 christos
55 1.1 christos /*
56 1.1 christos * timezone --
57 1.1 christos * The arguments are the number of minutes of time you are westward
58 1.1 christos * from Greenwich and whether DST is in effect. It returns a string
59 1.1 christos * giving the name of the local timezone. Should be replaced, in the
60 1.1 christos * application code, by a call to localtime.
61 1.1 christos */
62 1.1 christos
63 1.1 christos char *_tztab __P((int, int));
64 1.1 christos
65 1.1 christos static char czone[TZ_MAX_CHARS]; /* space for zone name */
66 1.1 christos
67 1.1 christos char *
68 1.1 christos timezone(zone, dst)
69 1.1 christos int zone,
70 1.1 christos dst;
71 1.1 christos {
72 1.1 christos char *beg,
73 1.1 christos *end;
74 1.1 christos
75 1.1 christos if ((beg = getenv("TZNAME")) != NULL) { /* set in environment */
76 1.1 christos if ((end = strchr(beg, ',')) != NULL) { /* "PST,PDT" */
77 1.1 christos if (dst)
78 1.1 christos return(++end);
79 1.1 christos *end = '\0';
80 1.1 christos (void)strlcpy(czone, beg, sizeof(czone));
81 1.1 christos *end = ',';
82 1.1 christos return(czone);
83 1.1 christos }
84 1.1 christos return(beg);
85 1.1 christos }
86 1.1 christos return(_tztab(zone,dst)); /* default: table or created zone */
87 1.1 christos }
88 1.1 christos
89 1.1 christos static const struct zone {
90 1.1 christos int offset;
91 1.1 christos char *stdzone;
92 1.1 christos char *dlzone;
93 1.1 christos } zonetab[] = {
94 1.1 christos { -1*60, "MET", "MET DST" }, /* Middle European */
95 1.1 christos { -2*60, "EET", "EET DST" }, /* Eastern European */
96 1.1 christos { 4*60, "AST", "ADT" }, /* Atlantic */
97 1.1 christos { 5*60, "EST", "EDT" }, /* Eastern */
98 1.1 christos { 6*60, "CST", "CDT" }, /* Central */
99 1.1 christos { 7*60, "MST", "MDT" }, /* Mountain */
100 1.1 christos { 8*60, "PST", "PDT" }, /* Pacific */
101 1.1 christos #ifdef notdef
102 1.1 christos /* there's no way to distinguish this from WET */
103 1.1 christos { 0, "GMT", 0 }, /* Greenwich */
104 1.1 christos #endif
105 1.1 christos { 0*60, "WET", "WET DST" }, /* Western European */
106 1.1 christos { -10*60, "EST", "EST" }, /* Aust: Eastern */
107 1.1 christos { -10*60+30, "CST", "CST" }, /* Aust: Central */
108 1.1 christos { -8*60, "WST", 0 }, /* Aust: Western */
109 1.1 christos { -1, NULL, NULL }
110 1.1 christos };
111 1.1 christos
112 1.1 christos /*
113 1.1 christos * _tztab --
114 1.1 christos * check static tables or create a new zone name; broken out so that
115 1.1 christos * we can make a guess as to what the zone is if the standard tables
116 1.1 christos * aren't in place in /etc. DO NOT USE THIS ROUTINE OUTSIDE OF THE
117 1.1 christos * STANDARD LIBRARY.
118 1.1 christos */
119 1.1 christos char *
120 1.1 christos _tztab(zone,dst)
121 1.1 christos int zone;
122 1.1 christos int dst;
123 1.1 christos {
124 1.1 christos const struct zone *zp;
125 1.1 christos char sign;
126 1.1 christos
127 1.1 christos for (zp = zonetab; zp->offset != -1;++zp) /* static tables */
128 1.1 christos if (zp->offset == zone) {
129 1.1 christos if (dst && zp->dlzone)
130 1.1 christos return(zp->dlzone);
131 1.1 christos if (!dst && zp->stdzone)
132 1.1 christos return(zp->stdzone);
133 1.1 christos }
134 1.1 christos
135 1.1 christos if (zone < 0) { /* create one */
136 1.1 christos zone = -zone;
137 1.1 christos sign = '+';
138 1.1 christos }
139 1.1 christos else
140 1.1 christos sign = '-';
141 1.1 christos (void)snprintf(czone, TZ_MAX_CHARS, "GMT%c%d:%02d", sign, zone / 60,
142 1.1 christos zone % 60);
143 1.1 christos return(czone);
144 1.1 christos }
145