X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FSchema%2FLoader%2FRelBuilder%2FCompat%2Fv0_05.pm;h=79e4a25f66d56c62b427339bfe6897903662b7aa;hb=023596033b27c52ba85a41181004cf960d84fb75;hp=56211173e8668bd212f8d6e57984de371800a2a7;hpb=19b7d71c67672e15f11ca6772963170fd6c6b588;p=dbsrgits%2FDBIx-Class-Schema-Loader.git diff --git a/lib/DBIx/Class/Schema/Loader/RelBuilder/Compat/v0_05.pm b/lib/DBIx/Class/Schema/Loader/RelBuilder/Compat/v0_05.pm index 5621117..79e4a25 100644 --- a/lib/DBIx/Class/Schema/Loader/RelBuilder/Compat/v0_05.pm +++ b/lib/DBIx/Class/Schema/Loader/RelBuilder/Compat/v0_05.pm @@ -2,12 +2,13 @@ package DBIx::Class::Schema::Loader::RelBuilder::Compat::v0_05; use strict; use warnings; -use Class::C3; use base 'DBIx::Class::Schema::Loader::RelBuilder::Compat::v0_06'; -use Carp::Clan qw/^DBIx::Class/; +use mro 'c3'; +use DBIx::Class::Schema::Loader::Utils 'array_eq'; +use namespace::clean; use Lingua::EN::Inflect::Number (); -our $VERSION = '0.07000'; +our $VERSION = '0.07036_03'; sub _to_PL { my ($self, $name) = @_; @@ -29,10 +30,10 @@ sub _relnames_and_method { my $remote_moniker = $rel->{remote_source}; my $remote_obj = $self->{schema}->source( $remote_moniker ); my $remote_class = $self->{schema}->class( $remote_moniker ); - my $remote_relname = $self->_remote_relname( $remote_obj->from, $cond); + my $remote_relname = $self->_remote_relname( $rel->{remote_table}, $cond); my $local_cols = $rel->{local_columns}; - my $local_table = $self->{schema}->source($local_moniker)->from; + my $local_table = $rel->{local_table}; # If more than one rel between this pair of tables, use the local # col names to distinguish @@ -44,20 +45,20 @@ sub _relnames_and_method { $local_relname = lc($local_table) . $colnames; $local_relname_uninflected = $local_relname; - $local_relname = $self->_inflect_plural( $local_relname ); + ($local_relname) = $self->_inflect_plural( $local_relname ); } else { $local_relname_uninflected = lc $local_table; - $local_relname = $self->_inflect_plural(lc $local_table); + ($local_relname) = $self->_inflect_plural(lc $local_table); } my $remote_method = 'has_many'; # If the local columns have a UNIQUE constraint, this is a one-to-one rel my $local_source = $self->{schema}->source($local_moniker); - if ($self->_array_eq([ $local_source->primary_columns ], $local_cols) || - grep { $self->_array_eq($_->[1], $local_cols) } @$uniqs) { + if (array_eq([ $local_source->primary_columns ], $local_cols) || + grep { array_eq($_->[1], $local_cols) } @$uniqs) { $remote_method = 'might_have'; - $local_relname = $self->_inflect_singular($local_relname_uninflected); + ($local_relname) = $self->_inflect_singular($local_relname_uninflected); } return ( $local_relname, $remote_relname, $remote_method );