X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FStorage%2FDBI%2FOracle.pm;h=722c62474031b473d9dc3f3bef052633a64954e9;hb=bf51641f97a504ae9796fcc45da4e409c6466ca4;hp=64bf9f182b67735b1bb62f07d6ac0bd0856c455c;hpb=eeb8cfeb91eebb5bd979202c234c9facf71f0b25;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Storage/DBI/Oracle.pm b/lib/DBIx/Class/Storage/DBI/Oracle.pm index 64bf9f1..722c624 100644 --- a/lib/DBIx/Class/Storage/DBI/Oracle.pm +++ b/lib/DBIx/Class/Storage/DBI/Oracle.pm @@ -4,39 +4,20 @@ use strict; use warnings; use base qw/DBIx::Class::Storage::DBI/; +use mro 'c3'; +use Try::Tiny; +use namespace::clean; sub _rebless { - my ($self) = @_; + my ($self) = @_; - my $version = eval { $self->_dbh->get_info(18); }; + # Default driver + my $class = $self->_server_info->{normalized_dbms_version} <= 8 + ? 'DBIx::Class::Storage::DBI::Oracle::WhereJoins' + : 'DBIx::Class::Storage::DBI::Oracle::Generic'; - if ( !$@ ) { - my ($major, $minor, $patchlevel) = split(/\./, $version); - - # Default driver - my $class = $major <= 8 - ? 'DBIx::Class::Storage::DBI::Oracle::WhereJoins' - : 'DBIx::Class::Storage::DBI::Oracle::Generic'; - - # Load and rebless - eval "require $class"; - - bless $self, $class unless $@; - } -} - -sub _svp_begin { - my ($self, $name) = @_; - - $self->dbh->do("SAVEPOINT $name"); -} - -# Would've implemented _svp_release here, but Oracle doesn't support it. - -sub _svp_rollback { - my ($self, $name) = @_; - - $self->dbh->do("ROLLBACK TO SAVEPOINT $name") + $self->ensure_class_loaded ($class); + bless $self, $class; } 1; @@ -45,11 +26,6 @@ sub _svp_rollback { DBIx::Class::Storage::DBI::Oracle - Base class for Oracle driver -=head1 SYNOPSIS - - # In your table classes - __PACKAGE__->load_components(qw/Core/); - =head1 DESCRIPTION This class simply provides a mechanism for discovering and loading a sub-class