Merge 'find_changes' into 'DBIx-Class-current'
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / CDBICompat / ColumnCase.pm
1 package # hide from PAUSE
2     DBIx::Class::CDBICompat::ColumnCase;
3
4 use strict;
5 use warnings;
6
7 use base qw/DBIx::Class/;
8
9 sub _register_column_group {
10   my ($class, $group, @cols) = @_;
11   return $class->next::method($group => map lc, @cols);
12 }
13
14 sub add_columns {
15   my ($class, @cols) = @_;
16   $class->mk_group_accessors(column => @cols);
17   $class->result_source_instance->add_columns(map lc, @cols);
18 }
19
20 sub has_a {
21   my ($class, $col, @rest) = @_;
22   $class->next::method(lc($col), @rest);
23   $class->mk_group_accessors('inflated_column' => $col);
24   return 1;
25 }
26
27 sub has_many {
28   my ($class, $rel, $f_class, $f_key, @rest) = @_;
29   return $class->next::method($rel, $f_class, ( ref($f_key) ?
30                                                           $f_key :
31                                                           lc($f_key) ), @rest);
32 }
33
34 sub get_inflated_column {
35   my ($class, $get, @rest) = @_;
36   return $class->next::method(lc($get), @rest);
37 }
38
39 sub store_inflated_column {
40   my ($class, $set, @rest) = @_;
41   return $class->next::method(lc($set), @rest);
42 }
43
44 sub set_inflated_column {
45   my ($class, $set, @rest) = @_;
46   return $class->next::method(lc($set), @rest);
47 }
48
49 sub get_column {
50   my ($class, $get, @rest) = @_;
51   return $class->next::method(lc($get), @rest);
52 }
53
54 sub set_column {
55   my ($class, $set, @rest) = @_;
56   return $class->next::method(lc($set), @rest);
57 }
58
59 sub store_column {
60   my ($class, $set, @rest) = @_;
61   return $class->next::method(lc($set), @rest);
62 }
63
64 sub find_column {
65   my ($class, $col) = @_;
66   return $class->next::method(lc($col));
67 }
68
69 # _build_query
70 #
71 # Build a query hash for find, et al. Overrides Retrieve::_build_query.
72
73 sub _build_query {
74   my ($self, $query) = @_;
75
76   my %new_query;
77   $new_query{lc $_} = $query->{$_} for keys %$query;
78
79   return \%new_query;
80 }
81
82 sub _mk_group_accessors {
83   my ($class, $type, $group, @fields) = @_;
84   #warn join(', ', map { ref $_ ? (@$_) : ($_) } @fields);
85   my @extra;
86   foreach (@fields) {
87     my ($acc, $field) = ref $_ ? @$_ : ($_, $_);
88     #warn "$acc ".lc($acc)." $field";
89     next if defined &{"${class}::${acc}"};
90     push(@extra, [ lc $acc => $field ]);
91   }
92   return $class->next::method($type, $group,
93                                                      @fields, @extra);
94 }
95
96 sub new {
97   my ($class, $attrs, @rest) = @_;
98   my %att;
99   $att{lc $_} = $attrs->{$_} for keys %$attrs;
100   return $class->next::method(\%att, @rest);
101 }
102
103 1;