X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FInflateColumn%2FDateTime.pm;h=afd118d396f918eed2fc6275c451235c587855d5;hb=d2f21b377c36ca386492605c7b2c571eed09c0f6;hp=8e2e2d5d2480d03e17985f0eda2c2158ee09bfd9;hpb=2c96eeed34d7fa42dbb9dbae04a93a9dc0048e2e;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/InflateColumn/DateTime.pm b/lib/DBIx/Class/InflateColumn/DateTime.pm index 8e2e2d5..afd118d 100644 --- a/lib/DBIx/Class/InflateColumn/DateTime.pm +++ b/lib/DBIx/Class/InflateColumn/DateTime.pm @@ -27,10 +27,10 @@ Then you can treat the specified column as a L object. print "This event starts the month of ". $event->starts_when->month_name(); -If you want to set a specific timezone for that field, use: +If you want to set a specific timezone and locale for that field, use: __PACKAGE__->add_columns( - starts_when => { data_type => 'datetime', extra => { timezone => "America/Chicago" } } + starts_when => { data_type => 'datetime', timezone => "America/Chicago", locale => "de_DE" } ); If you want to inflate no matter what data_type your column is, @@ -110,10 +110,22 @@ sub register_column { } my $timezone; - if ( exists $info->{extra} and exists $info->{extra}{timezone} and defined $info->{extra}{timezone} ) { + if ( defined $info->{extra}{timezone} ) { + warn "Putting timezone into extra => { timezone => '...' } has been deprecated, ". + "please put it directly into the columns definition."; $timezone = $info->{extra}{timezone}; } + my $locale; + if ( defined $info->{extra}{locale} ) { + warn "Putting locale into extra => { locale => '...' } has been deprecated, ". + "please put it directly into the columns definition."; + $locale = $info->{extra}{locale}; + } + + $locale = $info->{locale} if defined $info->{locale}; + $timezone = $info->{timezone} if defined $info->{timezone}; + my $undef_if_invalid = $info->{datetime_undef_if_invalid}; if ($type eq 'datetime' || $type eq 'date') { @@ -132,7 +144,13 @@ sub register_column { # closure &G, $info => $H # $H => %E # - my $floating_tz_ok = $info->{extra}{floating_tz_ok}; + my $floating_tz_ok; + if (defined $info->{extra}{floating_tz_ok}) { + warn "Putting floating_tz_ok into extra => { floating_tz_ok => 1 } has been deprecated, ". + "please put it directly into the columns definition."; + $floating_tz_ok = $info->{extra}{floating_tz_ok}; + } + $floating_tz_ok = $info->{floating_tz_ok} if defined $info->{floating_tz_ok}; $self->inflate_column( $column => @@ -143,6 +161,7 @@ sub register_column { die "Error while inflating ${value} for ${column} on ${self}: $@" if $@ and not $undef_if_invalid; $dt->set_time_zone($timezone) if $timezone; + $dt->set_locale($locale) if $locale; return $dt; }, deflate => sub { @@ -154,6 +173,7 @@ sub register_column { and not $floating_tz_ok and not $ENV{DBIC_FLOATING_TZ_OK}; $value->set_time_zone($timezone); + $value->set_locale($locale) if $locale; } $obj->_datetime_parser->$format($value); }, @@ -182,7 +202,7 @@ timezone, you will get a warning (as there is a very good chance this will not h result you expect). For example: __PACKAGE__->add_columns( - starts_when => { data_type => 'datetime', extra => { timezone => "America/Chicago" } } + starts_when => { data_type => 'datetime', timezone => "America/Chicago" } ); my $event = $schema->resultset('EventTZ')->create({ @@ -206,7 +226,7 @@ to be supply explicit times to the database: =item Suppress the check on per-column basis __PACKAGE__->add_columns( - starts_when => { data_type => 'datetime', extra => { timezone => "America/Chicago", floating_tz_ok => 1 } } + starts_when => { data_type => 'datetime', timezone => "America/Chicago", floating_tz_ok => 1 } ); =item Suppress the check globally @@ -215,7 +235,10 @@ Set the environment variable DBIC_FLOATING_TZ_OK to some true value. =back - +Putting extra attributes like timezone, locale or floating_tz_ok into extra => {} has been +B because this gets you into trouble using L. +Instead put it directly into the columns definition like in the examples above. If you still +use the old way you'll see a warning - please fix your code then! =head1 SEE ALSO