NAME
Date - fast Date framework with timezone and microseconds support, with Perl and C++ interface.
DESCRIPTION
Date is almost fully compatible with Class::Date, but has several more features and much greater perfomance. It is written fully in C++.
Date supports dates between -2147483648/01/01 00:00:00 and 2147483647/12/31 23:59:59 (on 64bit perls).
With Date you can perform some operations even faster than in plain C program using stdlibc functions. See Time::XS why.
SYNOPSIS
use Time::XS qw/tzset/;
use Date qw/now now_hires date today rdate idate :const/;
my $date = Date->new($epoch); # using server's local timezone
$date = Date->new([$y,$m,$d,$h,$m,$s]);
$date = Date->new({year => $y, month => $m, day => $d, hour => $h, min => $m, sec => $s, mksec => $mks});
$date = Date->new("2013-03-05 23:45:56");
$date = Date->new("2013-03-05 23:45:56.345");
$date = now(); # same as Date->new(time()) but faster
$date = today(); # same as Date->new(time())->truncate but faster
$date = now_hires(); # current time with microseconds
# create using function 'date'
tzset('Europe/Moscow'); # using 'Europe/Moscow' as server's local timezone
$date = date [$year,$month,$day,$hour,$min,$sec];
$date = date { year => $year, month => $month, day => $day, hour => $hour, min => $min, sec => $sec };
$date = date "2001/11/12 07:13:12";
$date = date 123456789;
$date = date("2001/11/12 07:13:12", 'America/New_York'); # $date operates in custom time zone
# creating relative date object
# (normally you don't need to create this object explicitly)
$reldate = new Date::Rel "3Y 1M 3D 6h 2m 4s";
$reldate = new Date::Rel "6Y";
$reldate = new Date::Rel $secs; # secs
$reldate = new Date::Rel [$year,$month,$day,$hour,$min,$sec];
$reldate = new Date::Rel { year => $year, month => $month, day => $day, hour => $hour, min => $min, sec => $sec };
$reldate = rdate "-1M -3D 6h";
$reldate = 3*MONTH; # "3M"
$reldate = 2*YEAR + MONTH - 30*DAY; # "2Y 1M -30D"
print $reldate/2; # 1Y 5h 14m 32s
$reldate = YEAR/2 + HOUR/2; # 6M 30m
$date; # prints the date in default output format (ISO/SQL format)
$date->epoch; # unix timestamp
$date->year; # year, e.g: 2001
$date->_year; # year - 1900, e.g. 101
$date->yr; # 2-digit year 0-99, e.g 1
$date->mon; # month 1..12
$date->month; # same as prev.
$date->_mon; # month 0..11
$date->_month; # same as prev.
$date->day; # day of month
$date->mday; # day of month
$date->day_of_month;# same as prev.
$date->hour;
$date->min;
$date->minute; # same as prev.
$date->sec;
$date->second; # same as prev.
$date->mksec;
$date->wday; # 1 = Sunday
$date->day_of_week; # same as prev.
$date->_wday; # 0 = Sunday
$date->ewday; # 1 = Monday, 7 = Sunday
$date->yday; # [1-366]
$date->day_of_year; # same as prev.
$date->_yday; # [0-365]
$date->isdst; # DST?
$date->daylight_savings; # same as prev.
$date->strftime($format);
$date->monname; # name of month, eg: March
$date->monthname; # same as prev.
$date->wdayname; # Thursday
$date->day_of_weekname # same as prev.
$date->hms # 01:23:45
$date->ymd # 2000/02/29
$date->mdy # 02/29/2000
$date->dmy # 29/02/2000
$date->meridiam # 01:23 AM
$date->ampm # AM/PM
$date->string # 2000-02-29 12:21:11 (format can be changed)
"$date" # same as prev.
$date->iso # 2000-02-29 12:21:11
$date->gmtoff # current offset from UTC (in seconds)
$date->tzname # returns the timezone name (EST, EET, etc)
$date->tzlocal # true if $date is in local time zone
$date->tz # returns timezone info
$date->tz('GMT+5') # changes $date's timezone (saving YMDhms)
$date->to_tz('UTC') # changes $date's timezone (saving epoch)
($year,$month,$day,$hour,$min,$sec)=$date->array;
($year,$month,$day,$hour,$min,$sec)=@{ $date->aref };
# !! $year: 1900-, $month: 1-12
($sec,$min,$hour,$day,$mon,$year,$wday,$yday,$isdst)=$date->struct;
($sec,$min,$hour,$day,$mon,$year,$wday,$yday,$isdst)=@{ $date->sref };
# !! $year: 0-, $month: 0-11
%hash=$date->hash;
# !! $hash{year}: 1900-, $hash{month}: 1-12
$hash=$date->href; # $hash can be reused as a constructor
print $hash->{year}."-".$hash->{month}. ... $hash->{sec} ... ;
# constructing new date based on an existing one:
$new_date = $date->clone;
$new_date = $date->clone({year => 1977, sec => 14, tz => 'Australia/Melbourne'});
# valid keys: year, _year, month, _month, day, hour, min, sec, tz
$date->month_begin # First day of the month (date object)
$date->month_end # Last day of the month
$date->days_in_month # 28..31
# changing date stringify format globally
Date::string_format("%Y%m%d%H%M%S");
print $date # result: 20011222000000
Date::string_format(undef);
print $date # result: 2000-02-29 12:21:11
Date::string_format("%Y/%m/%d");
print $date # result: 1994/10/13
# error handling
$a = date($date_string);
if ($a) { # valid date
...
} else { # invalid date
if ($a->error == E_UNPARSABLE) { ... }
print $a->errstr;
}
# date range check
Date::range_check(0); # this is the default
print date("2001-02-31"); # will print 2001-03-03
Date::range_check(1);
print date("2001-02-31"); # will print nothing
# getting values of a relative date object
int($reldate); # reldate in seconds (assumed 1 month = 2_629_744 secs)
"$reldate"; # reldate in "1Y 2M 3D 4h 5m 6s" format
$reldate->year;
$reldate->mon;
$reldate->month; # same as prev.
$reldate->day;
$reldate->hour;
$reldate->min;
$reldate->minute; # same as prev.
$reldate->sec; # same as $reldate
$reldate->second; # same as prev.
$reldate->to_sec; # relative date in seconds
$reldate->to_min; # relative date in minutes
$reldate->to_hour; # relative date in hours
$reldate->to_day; # relative date in days
$reldate->to_month; # relative date in months
$reldate->to_year; # relative date in years
# arithmetic with dates:
print date([2001,12,11,4,5,6])->truncate; # will print "2001-12-11"
$new_date = $date+$reldate;
$date2 = $date+'3Y 2D'; # 3 Years and 2 days
$date3 = $date+[1,2,3]; # $date plus 1 year, 2 months, 3 days
$new_date = $date-$reldate;
$date2 = $date-'3Y'; # 3 Yearss
$date3 = $date-[1,2,3]; # $date minus 1 year, 2 months, 3 days
$intdate = $date1-$date2;
$intdate2 = date('2000-11-12')-'2000-11-10';
$intdate3 = $date3-'1977-11-10';
$intdate = date("2013-10-25") - "2012-03-10";
$intdate->from; # lower date in interval (2012-03-10)
$intdate->till; # upper date in interval (2013-10-25)
$reldate = $intdate->relative; # relative date ("1Y 7M 15D")
$intdate->sec; # accurate number of seconds in interval
$intdate->month; # accurate number of months in interval
$reldate->to_sec; # number of seconds in relative date (inaccurate)
$intdate->includes("2013-01-01") # returns -1, 0, or 1
$days_between = (Class::Date->new('2001-11-12')-'2001-07-04')->day;
# comparison between absolute dates
print $date1 > $date2 ? "I am older" : "I am younger";
# comparison between relative dates
print $reldate1 > $reldate2 ? "I am faster" : "I am slower";
# Adding / Subtracting months and years are sometimes tricky:
print date("2001-01-29") + '1M' - '1M'; # gives "2001-02-01"
print date("2000-02-29") + '1Y' - '1Y'; # gives "2000-03-01"
# Named interface ($date2 does not necessary to be a Class::Date object)
$date1->string; # same as $date1 in scalar context
$date1->subtract($date2); # same as $date1 -= $date2
$date1->subtract_new($date2); # same as $date1 - $date2
$date1->add($date2); # same as $date1 += $date2
$date1->add_new($date2); # same as $date1 + $date2
$date1->compare($date2); # same as $date1 <=> $date2
$reldate1->sec; # same as $reldate1 in numeric or scalar context
$reldate1->compare($reldate2);# same as $reldate1 <=> $reldate2
$reldate1->add($reldate2); # same as $reldate1 + $reldate2
$reldate1->neg # used for subtraction
CLASS METHODS
new($epoch | \@ymdhms | \%ymdhms | $iso_fmt | $date, [$timezone])
Creates a date object.
If $timezone is present, created object will operate as if tzset($timezone)
was called, but without calling tzset()
.
If $timezone is absent (or undef or ""), $date uses local timezone. Further changes of local timezone via tzset()
won't affect constructed object.
- 123456 or "123456" or 123456.789
-
Treated as UNIX timestamp (64-bit int or double with mksecs). To define a date below 1970 year, use negative timestamp.
- [$year, $month, $day, $hour, $min, $sec, $mksec]
-
If some args are missing, will use defaults [2000,1,1,0,0,0,0]
- {year => x, month => x, day => x, hour => x, min => x, sec => x, mksec => x}
-
If some args are missing, will use defaults defined in previous section.
- ISO 8601 and some additional formats
-
- YYYY-
- YYYY/
- YYYY-MM
- YYYY/MM
- YYYY-MM-DD
- YYYY/MM/DD
- YYYYMMDD
- YYYY-MM-DD hh
- YYYY/MM/DD hh
- YYYY-MM-DD hh:mm[:ss][.mks][±hh[:]mm]
- YYYY/MM/DD hh:mm[:ss][.mks][±hh[:]mm]
- YYYYMMDDThhmmss[.mks][±hh[:]mm]
- YYYY-MM-DDThh:mm:ss[.mks][±hh[:]mm]
If timezone offset designator is present, the date is created in unnamed timezone with constant offset from GMT (no transition rules). If you pass your own timezone (second parameter to constructor or set()) in this case, it will be ignored (your parameter).
- Another date object
-
Clones another object.
If $timezone parameter is absent (or undef or ""), newly created date will use $date's timezone. Otherwise constructed date is converted to timezone $timezone preserving YMDhms information.
If there is any error while creating an object, properties error() and errstr() will be set and the date is set to epoch=0. The object itself will return false in boolean context, empty string in string context and so on.
FUNCTIONS
now()
Same as Date->new(time()) but runs faster.
now_hires()
Same as Date->new(Time::HiRes::time()) but runs faster.
today()
Same as Date->new(time())->truncate but runs faster.
today_epoch()
Same as today()->epoch but runs faster.
string_format([$format])
strftime-compatible format that is used to stringify the date with '.', "", to_string(), string() or as_string(). If it's false (the default) then iso() is used.
range_check([$true_false])
If parts of the date are invalid or the whole date is not valid, e.g. 2001-02-31 then:
when range_check is not set (the default), then these date values are automatically converted to a valid date (normalized): 2001-03-03
when range_check is set, then a date "2001-02-31" became invalid date and error() is set to E_RANGE.
date($epoch | \@ymdhms | \%ymdhms | $iso_fmt | $date, [$timezone])
Same as Date->new($arg, [$timezone])
rdate($rel_string | $seconds | \@rel_array | \%rel_hash | $reldate)
Same as Date::Rel->new($arg)
rdate($from, $till)
Same as Date::Rel->new($from, $till)
idate($epoch | \@ymdhms | \%ymdhms | $iso_fmt | $date, $epoch | \@ymdhms | \%ymdhms | $iso_fmt | $date)
Same as Date::Int->new($arg1, $arg2)
OBJECT METHODS
set($epoch | \@ymdhms | \%ymdhms | $iso_fmt | $date)
Set date from argument or another date. This is much faster than creating new object.
epoch([$epoch])
Get or set UNIX timestamp (integer or double with mksecs)
epoch_sec ()
Get UNIX timestamp without microseconds as integer.
year([$year])
Get or set Year [-2**31, 2**31-1]
_year([$year])
Get or set Year (year() - 1900)
yr([$yr])
Get or set last 2 digits of the year [0-99]
month([$mon]), mon
Get or set month [1-12]
_month([$mon]), _mon
Get or set month [0-11]
day([$day]), mday, day_of_month
Get or set day of month [1-31]
hour([$hour])
Get or set hours [0-23]
min([$min]), minute
Get or set minutes [0-59]
sec([$sec]), second
Get or set seconds [0-60]
mksec([$mksec])
Get or set microseconds [0-999999]
wday([$wday]), day_of_week
Day of week. 1 = Sunday, 2 = Monday, ... , 7 = Saturday. If you pass an argument then another day of the same week will be set.
_wday([$_wday])
Day of week. 0 = Sunday, 1 = Monday, ... , 6 = Saturday. If you pass an argument then another day of the same week will be set.
ewday([$ewday])
Day of week (Europe-friendly). 1 = Monday, ..., 7 = Sunday. If you pass an argument then another day of the same week will be set.
yday([$yday]), day_of_year
Day of the year [1-366]. If you pass an argument then another day of the same year will be set.
_yday([$_yday])
Day of the year [0-365]. If you pass an argument then another day of the same year will be set.
isdst(), daylight_savings()
Is daylight savings time in effect now (true/false).
strftime($format)
Works like strftime from C POSIX
monthname(), monname()
Full name of the month in the genitive
wdayname(), day_of_weekname()
Full name of the day in the nominative case.
hms()
Same as strftime('%H:%M:%S')
but much faster
ymd()
Same as strftime('%Y/%m/%d')
but much faster
mdy()
Same as strftime('%m/%d/%Y')
but much faster
dmy()
Same as strftime('%d/%m/%Y')
but much faster
"", to_string(), string(), as_string()
By default returns iso()
. String format can be changed via string_format()
'bool', to_bool()
Called implicitly in boolean context
if ($date)
$date ? EXPR1 : EXPR2
$date && $something
Returns TRUE if date has no errors (i.e. has no parsing or out of range errors, etc), otherwise FALSE
'0+', to_number()
Returns epoch()
in numeric context
iso(), sql()
Return date in format YYYY-MM-DD HH:MM:SS[.MKS]. Microseconds part will be absent if mksec == 0.
iso_sec()
Same as iso() but ignores microseconds part.
mysql()
Same as strftime('%Y%m%d%H%M%S')
but much faster
ampm()
Returns string 'AM' or 'PM'
meridiam()
Returns time in "11:35 AM" format (american 12h style)
gmtoff()
Returns current timezone offset from UTC in seconds
tzname()
Returns the name of the object's timezone (Europe/Moscow, America/New_York, etc).
tzabbr()
Returns timezone abbreviation (EST, EET, etc) - may change when the date changes isdst/nodst.
tzlocal()
Returns TRUE if this object's timezone is set as local.
tz([$newzone])
With no arguments returns information about object's timezone. See "tzget([$zone])" in Time::XS.
With argument changes the timezone of current object to $newzone preserving YMDhms information (epoch may change) and returns nothing.
to_tz($newzone)
Changes the timezone of current object to $newzone in a way that changed date still points to the same time moment (same epoch). YMDhms info may change. Returns nothing.
array()
Returns elements list - $year,$month,$day,$hour,$min,$sec,[$mksec]. $year is year() [2013=2013] $month is month() [1-12] If $mksec == 0 it will not be on the list
aref()
Same as [array()] (array reference)
struct()
Returns elements list - $sec,$min,$hour,$day,$mon,$year,$wday,$yday,$isdst $year is _year() [113 = 2013] $month is _month() [0-11] $wday is _wday() [0-6] $yday is _yday() [0-365]
sref()
Same as [struct()] (array reference)
hash()
Returns key-value list. Keys are 'year', 'month', 'day', 'hour', 'min', 'sec' and optionally 'mksec' year, month are human-friendly (2013 year, month [1-12])
href()
Same as {href()} (hash reference)
clone([\@diff | \%diff, [$timezone]])
Returns copy of the date.
If you pass a hash or array ref then date is cloned with changes described in the hash/array. Hash keys: 'year' (YYYY), 'month' [1-12], 'day', 'hour', 'min', 'sec', 'mksec'. Array: [$year (YYYY), $month [1-12], $day, $hour, $min, $sec, $mksec]
If any values in hash or array are absent (or = undef or = -1) the appropriate field of date is not changed.
If $timezone parameter is absent (or undef or ""), newly created date will use $date's timezone. Otherwise constructed date is converted to timezone $timezone preserving YMDhms information.
month_begin_new()
Returns the beggining of month. Only day of month is changed, HMS are preserved.
month_begin()
Same as month_begin_new()
but changes current object instead of cloning.
month_end_new()
Returns the end of month. Only day of month is changed, HMS are preserved.
month_end()
Same as month_end_new()
but changes current object instead of cloning.
days_in_month()
Returns the number of days in month
error()
Returns error code occured during creating or cloning object (if any). If no errors returns E_OK.
errstr()
Returns error string if any, otherwise undef.
truncate_new()
Return copy of the current date with HMS set to 0. Same as clone({hour =
0, min => 0, sec => 0})>, but much faster.
truncate()
Same as truncate_new()
but changes current object instead of cloning. It's extremely faster.
'<=>', 'cmp', compare($date | $iso_string | $epoch | \@array | \%hash)
Compares 2 dates and returns -1, 0 or 1. Second operand may be anything that one-argument constructor supports.
'+', add_new($reldate | $rel_string | $seconds | \@rel_array | \%rel_hash)
Adds a relative date to date object. If second operand is not an object then it's created (Date::Rel).
'+=', add($reldate | $rel_string | $seconds | \@rel_array | \%rel_hash)
Same as add_new()
but changes current object instead of creating new one.
'-', subtract_new($reldate | $rel_string | $seconds | \@rel_array | \%rel_hash | $date | $iso_string)
Subtracts a relative date or another date from the date object. In case of relative date the result is a Date object. Otherwise the result is Date::Int. If second operand is not an object then it's created (Date::Rel or Date).
'-=', subtract($reldate | $rel_string | $seconds | \@rel_array | \%rel_hash)
Same as subtract()
but changes current object instead of creating new one. Operand can only be a Date::Rel object.
CONSTANTS
E_OK
No errors
E_UNPARSABLE
Wrong date string format
E_RANGE
Invalid date (or date part) supplied when range_check() is in effect
YEAR
Constant for rdate("1Y"). These (YEAR...SEC) objects are constants (read-only).
If you try to change these objects they'll croak.
MONTH
Constant for rdate("1M").
DAY
Constant for rdate("1D").
HOUR
Constant for rdate("1h").
MIN
Constant for rdate("1m").
SEC
Constant for rdate("1s").
OPERATOR OVERLOAD RULES
See screenshot http://crazypanda.ru/v/clip2net/a/v/ri93sO22KI.png
CLONING/SERIALIZATION
Date
supports:
- Storable serialization/deserealization
-
You can freeze Date::* objects and thaw serialized data back without losing any date information.
If you serialize a date object which was created with personal timezone (second arg to constructor), then it will be deserialized exactly in the same timezone.
If a date object is in local timezone, then it will be deserialized in local timezone too (which may differ on differrent servers), but it's guaranteed that those two dates will point to the same time moment (epoch is preserved).
For example:
tzset('Europe/Moscow'); my $date = date("2014-01-01"); my $frozen = freeze $date; tzset('America/New_York'); my $date2 = thaw $frozen; $date == $date2; # true, because $date->epoch == $date2->epoch say $date; # 2014-01-01 00:00:00 say $date2; # 2013-12-31 15:00:00
- Data::Recursive's
clone
- JSON::XS serialization with convert_blessed
-
Serializes to
epoch()
DATE RANGES
64bit OS + perl-64bit-int
from -2147483648/01/01 00:00:00 till 2147483647/12/31 23:59:59
32bit OS + perl-64bit-int
from -2147483648/01/01 00:00:00 till 2147483647/12/31 23:59:59
32bit OS + perl-32bit-int
from -285424812/02/20 18:53:48 till 285428751/11/12 11:36:32
PERFOMANCE
Date operates 40-70x faster than Class::Date, tests were performed on Core i7 3.2Ghz, MacOSX Lion, perl 5.12.4
my $cdate = new Class::Date("2013-06-05 23:45:56");
my $date = new Date("2013-06-05 23:45:56");
my $crel = Class::Date::Rel->new("1M");
my $rel = rdate("1M");
timethese(-1, {
cdate_new_str => sub { new Class::Date("2013-01-25 21:26:43"); },
date_new_str => sub { new Date("2013-01-25 21:26:43"); },
cdate_new_epoch => sub { new Class::Date(1000000000); },
date_new_epoch => sub { new Date(1000000000); },
date_new_reuse => sub { state $date = new Date(0); $date->set(1000000000); },
cdate_now => sub { Class::Date->now; },
date_now => sub { now(); },
cdate_truncate => sub { $cdate->truncate },
date_truncate_new => sub { $date->truncate_new },
date_truncate => sub { $date->truncate },
cdate_today => sub { Class::Date->now->truncate; },
date_today1 => sub { now()->truncate; },
date_today2 => sub { today(); },
cdate_stringify => sub { $cdate->string },
date_stringify => sub { $date->to_string },
cdate_strftime => sub { $cdate->strftime("%H:%M:%S") },
date_strftime => sub { $date->strftime("%H:%M:%S") },
cdate_clone_simple => sub { $cdate->clone },
date_clone_simple => sub { $date->clone },
cdate_clone_change => sub { $cdate->clone(year => 2008, month => 12) },
date_clone_change => sub { $date->clone({year => 2008, month => 12}) },
cdate_rel_new_sec => sub { new Class::Date::Rel 1000 },
pdate_rel_new_sec => sub { new Date::Rel 1000 },
cdate_rel_new_str => sub { new Class::Date::Rel "1Y 2M 3D 4h 5m 6s" },
date_rel_new_str => sub { new Date::Rel "1Y 2M 3D 4h 5m 6s" },
cdate_add => sub { $cdate = $cdate + '1M' },
date_add_new => sub { $date = $date + '1M' },
date_add => sub { $date += '1M' },
date_add2 => sub { $date += MONTH },
date_add3 => sub { $date->month($date->month+1) },
cdate_compare => sub { $cdate == $cdate },
date_compare => sub { $date == $date },
});
#RESULTS
#cdate_new_epoch: 2 wallclock secs ( 1.11 usr + 0.00 sys = 1.11 CPU) @ 59609.01/s (n=66166)
#date_new_epoch: 1 wallclock secs ( 1.08 usr + 0.01 sys = 1.09 CPU) @ 1485434.86/s (n=1619124)
#cdate_new_str: 1 wallclock secs ( 1.09 usr + 0.01 sys = 1.10 CPU) @ 19549.09/s (n=21504)
#date_new_str: 1 wallclock secs ( 1.01 usr + 0.00 sys = 1.01 CPU) @ 1238753.47/s (n=1251141)
#date_new_reuse: 1 wallclock secs ( 1.05 usr + 0.00 sys = 1.05 CPU) @ 5242879.05/s (n=5505023)
#cdate_now: 1 wallclock secs ( 1.11 usr + 0.00 sys = 1.11 CPU) @ 55350.45/s (n=61439)
#date_now: 1 wallclock secs ( 1.08 usr + 0.00 sys = 1.08 CPU) @ 1341379.63/s (n=1448690)
#cdate_truncate: 1 wallclock secs ( 1.07 usr + 0.00 sys = 1.07 CPU) @ 25120.56/s (n=26879)
#date_truncate: 1 wallclock secs ( 1.02 usr + 0.00 sys = 1.02 CPU) @ 7710116.67/s (n=7864319)
#date_truncate_new: 1 wallclock secs ( 1.00 usr + 0.00 sys = 1.00 CPU) @ 1376255.00/s (n=1376255)
#cdate_today: 1 wallclock secs ( 1.08 usr + 0.00 sys = 1.08 CPU) @ 16591.67/s (n=17919)
#date_today1: 1 wallclock secs ( 1.03 usr + 0.00 sys = 1.03 CPU) @ 1027823.30/s (n=1058658)
#date_today2: 1 wallclock secs ( 1.03 usr + 0.01 sys = 1.04 CPU) @ 1323322.12/s (n=1376255)
#cdate_stringify: 1 wallclock secs ( 1.09 usr + 0.00 sys = 1.09 CPU) @ 92839.45/s (n=101195)
#date_stringify: 2 wallclock secs ( 1.09 usr + 0.00 sys = 1.09 CPU) @ 5072344.04/s (n=5528855)
#cdate_strftime: 1 wallclock secs ( 1.06 usr + 0.00 sys = 1.06 CPU) @ 101433.02/s (n=107519)
#date_strftime: 2 wallclock secs ( 1.06 usr + 0.01 sys = 1.07 CPU) @ 1513200.00/s (n=1619124)
#cdate_clone_simple: 1 wallclock secs ( 1.07 usr + 0.00 sys = 1.07 CPU) @ 26796.26/s (n=28672)
#date_clone_simple: 2 wallclock secs ( 1.03 usr + 0.00 sys = 1.03 CPU) @ 1670213.59/s (n=1720320)
#cdate_clone_change: 2 wallclock secs ( 1.11 usr + 0.00 sys = 1.11 CPU) @ 25830.63/s (n=28672)
#date_clone_change: 1 wallclock secs ( 1.08 usr + 0.00 sys = 1.08 CPU) @ 637154.63/s (n=688127)
#cdate_rel_new_sec: 1 wallclock secs ( 1.08 usr + 0.00 sys = 1.08 CPU) @ 245059.26/s (n=264664)
#cdate_rel_new_str: 1 wallclock secs ( 1.05 usr + 0.00 sys = 1.05 CPU) @ 68265.71/s (n=71679)
#pdate_rel_new_sec: 2 wallclock secs ( 1.02 usr + 0.00 sys = 1.02 CPU) @ 1420284.31/s (n=1448690)
#date_rel_new_str: 1 wallclock secs ( 1.01 usr + 0.00 sys = 1.01 CPU) @ 1238753.47/s (n=1251141)
#cdate_add: 1 wallclock secs ( 1.09 usr + 0.00 sys = 1.09 CPU) @ 17934.86/s (n=19549)
#date_add: 0 wallclock secs ( 1.01 usr + 0.00 sys = 1.01 CPU) @ 4542099.01/s (n=4587520)
#date_add2: 1 wallclock secs ( 1.03 usr + 0.00 sys = 1.03 CPU) @ 4858802.91/s (n=5004567)
#date_add3: 1 wallclock secs ( 1.05 usr + 0.00 sys = 1.05 CPU) @ 2759410.48/s (n=2897381)
#date_add_new: 2 wallclock secs ( 1.06 usr + 0.00 sys = 1.06 CPU) @ 1180321.70/s (n=1251141)
#cdate_compare: 1 wallclock secs ( 1.10 usr + 0.00 sys = 1.10 CPU) @ 71087.27/s (n=78196)
#date_compare: 2 wallclock secs ( 1.07 usr + 0.00 sys = 1.07 CPU) @ 3674914.95/s (n=3932159)
AUTHOR
Pronin Oleg <syber@cpan.org>, Crazy Panda LTD
LICENSE
You may distribute this code under the same terms as Perl itself.
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 259:
Non-ASCII character seen before =encoding in 'hh:mm[:ss][.mks][±hh[:]mm]'. Assuming UTF-8