X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FGetSet.pm;h=dd621f27da7591287de9f27fd4e26baedd0c452e;hb=7da0602386cfd7c10aa24cfa053b32bdcb27c081;hp=f90a2046891f6ed774e461a2d83554f75d8b02f9;hpb=c0e7b4e55952cd193b6f1866d0c27ece182397eb;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/CDBICompat/GetSet.pm b/lib/DBIx/Class/CDBICompat/GetSet.pm index f90a204..dd621f2 100644 --- a/lib/DBIx/Class/CDBICompat/GetSet.pm +++ b/lib/DBIx/Class/CDBICompat/GetSet.pm @@ -1,6 +1,9 @@ -package # hide from PAUSE +package # hide from PAUSE DBIx::Class::CDBICompat::GetSet; +use strict; +use warnings; + #use base qw/Class::Accessor/; sub get { @@ -13,7 +16,17 @@ sub get { } sub set { - return shift->set_column(@_); + my($self, %data) = @_; + + # set_columns() is going to do a string comparison before setting. + # This breaks on DateTime objects (whose comparison is arguably broken) + # so we stringify anything first. + for my $key (keys %data) { + next unless ref $data{$key}; + $data{$key} = "$data{$key}"; + } + + return shift->set_columns(\%data); } 1;