Now passing four more tests, has_a and has_many compliance extended
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / CDBICompat / AccessorMapping.pm
index 07e72ac..1604a7c 100644 (file)
@@ -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')
@@ -18,7 +18,7 @@ sub mk_group_accessors {
                     ? $class->mutator_name($col)
                     : $col);
     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 +26,23 @@ sub mk_group_accessors {
   }
 }
 
+sub create {
+  my ($class, $attrs, @rest) = @_;
+  die "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;