X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FCDBICompat%2FColumnCase.pm;h=9be24ff4723ee3fff9cecd159bb2bfdca9e151a0;hb=5233443c7147a7f75ff41560495d8258ae18622c;hp=d79104db8f62652bf7bff13d309451bcf4a39b74;hpb=fc02b7673d45eba9dd36fbd127eb8e4afe21903b;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/CDBICompat/ColumnCase.pm b/lib/DBIx/Class/CDBICompat/ColumnCase.pm index d79104d..9be24ff 100644 --- a/lib/DBIx/Class/CDBICompat/ColumnCase.pm +++ b/lib/DBIx/Class/CDBICompat/ColumnCase.pm @@ -1,4 +1,5 @@ -package DBIx::Class::CDBICompat::ColumnCase; +package # hide from PAUSE + DBIx::Class::CDBICompat::ColumnCase; use strict; use warnings; @@ -10,15 +11,10 @@ sub _register_column_group { return $class->next::method($group => map lc, @cols); } -sub _register_columns { - my ($class, @cols) = @_; - return $class->next::method(map lc, @cols); -} - sub add_columns { my ($class, @cols) = @_; - $class->result_source->add_columns(map lc, @cols); - $class->_mk_column_accessors(@cols); + $class->mk_group_accessors(column => @cols); + $class->result_source_instance->add_columns(map lc, @cols); } sub has_a { @@ -30,8 +26,8 @@ sub has_a { sub has_many { my ($class, $rel, $f_class, $f_key, @rest) = @_; - return $class->next::method($rel, $f_class, ( ref($f_key) ? - $f_key : + return $class->next::method($rel, $f_class, ( ref($f_key) ? + $f_key : lc($f_key) ), @rest); } @@ -70,6 +66,19 @@ sub find_column { return $class->next::method(lc($col)); } +# _build_query +# +# Build a query hash for find, et al. Overrides Retrieve::_build_query. + +sub _build_query { + my ($self, $query) = @_; + + my %new_query; + $new_query{lc $_} = $query->{$_} for keys %$query; + + return \%new_query; +} + sub _mk_group_accessors { my ($class, $type, $group, @fields) = @_; #warn join(', ', map { ref $_ ? (@$_) : ($_) } @fields);