NAME
DateTimeX::Lite - A Low Calorie DateTime
SYNOPSIS
use DateTimeX::Lite;
my $dt = DateTimeX::Lite->new(year => 2008, month => 12, day => 1);
$dt->year;
$dt->month;
$dt->day;
$dt->hour;
$dt->minuute;
$dt->second;
# Arithmetic doesn't come with DateTimeX::Lite by default
use DateTimeX::Lite qw(Arithmetic);
$dt->add( DateTimeX::Lite::Duration->new(days => 5) );
# Strftime doesn't come with DateTimeX::Lite by default
use DateTimeX::Lite qw(Strftime);
$dt->strftime('%Y %m %d');
# ZeroBase accessors doesn't come with DateTimeX::Lite by default
use DateTimeX::Lite qw(ZeroBase);
$dt->month_0;
# Overloading is disabled by default
use DateTimeX::Lite qw(Overload);
print "the date is $dt\n";
if ($dt1 < $dt2) {
print "dt1 is less than dt2\n";
}
DESCRIPTION
This is a lightweight version of DateTime.pm, which requires no XS, and aims to be light(er) than the original, for a given subset of the problems that the original DateTime.pm can solve.
The idea is to encourage light users to use DateTime compatible API, while adapting to realistic environments (such as people without access to C compilers, people on rental servers who can't install modules, people who needs to convince pointy-haired bosses that they're not sacrificing performance), so later when they find engineering freedom, they can switch back to the more reliable DateTime.pm.
Please make no mistake: THIS IS NOT A REPLACEMENT FOR Datetime.pm. I will try to keep up with DateTime.pm, but DateTime.pm is the referece implementation. This is just stripped down version.
Please also note that internally, this module is a complete rip-off of the original DateTime.pm module. The author simply copied and pasted about 90% of the code, tweaked it and repackaged it. All credits go to the original DateTime.pm's authors.
RATIONALE
The aim of this module is as follows:
- (1) Target those who do not need the full feature of DateTime.pm.
-
In particular, I'm thinking of people who wants to simply grab a date, maybe do some date arithmetic on it, and print the year/month/date or store those values somewhere. These people do not use advanced date logic, sets, or calendars.
- (2) Target the newbies who are afraid of XS code.
-
Let's face it, /we/ the developers know how to deal with XS. But we can't expect that out of everybody. DateTime.pm doesn't require XS, but to get decent performance it's sort of a requirement. We do our best to get there without XS.
- (3) Get better performance.
-
In particular,
* Reduce the amount of memory consumed, and * Reduce the time it takes to load the module
Again, /we/ know why it's worth it to use DateTime. Some people don't, and will judge DateTime (and worse yet, maybe perl itself) unusable simply because it takes more memory to load DateTime. We want to avoid that.
- (4) Make it easy to install on rental servers.
-
This also ties into (2). No XS code, becuse compilers may not be available, or people simply wouldn't know how to use compilers.
If we can simply copy the DateTimeX::Lite files over via FTP instead of 'make install', that's even better.
- (5) Bundle everything in one distribution, including timezones and locales
-
This goes with (4). We like time zones and locales. However, we would like to limit the number of dependencies. It would be even better if we can choose which locales and timezones to install.
- (6) Be compatible enough with DateTime.pm
-
While given all of the above, we would like to leave a way for users to easily (relatively speaking) switch back to DateTime.pm, when they so choose to. Hence, the API needs to remain mostly compatible.
COMPATIBILITY WITH DateTime.pm
As stated elsewhere, DateTimeX::Lite does not intend to be a drop-in replacement for DateTime.pm.
You should not expect other DateTime::* modules (such as Format and Calendar) to work with it. It might, but we won't guarantee it.
We feel that if you use the extended features of the DateTime family, you should be using the original DateTime.pm
NOTABLE DIFFERENCES
DateTimeX::Lite tries to be as compatible as possible with DateTime.pm, but there are a few places it deliberately changed from DateTime.pm. Some notable differences from DateTime.pm are as follows
- Non-essential methods are loaded on demand
-
For example, A lot of times you don't even need to do date time arithmetic. These methods are separated out onto a different file, so you need to load it on demand. To load, include "Arithmetic" in the use line.
use DateTimeX::Lite qw(Arithmetic);
Similarly, strftime() imposes a lot of code on DateTime. So if ymd(), iso8601() or the like is sufficient, it would be best not to load it. To load, include "Strftime" in the use line.
use DateTimeX::Lite qw(Strftime);
Zero-based accessors are also taken out of the core DateTimeX::Lite code.
use DateTimeX::Lite qw(ZeroBase);
Overload operators are also taken out. If you want to automatically compare or stringify two DateTimeX::Lite objects using standard operators, you need to include Overload:
use DateTimeX::Lite qw(Overload);
- DateTimeX::Lite::TimeZone and DateTimeX::Lite::Locale
-
DateTimeX::Lite::TimeZone and DateTimeX::Lite::Locale have big changes from their original counterparts.
First, you do NOT call new() on these objects (unless this is something you explicitly want to do). Instead, you need to call load(). So if you were mucking with DateTimeX::Lite::TimeZone and DateTime::Locale, you need to find out every occurance of
DateTime::TimeZone->new( name => 'Asia/Tokyo' );
and change them to
DateTimeX::Lite::TimeZone->load( name => 'Asia/Tokyo' );
Singletons are okay, they serve a particular purpose. But besides being a memory hog of relative low benefit, I've had claims from users questioning the benefit of timezones and locales when they saw that those two distributions installed hundreds of singleton classes.
With this version, the objects are just regular objects, and the exact definition for each timezone/locale is stored in data files. (TODO: They can be located anywhere DateTimeX::Lite can find them)
TODO: We want to make it easy to pick and choose which locales/timezones to be available -- DateTime::TimeZone and Locale comes with the full-set, and normally we don't need this feature. For example, I only use Asia/Tokyo and UTC time zones for my dayjob. When we ask casual users to install a datetime package, we do not want to overwhelm then with 100+ timezones and locales.
METHODS
am_or_pm
ce_year
clone
compare
compare_ignore_floating
date
datetime
day
day_abbr
day_name
day_of_month
day_of_quarter
day_of_week
day_of_year
dmy
doq
dow
doy
epoch
formatter
fractional_second
from_day_of_year
from_epoch
from_object
hires_epoch
hms
hour
hour_1
hour_12
is_dst
is_finite
is_infinite
is_leap_year
iso8601
jd
last_day_of_month
leap_seconds
local_day_of_week
local_rd_as_seconds
local_rd_values
locale
mday
mdy
microsecond
millisecond
min
minute
mjd
mon
month
month_abbr
month_name
nanosecond
new
now
offset
quarter
quarter_abbr
quarter_name
sec
second
set
set_day
set_formatter
set_hour
set_locale
set_minute
set_month
set_nanosecond
set_second
set_time_zone
set_year
time
time_zone
time_zone_long_name
time_zone_short_name
to_datetime
today
truncate
utc_rd_as_seconds
utc_rd_values
wday
week
week_number
week_of_month
week_year
weekday_of_month
year
ymd
TODO
- Make it possible to separate locales and time zones
- Create an easy way to install new locales or time zones.
- The files for timezones/locales may not be safe-to-load. need to check
AUTHOR
- Original DateTime.pm:
-
Copyright (c) 2003-2008 David Rolsky
<autarch@urth.org>
. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. - DateTimeX::Lite tweaks
-
Daisuke Maki
<daisuke@endeworks.jp>
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.