X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FAccessorMapping.pm;h=e235440ec0c2292d35cf323ac3b582c90e5dd3a4;hb=5e0eea3522876a30453af24097507198bbbc9409;hp=c09140f49fba81ded7341249849f500c975d6539;hpb=7da0602386cfd7c10aa24cfa053b32bdcb27c081;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/CDBICompat/AccessorMapping.pm b/lib/DBIx/Class/CDBICompat/AccessorMapping.pm index c09140f..e235440 100644 --- a/lib/DBIx/Class/CDBICompat/AccessorMapping.pm +++ b/lib/DBIx/Class/CDBICompat/AccessorMapping.pm @@ -4,14 +4,23 @@ package # hide from PAUSE Indexer use strict; use warnings; +use base 'DBIx::Class'; + +use Scalar::Util 'blessed'; +use namespace::clean; + sub mk_group_accessors { my ($class, $group, @cols) = @_; foreach my $col (@cols) { - my($accessor, $col) = ref $col ? @$col : (undef, $col); + my($accessor, $col) = ref $col eq 'ARRAY' ? @$col : (undef, $col); my($ro_meth, $wo_meth); - if( defined $accessor ) { + if (defined blessed $col and $col->isa('Class::DBI::Column')) { + $ro_meth = $col->accessor; + $wo_meth = $col->mutator; + } + elsif (defined $accessor and ($accessor ne $col)) { $ro_meth = $wo_meth = $accessor; } else { @@ -21,21 +30,22 @@ sub mk_group_accessors { # warn "class: $class / col: $col / ro: $ro_meth / wo: $wo_meth\n"; if ($ro_meth eq $wo_meth or # they're the same - $wo_meth eq $col) # or only the accessor is custom - { - $class->next::method($group => [ $ro_meth => $col ]); - } else { - $class->mk_group_ro_accessors($group => [ $ro_meth => $col ]); - $class->mk_group_wo_accessors($group => [ $wo_meth => $col ]); - } + $wo_meth eq $col) # or only the accessor is custom + { + $class->next::method($group => [ $ro_meth => $col ]); + } + else { + $class->mk_group_ro_accessors($group => [ $ro_meth => $col ]); + $class->mk_group_wo_accessors($group => [ $wo_meth => $col ]); + } } } sub accessor_name_for { my ($class, $column) = @_; - if ($class->can('accessor_name')) { - return $class->accessor_name($column) + if ($class->can('accessor_name')) { + return $class->accessor_name($column) } return $column; @@ -43,8 +53,8 @@ sub accessor_name_for { sub mutator_name_for { my ($class, $column) = @_; - if ($class->can('mutator_name')) { - return $class->mutator_name($column) + if ($class->can('mutator_name')) { + return $class->mutator_name($column) } return $column;