1 package # hide from PAUSE
2 DBIx::Class::ResultSourceProxy;
7 use base 'DBIx::Class';
9 use DBIx::Class::_Util qw( quote_sub fail_on_internal_call );
12 __PACKAGE__->mk_group_accessors('inherited_ro_instance' => 'source_name');
14 sub get_inherited_ro_instance { $_[0]->get_inherited($_[1]) }
16 sub set_inherited_ro_instance {
17 $_[0]->throw_exception ("Cannot set '$_[1]' on an instance")
20 $_[0]->set_inherited( $_[1], $_[2] );
25 my ($class, @cols) = @_;
26 my $source = $class->result_source_instance;
27 $source->add_columns(@cols);
30 foreach my $c (grep { !ref } @cols) {
31 # If this is an augment definition get the real colname.
34 $class->register_column(
36 ( $colinfos ||= $source->columns_info )->{$c}
42 DBIx::Class::_ENV_::ASSERT_NO_INTERNAL_INDIRECT_CALLS and fail_on_internal_call;
43 shift->add_columns(@_)
47 sub add_relationship {
48 my ($class, $rel, @rest) = @_;
49 my $source = $class->result_source_instance;
50 $source->add_relationship($rel => @rest);
51 $class->register_relationship($rel => $source->relationship_info($rel));
55 # legacy resultset_class accessor, seems to be used by cdbi only
57 DBIx::Class::_ENV_::ASSERT_NO_INTERNAL_INDIRECT_CALLS and fail_on_internal_call;
58 shift->result_source_instance->resultset_class(@_)
61 for my $method_to_proxy (qw/
75 column_info_from_storage
82 add_unique_constraints
85 unique_constraint_names
86 unique_constraint_columns
92 quote_sub __PACKAGE__."::$method_to_proxy", sprintf( <<'EOC', $method_to_proxy );
93 DBIx::Class::_ENV_::ASSERT_NO_INTERNAL_INDIRECT_CALLS and DBIx::Class::_Util::fail_on_internal_call;
94 shift->result_source_instance->%s (@_);