NetBSD/lib/libc/time
drochner fb535ac77e Make mktime(3) work with 64-bit time_t.
The problem is that the tm_year field of "struct tm" is just an "int"
(per POSIX), and thus time_t values >  2^31*60*60*24*365 cannot
be converted. This made mktime(3) fail even if no such large time values
were passed in by user code because the algorithm does a binary search
over the time_t range which fails if a probe value cannot be converted.
To fix this, limit the time_t range to be scanned to 55 bits (which
is a bit on the safe side, but still good until y570855533).
This is more a stopgap fix, the overflow should be checked for
at other places as well (eg localtime(3)), and there are some more
limitations in timezone parsing code.
2009-01-18 10:57:15 +00:00
..
_daylight.c compat core reorg. 2005-09-13 01:44:08 +00:00
asctime.c Make the declarations of wday_name and mon_name less eccentric. I 2006-10-15 15:32:42 +00:00
checktab.awk
ctime.3
difftime.c
ialloc.c
localtime.c Make mktime(3) work with 64-bit time_t. 2009-01-18 10:57:15 +00:00
Makefile.inc Use CPPFLAGS for -D flags otherwise lint does not get it. 2005-07-16 19:36:25 +00:00
offtime.3 Add a manual page for the standard-inspired offtime(3) and friends; 2004-05-10 02:02:00 +00:00
private.h Merge tzcode2003e. 2003-12-20 00:12:05 +00:00
README
scheck.c
strftime.3 Fix typo or mispelling. 2006-06-17 04:58:14 +00:00
strftime.c merge christos-time_t 2009-01-11 02:45:45 +00:00
strptime.3 Our new syslogd seems to want to depend on %z which is a gnu extension. 2008-11-04 18:37:28 +00:00
strptime.c don't forget to use neg. 2008-11-04 21:08:33 +00:00
Theory Merge tzcode2004a. 2004-05-27 20:39:49 +00:00
time2posix.3
tz-art.htm Import tzcode2003d. 2003-10-29 20:19:13 +00:00
tz-link.htm Merge tzcode2004a. 2004-05-27 20:39:49 +00:00
tzcode2netbsd Update for tzcode2004a. 2004-05-27 20:33:31 +00:00
tzfile.5
tzfile.h
tzselect.8
tzselect.ksh
tzset.3
zdump.8 Merge tzcode2003d. 2003-10-29 20:43:27 +00:00
zdump.c Restore i18n wrapping removed in previous. 2006-12-04 17:24:40 +00:00
zic.8 Merge tzcode2003e. 2003-12-20 00:12:05 +00:00
zic.c Merge tzcode2004a. 2004-05-27 20:39:49 +00:00

@(#)README	7.11

"What time is it?" -- Richard Deacon as The King
"Any time you want it to be." -- Frank Baxter as The Scientist
					(from the Bell System film "About Time")

The 1989 update of the time zone package featured

*	POSIXization (including interpretation of POSIX-style TZ environment
	variables, provided by Guy Harris),
*	ANSIfication (including versions of "mktime" and "difftime"),
*	SVIDulation (an "altzone" variable)
*	MACHination (the "gtime" function)
*	corrections to some time zone data (including corrections to the rules
	for Great Britain and New Zealand)
*	reference data from the United States Naval Observatory for folks who
	want to do additional time zones
*	and the 1989 data for Saudi Arabia.

(Since this code will be treated as "part of the implementation" in some places
and as "part of the application" in others, there's no good way to name
functions, such as timegm, that are not part of the proposed ANSI C standard;
such functions have kept their old, underscore-free names in this update.)

And the "dysize" function has disappeared; it was present to allow compilation
of the "date" command on old BSD systems, and a version of "date" is now
provided in the package.  The "date" command is not created when you "make all"
since it may lack options provided by the version distributed with your
operating system, or may not interact with the system in the same way the
native version does.

Since POSIX frowns on correct leap second handling, the default behavior of
the "zic" command (in the absence of a "-L" option) has been changed to omit
leap second information from its output files.

Here is a recipe for acquiring, building, installing, and testing the
tz distribution on a GNU/Linux or similar host.

	mkdir tz
	cd tz
	wget 'ftp://elsie.nci.nih.gov/pub/tz*.tar.gz'
	gzip -dc tzcode*.tar.gz | tar -xf -
	gzip -dc tzdata*.tar.gz | tar -xf -

Be sure to read the comments in "Makefile" and make any changes needed
to make things right for your system, especially if you are using some
platform other than GNU/Linux.  Then run the following commands,
substituting your desired installation directory for "$HOME/tzdir":

	make TOPDIR=$HOME/tzdir install
	$HOME/tzdir/etc/zdump -v America/Los_Angeles

To use the new functions, use a "-ltz" option when compiling or linking.

Historical local time information has been included here not because it
is particularly useful, but rather to:

*	give an idea of the variety of local time rules that have
	existed in the past and thus an idea of the variety that may be
	expected in the future;

*	provide a test of the generality of the local time rule description
	system.

The information in the time zone data files is by no means authoritative;
if you know that the rules are different from those in a file, by all means
feel free to change file (and please send the changed version to
tz@elsie.nci.nih.gov for use in the future).  Europeans take note!

Thanks to these Timezone Caballeros who've made major contributions to the
time conversion package:  Keith Bostic; Bob Devine; Paul Eggert; Robert Elz;
Guy Harris; Mark Horton; John Mackin; and Bradley White.  Thanks also to
Michael Bloom, Art Neilson, Stephen Prince, John Sovereign, and Frank Wales
for testing work, and to Gwillim Law for checking local mean time data.
None of them are responsible for remaining errors.

Look in the ~ftp/pub directory of elsie.nci.nih.gov
for updated versions of these files.

Please send comments or information to tz@elsie.nci.nih.gov.