X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FStorage%2FDBI%2FODBC.pm;h=d9b810ae42aea11abb881d8930f19feed22e3e3b;hb=84ccbc01107eeadbbac452d5368b4dd74f12ab8e;hp=e8b9c123e60d5d78e949e0fe8b64a7725d15751c;hpb=455833d94b90a5958a47fda7e3f73818377fb3d7;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Storage/DBI/ODBC.pm b/lib/DBIx/Class/Storage/DBI/ODBC.pm index e8b9c12..d9b810a 100644 --- a/lib/DBIx/Class/Storage/DBI/ODBC.pm +++ b/lib/DBIx/Class/Storage/DBI/ODBC.pm @@ -3,17 +3,21 @@ use strict; use warnings; use base qw/DBIx::Class::Storage::DBI/; +use mro 'c3'; sub _rebless { my ($self) = @_; - my $dbtype = eval { $self->_dbh->get_info(17) }; + my $dbtype = eval { $self->_get_dbh->get_info(17) }; + unless ( $@ ) { # Translate the backend name into a perl identifier $dbtype =~ s/\W/_/gi; - my $class = "DBIx::Class::Storage::DBI::ODBC::${dbtype}"; - eval "require $class"; - bless $self, $class unless $@; + my $subclass = "DBIx::Class::Storage::DBI::ODBC::${dbtype}"; + if ($self->load_optional_class($subclass) && !$self->isa($subclass)) { + bless $self, $subclass; + $self->_rebless; + } } }