Helper primary_columns wrapper to throw if a PK is not defined
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / ResultSourceProxy.pm
CommitLineData
75d07914 1package # hide from PAUSE
c0e7b4e5 2 DBIx::Class::ResultSourceProxy;
b98e75f6 3
4use strict;
5use warnings;
6
7use base qw/DBIx::Class/;
93405cf0 8use Scalar::Util qw/blessed/;
9use Carp::Clan qw/^DBIx::Class/;
b98e75f6 10
5ac6a044 11sub iterator_class { shift->result_source_instance->resultset_class(@_) }
b98e75f6 12sub resultset_class { shift->result_source_instance->resultset_class(@_) }
831ad24f 13sub result_class { shift->result_source_instance->result_class(@_) }
a48e92d7 14sub source_info { shift->result_source_instance->source_info(@_) }
b98e75f6 15
93405cf0 16sub 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
24sub get_inherited_ro_instance {
25 return shift->get_inherited(@_);
26}
27
28__PACKAGE__->mk_group_accessors('inherited_ro_instance' => 'source_name');
29
30
5ac6a044 31sub resultset_attributes {
32 shift->result_source_instance->resultset_attributes(@_);
33}
34
b98e75f6 35sub add_columns {
36 my ($class, @cols) = @_;
1f23a877 37 my $source = $class->result_source_instance;
38 $source->add_columns(@cols);
39 foreach my $c (grep { !ref } @cols) {
40 $class->register_column($c => $source->column_info($c));
41 }
b98e75f6 42}
43
f871c774 44sub add_column {
45 shift->add_columns(@_);
46}
002a359a 47
75d07914 48sub has_column {
bfeb73b2 49 shift->result_source_instance->has_column(@_);
b98e75f6 50}
51
75d07914 52sub column_info {
bfeb73b2 53 shift->result_source_instance->column_info(@_);
b98e75f6 54}
55
d9916234 56sub column_info_from_storage {
57 shift->result_source_instance->column_info_from_storage(@_);
6eda9bcf 58}
002a359a 59
75d07914 60sub columns {
bfeb73b2 61 shift->result_source_instance->columns(@_);
75d07914 62}
002a359a 63
64sub remove_columns {
bfeb73b2 65 shift->result_source_instance->remove_columns(@_);
002a359a 66}
67
68*remove_column = \&remove_columns;
69
bc0c9800 70sub set_primary_key {
71 shift->result_source_instance->set_primary_key(@_);
72}
73
74sub primary_columns {
75 shift->result_source_instance->primary_columns(@_);
76}
b98e75f6 77
bc0c9800 78sub add_unique_constraint {
79 shift->result_source_instance->add_unique_constraint(@_);
80}
81
82sub unique_constraints {
83 shift->result_source_instance->unique_constraints(@_);
84}
87f0da6a 85
1bc0b925 86sub unique_constraint_names {
87 shift->result_source_instance->unique_constraint_names(@_);
88}
89
90sub unique_constraint_columns {
91 shift->result_source_instance->unique_constraint_columns(@_);
92}
93
8c49f629 94sub add_relationship {
71e65b39 95 my ($class, $rel, @rest) = @_;
96 my $source = $class->result_source_instance;
97 $source->add_relationship($rel => @rest);
98 $class->register_relationship($rel => $source->relationship_info($rel));
8c49f629 99}
100
101sub relationships {
102 shift->result_source_instance->relationships(@_);
103}
104
105sub relationship_info {
106 shift->result_source_instance->relationship_info(@_);
107}
108
b98e75f6 1091;