NAME

Time::y2038 - Versions of Perl's time functions which work beyond 2038

SYNOPSIS

use Time::y2038;

print scalar gmtime 2**52;  # Sat Dec  6 03:48:16 142715360

DESCRIPTION

On many computers, Perl's time functions will not work past the year 2038. This is a design fault in the underlying C libraries Perl uses. Time::y2038 provides replacements for those functions which will work accurately +/1 142 million years.

This only imports the functions into your namespace. To replace it everywhere, see Time::y2038::Everywhere.

Replaces the following functions:

gmtime()

See "gmtime" in perlfunc for details.

localtime()

See "localtime" in perlfunc for details.

timegm()

my $time = timegm($sec, $min, $hour, $month_day, $month, $year);

The inverse of gmtime(), takes a date and returns the coorsponding $time (number of seconds since Midnight, January 1st, 1970 GMT). All values are the same as gmtime() so $month is 0..11 (January is 0) and the $year is years since 1900 (2008 is 108).

# June 4, 1906 03:02:01 GMT
my $time = timegm(1, 2, 3, 4, 5, 6);

timegm() can take two additional arguments which are always ignored. This lets you feed the results from gmtime() back into timegm() without having to strip the arguments off.

The following is always true:

timegm(gmtime($time)) == $time;

timelocal()

my $time = timelocal($sec, $min, $hour, $mday, $month, $year);

Like timegm(), but interprets the date in the current time zone.

LIMITATIONS

The safe range of times is +/ 2**52 (about 142 million years).

Although the underlying time library can handle times from -2**63 to 2**63-1 (about +/- 292 billion years) Perl uses floating point numbers internally and so accuracy degrates after 2**52.

BUGS & FEEDBACK

See http://rt.cpan.org to report and view bugs.

If you like the module, please drop the author an email.

AUTHOR

Michael G Schwern <schwern@pobox.com>

LICENSE & COPYRIGHT

Copyright 2008 Michael G Schwern

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

See http://www.perl.com/perl/misc/Artistic.html

SEE ALSO

Time::y2038::Everywhere overrides localtime() and gmtime() across the whole program.

The y2038 project at http://y2038.googlecode.com/