X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FResultSourceProxy%2FTable.pm;h=db82b4790f505df2677a4779d15cd81d356a5952;hb=9a6a7fdb92b50d48c7d132bdf28ca2a3ec28336a;hp=c326bcc56ae5886c69c50efd91fea7b4384dfa93;hpb=3d0487321f6ce0bd865ce97aaf5f636be45d0171;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/ResultSourceProxy/Table.pm b/lib/DBIx/Class/ResultSourceProxy/Table.pm index c326bcc..db82b47 100644 --- a/lib/DBIx/Class/ResultSourceProxy/Table.pm +++ b/lib/DBIx/Class/ResultSourceProxy/Table.pm @@ -23,8 +23,11 @@ sub _init_result_source_instance { my $class_has_table_instance = ($table and $table->result_class eq $class); return $table if $class_has_table_instance; + my $table_class = $class->table_class; + $class->ensure_class_loaded($table_class); + if( $table ) { - $table = $class->table_class->new({ + $table = $table_class->new({ %$table, result_class => $class, source_name => undef, @@ -32,7 +35,7 @@ sub _init_result_source_instance { }); } else { - $table = $class->table_class->new({ + $table = $table_class->new({ name => undef, result_class => $class, source_name => undef, @@ -68,7 +71,7 @@ Adds columns to the current class and creates accessors for them. =head2 table __PACKAGE__->table('tbl_name'); - + Gets or sets the table name. =cut @@ -78,7 +81,11 @@ sub table { return $class->result_source_instance->name unless $table; unless (Scalar::Util::blessed($table) && $table->isa($class->table_class)) { - $table = $class->table_class->new({ + + my $table_class = $class->table_class; + $class->ensure_class_loaded($table_class); + + $table = $table_class->new({ $class->can('result_source_instance') ? %{$class->result_source_instance||{}} : (), name => $table,