X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FGetSet.pm;h=e9480488c37c4a07100678b58a88f60b3fd3bab8;hb=4a27d168d64e0c2c61ddbfa367c360ed5028a3d3;hp=a748c557fd66ba72e1a416b6b297ccc6595a3af4;hpb=fe5d862bdaa631796cb26e5fea232a81458e68f8;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/CDBICompat/GetSet.pm b/lib/DBIx/Class/CDBICompat/GetSet.pm index a748c55..e948048 100644 --- a/lib/DBIx/Class/CDBICompat/GetSet.pm +++ b/lib/DBIx/Class/CDBICompat/GetSet.pm @@ -1,6 +1,10 @@ -package DBIx::Class::CDBICompat::GetSet; +package # hide from PAUSE + DBIx::Class::CDBICompat::GetSet; -#use base qw/Class::Accessor/; +use strict; +use warnings; + +use base 'DBIx::Class'; sub get { my ($self, @cols) = @_; @@ -12,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;