changed versioning table from SchemaVersions to dbix_class_schema_versions with trans...
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / CDBICompat / AccessorMapping.pm
index e5703c9..c012586 100644 (file)
@@ -1,14 +1,13 @@
-package DBIx::Class::CDBICompat::AccessorMapping;
+package # hide from PAUSE Indexer
+    DBIx::Class::CDBICompat::AccessorMapping;
 
 use strict;
 use warnings;
 
-use NEXT;
-
-sub _mk_column_accessors {
-  my ($class, @cols) = @_;
+sub mk_group_accessors {
+  my ($class, $group, @cols) = @_;
   unless ($class->can('accessor_name') || $class->can('mutator_name')) {
-    return $class->NEXT::_mk_column_accessors('column' => @cols);
+    return $class->next::method($group => @cols);
   }
   foreach my $col (@cols) {
     my $ro_meth = ($class->can('accessor_name')
@@ -17,13 +16,30 @@ sub _mk_column_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('column' => $col);
+      $class->next::method($group => [ $ro_meth => $col ]);
     } else {
-      $class->mk_group_ro_accessors('column' => $ro_meth);
-      $class->mk_group_wo_accessors('column' => $wo_meth);
+      $class->mk_group_ro_accessors($group => [ $ro_meth => $col ]);
+      $class->mk_group_wo_accessors($group => [ $wo_meth => $col ]);
+    }
+  }
+}
+
+sub new {
+  my ($class, $attrs, @rest) = @_;
+  $class->throw_exception( "create needs a hashref" ) unless ref $attrs eq 'HASH';
+  foreach my $col ($class->columns) {
+    if ($class->can('accessor_name')) {
+      my $acc = $class->accessor_name($col);
+      $attrs->{$col} = delete $attrs->{$acc} if exists $attrs->{$acc};
+    }
+    if ($class->can('mutator_name')) {
+      my $mut = $class->mutator_name($col);
+      $attrs->{$col} = delete $attrs->{$mut} if exists $attrs->{$mut};
     }
   }
+  return $class->next::method($attrs, @rest);
 }
 
 1;