feb0a593c154674275e9a936d34480e01700c3f4
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / ResultSourceProxy.pm
1 package # hide from PAUSE
2     DBIx::Class::ResultSourceProxy;
3
4 use strict;
5 use warnings;
6
7 use base qw/DBIx::Class/;
8 use Scalar::Util qw/blessed/;
9 use Carp::Clan qw/^DBIx::Class/;
10
11 sub iterator_class  { shift->result_source_instance->resultset_class(@_) }
12 sub resultset_class { shift->result_source_instance->resultset_class(@_) }
13 sub result_class { shift->result_source_instance->result_class(@_) }
14 sub source_info { shift->result_source_instance->source_info(@_) }
15
16 sub set_inherited_ro_instance {
17     my $self = shift;
18
19     croak "Cannot set @{[shift]} on an instance" if blessed $self;
20
21     return $self->set_inherited(@_);
22 }
23
24 sub get_inherited_ro_instance {
25     return shift->get_inherited(@_);
26 }
27
28 __PACKAGE__->mk_group_accessors('inherited_ro_instance' => 'source_name');
29
30
31 sub resultset_attributes {
32   shift->result_source_instance->resultset_attributes(@_);
33 }
34
35 sub add_columns {
36   my ($class, @cols) = @_;
37   my $source = $class->result_source_instance;
38   $source->add_columns(@cols);
39   foreach my $c (grep { !ref } @cols) {
40     # If this is an augment definition get the real colname.
41     $c =~ s/^\+//;
42
43     $class->register_column($c => $source->column_info($c));
44   }
45 }
46
47 sub add_column {
48   shift->add_columns(@_);
49 }
50
51 sub has_column {
52   shift->result_source_instance->has_column(@_);
53 }
54
55 sub column_info {
56   shift->result_source_instance->column_info(@_);
57 }
58
59 sub column_info_from_storage {
60   shift->result_source_instance->column_info_from_storage(@_);
61 }
62
63 sub columns {
64   shift->result_source_instance->columns(@_);
65 }
66
67 sub remove_columns {
68   shift->result_source_instance->remove_columns(@_);
69 }
70
71 *remove_column = \&remove_columns;
72
73 sub set_primary_key {
74   shift->result_source_instance->set_primary_key(@_);
75 }
76
77 sub primary_columns {
78   shift->result_source_instance->primary_columns(@_);
79 }
80
81 sub _pri_cols {
82   shift->result_source_instance->_pri_cols(@_);
83 }
84
85 sub add_unique_constraint {
86   shift->result_source_instance->add_unique_constraint(@_);
87 }
88
89 sub unique_constraints {
90   shift->result_source_instance->unique_constraints(@_);
91 }
92
93 sub unique_constraint_names {
94   shift->result_source_instance->unique_constraint_names(@_);
95 }
96
97 sub unique_constraint_columns {
98   shift->result_source_instance->unique_constraint_columns(@_);
99 }
100
101 sub add_relationship {
102   my ($class, $rel, @rest) = @_;
103   my $source = $class->result_source_instance;
104   $source->add_relationship($rel => @rest);
105   $class->register_relationship($rel => $source->relationship_info($rel));
106 }
107
108 sub relationships {
109   shift->result_source_instance->relationships(@_);
110 }
111
112 sub relationship_info {
113   shift->result_source_instance->relationship_info(@_);
114 }
115
116 sub has_relationship {
117   shift->result_source_instance->has_relationship(@_);
118 }
119 1;