X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FAccessorMapping.pm;h=6d5e4b0c2edd7cd63a1397688069ca27c123f136;hb=429bd4f15b0ea80aef96873a9db11801538eb3ee;hp=07e72acf7c069fab21e9eac726743f240272a0d3;hpb=b8e1e21f0fcd55e6e3ce987e57601b279a75b666;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/CDBICompat/AccessorMapping.pm b/lib/DBIx/Class/CDBICompat/AccessorMapping.pm index 07e72ac..6d5e4b0 100644 --- a/lib/DBIx/Class/CDBICompat/AccessorMapping.pm +++ b/lib/DBIx/Class/CDBICompat/AccessorMapping.pm @@ -8,7 +8,7 @@ use NEXT; sub mk_group_accessors { my ($class, $group, @cols) = @_; unless ($class->can('accessor_name') || $class->can('mutator_name')) { - return $class->NEXT::mk_group_accessors($group => @cols); + return $class->NEXT::ACTUAL::mk_group_accessors($group => @cols); } foreach my $col (@cols) { my $ro_meth = ($class->can('accessor_name') @@ -17,8 +17,9 @@ sub mk_group_accessors { my $wo_meth = ($class->can('mutator_name') ? $class->mutator_name($col) : $col); + #warn "$col $ro_meth $wo_meth"; if ($ro_meth eq $wo_meth) { - $class->mk_group_accessors($group => [ $ro_meth => $col ]); + $class->NEXT::ACTUAL::mk_group_accessors($group => [ $ro_meth => $col ]); } else { $class->mk_group_ro_accessors($group => [ $ro_meth => $col ]); $class->mk_group_wo_accessors($group => [ $wo_meth => $col ]); @@ -26,4 +27,23 @@ sub mk_group_accessors { } } +sub create { + my ($class, $attrs, @rest) = @_; + $class->throw( "create needs a hashref" ) unless ref $attrs eq 'HASH'; + $attrs = { %$attrs }; + my %att; + foreach my $col (keys %{ $class->_columns }) { + if ($class->can('accessor_name')) { + my $acc = $class->accessor_name($col); +#warn "$col $acc"; + $att{$col} = delete $attrs->{$acc} if exists $attrs->{$acc}; + } + if ($class->can('mutator_name')) { + my $mut = $class->mutator_name($col); + $att{$col} = delete $attrs->{$mut} if exists $attrs->{$mut}; + } + } + return $class->NEXT::ACTUAL::create({ %$attrs, %att }, @rest); +} + 1;