X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FStorage%2FDBI%2FODBC.pm;h=98ca586eb7f3de8a15e2cd159881fe01d72640b4;hb=ed7ab0f4ce1a9118ea6285ee562ef003085a6b64;hp=2b7790df519be659467de499552268cb8478ae7c;hpb=d88ecca6486a2b1c4b6e2f0440165b186aab39bc;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Storage/DBI/ODBC.pm b/lib/DBIx/Class/Storage/DBI/ODBC.pm index 2b7790d..98ca586 100644 --- a/lib/DBIx/Class/Storage/DBI/ODBC.pm +++ b/lib/DBIx/Class/Storage/DBI/ODBC.pm @@ -4,13 +4,17 @@ use warnings; use base qw/DBIx::Class::Storage::DBI/; use mro 'c3'; +use Try::Tiny; sub _rebless { my ($self) = @_; - my $dbtype = eval { $self->_get_dbh->get_info(17) }; + my $caught; + my $dbtype; + try { $self->_get_dbh->get_info(17) } + catch { $caught = 1 }; - unless ( $@ ) { + unless ( $caught ) { # Translate the backend name into a perl identifier $dbtype =~ s/\W/_/gi; my $subclass = "DBIx::Class::Storage::DBI::ODBC::${dbtype}"; @@ -21,15 +25,6 @@ sub _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; =head1 NAME