NAME
Rose::Object::MakeMethods::DateTime - Create methods that store DateTime objects.
SYNOPSIS
package MyObject;
use Rose::Object::MakeMethods::DateTime
(
datetime =>
[
'birthday',
'arrival' => { tz => 'UTC' }
],
);
...
$obj = MyObject->new(birthday => '1/24/1984 1am');
$dt = $obj->birthday; # DateTime object
$bday = $obj->birthday(format => '%B %E'); # 'January 24th'
# Shortcut for $obj->birthday->clone->truncate(to => 'month');
$month = $obj->birthday(truncate => 'month');
$obj->birthday('blah'); # croaks - invalid date!
$obj->birthday('1999-04-31'); # croaks - invalid date!
DESCRIPTION
Rose::Object::MakeMethods::DateTime
is a method maker that inherits from Rose::Object::MakeMethods
. See the Rose::Object::MakeMethods
documentation to learn about the interface. The method types provided by this module are described below. All methods work only with hash-based objects.
METHODS TYPES
- datetime
-
Create get/set methods for scalar attributes that store
DateTime
objects.- Options
-
hash_key
-
The key inside the hash-based object to use for the storage of this attribute. Defaults to the name of the method.
init_method
-
The name of the method to call when initializing the value of an undefined attribute. This option is only applicable when using the
get_set_init
interface. Defaults to the method name with the prefixinit_
added.This method should return a value that can be parsed by
Rose::DateTime::Util
's theparse_date()
function. If the return value is aDateTime
object, it will have its time zone set (see thetz
option below) usingDateTime
'sset_time_zone()
method. interface
-
Chooses one of the two possible interfaces. Defaults to
get_set
. tz
-
The time zone of the
DateTime
object to be stored. If present, this value will be passed as the second argument toRose::DateTime::Util
's theparse_date()
function when creatingDateTime
objects for storage. If absent,DateTime
objects will use the default time zone of theRose::DateTime::Util
class, which is set byRose::DateTime::Util
'stime_zone()
class method. See theRose::DateTime::Util
documentation for more information.
- Interfaces
-
get_set
-
Creates a get/set accessor method for an object attribute that stores a
DateTime
object.When called with a single argument, the argument is passed through
Rose::DateTime::Util
'sparse_date()
function in order to create theDateTime
object that is stored. The current value of the attribute is returned. Passing a value that is not understood byRose::DateTime::Util
'sparse_date()
function causes a fatal error.When called with two arguments and the first argument is the string 'format', then the second argument is taken as a format specifier which is passed to
Rose::DateTime::Util
'sformat_date()
function. The formatted string is returned. In other words, this:$obj->birthday(format => '%m/%d/%Y');
Is just a shortcut for this:
Rose::DateTime::Util::format_date($obj->birthday, '%m/%d/%Y');
When called with two arguments and the first argument is the string 'truncate', then the second argument is taken as a truncation specifier which is passed to
DateTime
'struncate()
method called on a clone of the existingDateTime
object. The cloned, truncatedDateTime
object is returned. In other words, this:$obj->birthday(truncate => 'month');
Is just a shortcut for this:
$obj->birthday->clone->truncate(to => 'month');
Passing more than two arguments or passing two arguments where the first argument is not 'format' or 'truncate' will cause a fatal error.
get_set_init
-
Behaves like the
get_set
interface unless the value of the attribute is undefined. In that case, the method specified by theinit_method
option is called, the return value is passed throughRose::DateTime::Util
'sparse_date()
function, and the attribute is set to the return value. An init method that returns a value that is not understood byRose::DateTime::Util
'sparse_date()
function will cause a fatal error.
Example:
package MyObject; use Rose::Object::MakeMethods::DateTime ( datetime => [ 'birthday', 'arrival' => { tz => 'UTC' } ], 'datetime --get_set_init' => [ 'departure' => { tz => 'UTC' } ], ); sub init_departure { DateTime->new(month => 1, day => 10, year => 2000, time_zone => 'America/Chicago'); } ... $obj = MyObject->new(birthday => '1/24/1984 1am'); $dt = $obj->birthday; # DateTime object $bday = $obj->birthday(format => '%B %E'); # 'January 24th' # Shortcut for $obj->birthday->clone->truncate(to => 'month'); $month = $obj->birthday(truncate => 'month'); $obj->birthday('blah'); # croaks - invalid date! $obj->birthday('1999-04-31'); # croaks - invalid date! # DateTime object with time zone set to UTC $dt = $obj->arrival('2005-21-01 4pm'); # DateTime object with time zone set to UTC, not America/Chicago! # Start with 2000-01-10T00:00:00 America/Chicago, # then set_time_zone('UTC'), # which results in: 2000-01-10T06:00:00 UTC $dt = $obj->departure; print $dt; # "2000-01-10T06:00:00"
AUTHOR
John C. Siracusa (siracusa@mindspring.com)