X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FResultSourceProxy.pm;h=62c05642850c12cd24eaf7541245b6d1b7086035;hb=d009cb7d393292037eff527a9f8bab93860224fb;hp=964805ab76bd4757ceb9706c18e4dfedb11ce5fe;hpb=5ac6a04477849fabc50271c5b7ab15a080ae0109;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/ResultSourceProxy.pm b/lib/DBIx/Class/ResultSourceProxy.pm index 964805a..62c0564 100644 --- a/lib/DBIx/Class/ResultSourceProxy.pm +++ b/lib/DBIx/Class/ResultSourceProxy.pm @@ -1,46 +1,44 @@ -package DBIx::Class::ResultSourceProxy; +package # hide from PAUSE + DBIx::Class::ResultSourceProxy; use strict; use warnings; -use base qw/DBIx::Class/; +use base 'DBIx::Class'; +use mro 'c3'; -sub iterator_class { shift->result_source_instance->resultset_class(@_) } -sub resultset_class { shift->result_source_instance->resultset_class(@_) } +use Scalar::Util 'blessed'; +use DBIx::Class::_Util 'quote_sub'; +use namespace::clean; -sub resultset_attributes { - shift->result_source_instance->resultset_attributes(@_); +__PACKAGE__->mk_group_accessors('inherited_ro_instance' => 'source_name'); + +sub get_inherited_ro_instance { shift->get_inherited(@_) } + +sub set_inherited_ro_instance { + my $self = shift; + + $self->throw_exception ("Cannot set @{[shift]} on an instance") + if blessed $self; + + $self->set_inherited(@_); } + sub add_columns { my ($class, @cols) = @_; my $source = $class->result_source_instance; $source->add_columns(@cols); foreach my $c (grep { !ref } @cols) { + # If this is an augment definition get the real colname. + $c =~ s/^\+//; + $class->register_column($c => $source->column_info($c)); } } -sub has_column { - my ($self, $column) = @_; - return $self->result_source_instance->has_column($column); -} - -sub column_info { - my ($self, $column) = @_; - return $self->result_source_instance->column_info($column); -} - - -sub columns { - return shift->result_source_instance->columns(@_); -} - -sub set_primary_key { shift->result_source_instance->set_primary_key(@_); } -sub primary_columns { shift->result_source_instance->primary_columns(@_); } +sub add_column { shift->add_columns(@_) } -sub add_unique_constraint { shift->result_source_instance->add_unique_constraint(@_); } -sub unique_constraints { shift->result_source_instance->unique_constraints(@_); } sub add_relationship { my ($class, $rel, @rest) = @_; @@ -49,12 +47,46 @@ sub add_relationship { $class->register_relationship($rel => $source->relationship_info($rel)); } -sub relationships { - shift->result_source_instance->relationships(@_); -} -sub relationship_info { - shift->result_source_instance->relationship_info(@_); +# legacy resultset_class accessor, seems to be used by cdbi only +sub iterator_class { shift->result_source_instance->resultset_class(@_) } + +for my $method_to_proxy (qw/ + source_info + result_class + resultset_class + resultset_attributes + + columns + has_column + + remove_column + remove_columns + + column_info + columns_info + column_info_from_storage + + set_primary_key + primary_columns + sequence + + add_unique_constraint + add_unique_constraints + + unique_constraints + unique_constraint_names + unique_constraint_columns + + relationships + relationship_info + has_relationship +/) { + quote_sub __PACKAGE__."::$method_to_proxy", sprintf( <<'EOC', $method_to_proxy ); + DBIx::Class::_ENV_::ASSERT_NO_INTERNAL_INDIRECT_CALLS and DBIx::Class::_Util::fail_on_internal_call; + shift->result_source_instance->%s (@_); +EOC + } 1;