Applied patch from kados regarding use of a DateTime::Format class to validate
[dbsrgits/DBIx-Class-Historic.git] / lib / DBIx / Class / Componentised.pm
CommitLineData
75d07914 1package # hide from PAUSE
c0e7b4e5 2 DBIx::Class::Componentised;
227d4dee 3
bf5ecff9 4use strict;
5use warnings;
6
1680d317 7use base 'Class::C3::Componentised';
aaba9524 8use Carp::Clan qw/^DBIx::Class/;
147dd158 9
227d4dee 10sub inject_base {
11 my ($class, $target, @to_inject) = @_;
12 {
13 no strict 'refs';
eb47985e 14 foreach my $to (reverse @to_inject) {
df88a29c 15 my @comps = qw(DigestColumns ResultSetManager Ordered UTF8Columns);
16 # Add components here that need to be loaded before Core
17 foreach my $first_comp (@comps) {
18 if ($to eq 'DBIx::Class::Core' &&
19 $target->isa("DBIx::Class::${first_comp}")) {
341d5ede 20 carp "Possible incorrect order of components in ".
df88a29c 21 "${target}::load_components($first_comp) call: Core loaded ".
22 "before $first_comp. See the documentation for ".
23 "DBIx::Class::$first_comp for more information";
24 }
25 }
26 unshift( @{"${target}::ISA"}, $to )
27 unless ($target eq $to || $target->isa($to));
eb47985e 28 }
227d4dee 29 }
20518cb4 30
1680d317 31 $class->next::method($target, @to_inject);
efe6365b 32}
33
227d4dee 341;