summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--connectivity/source/manager/mdrivermanager.cxx24
-rw-r--r--connectivity/source/manager/mdrivermanager.hxx3
-rw-r--r--connectivity/source/manager/sdbc2.component4
3 files changed, 4 insertions, 27 deletions
diff --git a/connectivity/source/manager/mdrivermanager.cxx b/connectivity/source/manager/mdrivermanager.cxx
index 71bcb6c9e816..ae1e226cd2fc 100644
--- a/connectivity/source/manager/mdrivermanager.cxx
+++ b/connectivity/source/manager/mdrivermanager.cxx
@@ -29,17 +29,13 @@
#include <tools/diagnose_ex.h>
#include <cppuhelper/implbase.hxx>
#include <cppuhelper/supportsservice.hxx>
+#include <cppuhelper/weak.hxx>
#include <osl/diagnose.h>
-#include <rtl/ref.hxx>
#include <algorithm>
#include <iterator>
#include <vector>
-static osl::Mutex g_InstanceGuard;
-static rtl::Reference<drivermanager::OSDBCDriverManager> g_Instance;
-static bool g_Disposed = false;
-
namespace drivermanager
{
@@ -259,15 +255,6 @@ OSDBCDriverManager::~OSDBCDriverManager()
{
}
-// XComponent
-void SAL_CALL OSDBCDriverManager::dispose()
-{
- OSDBCDriverManager_Base::dispose();
- osl::MutexGuard aGuard(g_InstanceGuard);
- g_Instance.clear();
- g_Disposed = true;
-}
-
void OSDBCDriverManager::bootstrapDrivers()
{
Reference< XContentEnumerationAccess > xEnumAccess( m_xContext->getServiceManager(), UNO_QUERY );
@@ -671,13 +658,8 @@ extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
connectivity_OSDBCDriverManager_get_implementation(
css::uno::XComponentContext* context , css::uno::Sequence<css::uno::Any> const&)
{
- osl::MutexGuard aGuard(g_InstanceGuard);
- if (g_Disposed)
- return nullptr;
- if (!g_Instance)
- g_Instance.set(new drivermanager::OSDBCDriverManager(context));
- g_Instance->acquire();
- return static_cast<cppu::OWeakObject*>(g_Instance.get());
+ return cppu::acquire(
+ static_cast<cppu::OWeakObject*>(new drivermanager::OSDBCDriverManager(context)));
}
diff --git a/connectivity/source/manager/mdrivermanager.hxx b/connectivity/source/manager/mdrivermanager.hxx
index 20fc0a72df7b..09ccd11e05c3 100644
--- a/connectivity/source/manager/mdrivermanager.hxx
+++ b/connectivity/source/manager/mdrivermanager.hxx
@@ -81,9 +81,6 @@ namespace drivermanager
const css::uno::Reference< css::uno::XComponentContext >& _rxContext );
virtual ~OSDBCDriverManager() override;
- // XComponent
- virtual void SAL_CALL dispose() override;
-
// XDriverManager
virtual css::uno::Reference< css::sdbc::XConnection > SAL_CALL getConnection( const OUString& url ) override;
virtual css::uno::Reference< css::sdbc::XConnection > SAL_CALL getConnectionWithInfo( const OUString& url, const css::uno::Sequence< css::beans::PropertyValue >& info ) override;
diff --git a/connectivity/source/manager/sdbc2.component b/connectivity/source/manager/sdbc2.component
index 8797ec80a27c..b9433256aabf 100644
--- a/connectivity/source/manager/sdbc2.component
+++ b/connectivity/source/manager/sdbc2.component
@@ -20,9 +20,7 @@
<component loader="com.sun.star.loader.SharedLibrary" environment="@CPPU_ENV@"
xmlns="http://openoffice.org/2010/uno-components">
<implementation name="com.sun.star.comp.sdbc.OSDBCDriverManager"
- constructor="connectivity_OSDBCDriverManager_get_implementation">
- <!-- fake singleton so the servicemanager shuts us down and we can clean up our global instance var -->
- <singleton name="com.sun.star.comp.sdbc.theOSDBCDriverManager"/>
+ constructor="connectivity_OSDBCDriverManager_get_implementation" single-instance="true">
<service name="com.sun.star.sdbc.DriverManager"/>
</implementation>
</component>