X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FStorage%2FDBI%2FODBC.pm;h=7c3b739230c54f62a264f5cb0f43911340f1e082;hb=e6d6286068a0c2cba2e7026cfdddfbeb512a0770;hp=42466efbb844781c1634837f1ec7e5081bd03f1a;hpb=a9f32dbced12b2b6c4f8b8a7aa142d5922350830;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Storage/DBI/ODBC.pm b/lib/DBIx/Class/Storage/DBI/ODBC.pm index 42466ef..7c3b739 100644 --- a/lib/DBIx/Class/Storage/DBI/ODBC.pm +++ b/lib/DBIx/Class/Storage/DBI/ODBC.pm @@ -3,21 +3,32 @@ use strict; use warnings; use base qw/DBIx::Class::Storage::DBI/; +use mro 'c3'; sub _rebless { my ($self) = @_; - my $dbh = $self->dbh; - my $dbtype = eval { $dbh->get_info(17) }; + my $dbtype = eval { $self->last_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; + } } } +sub _dbh_last_insert_id { + my ($self, $dbh, $source, $col) = @_; + + # punt: if there is no derived class for the specific backend, attempt + # to use the DBI->last_insert_id, which may not be sufficient (see the + # discussion of last_insert_id in perldoc DBI) + return $dbh->last_insert_id(undef, undef, $source->from, $col); +} 1; @@ -39,7 +50,7 @@ for a specific ODBC backend. It should be transparent to the user. =head1 AUTHORS -Marc Mims C<< >> +Marc Mims C<< >> =head1 LICENSE