package DBIx::Class::Storage::DBI::ADO;
+use warnings;
+use strict;
+
use base 'DBIx::Class::Storage::DBI';
use mro 'c3';
+use Sub::Name;
+use Try::Tiny;
+use namespace::clean;
+
=head1 NAME
DBIx::Class::Storage::DBI::ADO - Support for L<DBD::ADO>
=cut
-sub _rebless {
- my $self = shift;
-
- my $dbtype = $self->_dbh_get_info(17);
-
- if (not $dbtype) {
- warn "Unable to determine ADO driver, failling back to generic support.\n";
- return;
- }
-
- $dbtype =~ s/\W/_/gi;
-
- my $subclass = "DBIx::Class::Storage::DBI::ADO::${dbtype}";
-
- if ($self->load_optional_class($subclass) && !$self->isa($subclass)) {
- bless $self, $subclass;
- $self->_rebless;
- }
- else {
- warn "Expected driver '$subclass' not found, using generic support. " .
- "Please file an RT.\n";
- }
-}
+sub _rebless { shift->_determine_connector_driver('ADO') }
# cleanup some warnings from DBD::ADO
# RT#65563, not fixed as of DBD::ADO v2.98
$self->next::method(@_);
}
+# Monkeypatch out the horrible warnings during global destruction.
+# A patch to DBD::ADO has been submitted as well, and it was fixed
+# as of 2.99
+# https://rt.cpan.org/Ticket/Display.html?id=65563
+sub _init {
+ unless ($DBD::ADO::__DBIC_MONKEYPATCH_CHECKED__) {
+ require DBD::ADO;
+
+ unless (try { DBD::ADO->VERSION('2.99'); 1 }) {
+ no warnings 'redefine';
+ my $disconnect = *DBD::ADO::db::disconnect{CODE};
+
+ *DBD::ADO::db::disconnect = subname 'DBD::ADO::db::disconnect' => sub {
+ my $warn_handler = $SIG{__WARN__} || sub { warn @_ };
+ local $SIG{__WARN__} = sub {
+ $warn_handler->(@_)
+ unless $_[0] =~ /Not a Win32::OLE object|uninitialized value/;
+ };
+ $disconnect->(@_);
+ };
+ }
+
+ $DBD::ADO::__DBIC_MONKEYPATCH_CHECKED__ = 1;
+ }
+}
+
# Here I was just experimenting with ADO cursor types, left in as a comment in
# case you want to as well. See the DBD::ADO docs.
-#sub _dbh_sth {
+#sub _prepare_sth {
# my ($self, $dbh, $sql) = @_;
#
# my $sth = $self->disable_sth_caching