X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass.pm;h=79d763081faf13f5fdf623bcbd53f9a55210a2e4;hb=d009cb7d393292037eff527a9f8bab93860224fb;hp=a87cf4a50f6598f3e956b77c0193d22af7fef516;hpb=4b0a90fd521969ffded3f6cfe9fea95078326b07;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class.pm b/lib/DBIx/Class.pm index a87cf4a..79d7630 100644 --- a/lib/DBIx/Class.pm +++ b/lib/DBIx/Class.pm @@ -18,8 +18,6 @@ $VERSION = eval $VERSION if $VERSION =~ /_/; # numify for warning-free dev relea use DBIx::Class::_Util; use mro 'c3'; -use DBIx::Class::Optional::Dependencies; - use base qw/DBIx::Class::Componentised DBIx::Class::AccessorGroup/; use DBIx::Class::StartupCheck; use DBIx::Class::Exception; @@ -39,17 +37,19 @@ BEGIN { sub DESTROY { &DBIx::Class::_Util::detected_reinvoked_destructor }; } -sub mk_classdata { - shift->mk_classaccessor(@_); -} +sub component_base_class { 'DBIx::Class' } -sub mk_classaccessor { - my $self = shift; - $self->mk_group_accessors('inherited', $_[0]); - $self->set_inherited(@_) if @_ > 1; -} +my $mro_already_set; +sub inject_base { -sub component_base_class { 'DBIx::Class' } + # only examine from $_[2] onwards + # C::C3::C already sets c3 on $_[1] and $_[0] is irrelevant + mro::set_mro( $_ => 'c3' ) for grep { + $mro_already_set->{$_} ? 0 : ( $mro_already_set->{$_} = 1 ) + } @_[2 .. $#_]; + + shift->next::method(@_); +} sub MODIFY_CODE_ATTRIBUTES { my ($class,$code,@attrs) = @_; @@ -291,7 +291,7 @@ accessible at the following locations: =item * Travis-CI log: L =for html -↪ Stable branch CI status: +↪ Bleeding edge dev CI status: =back