Skip to content

Commit

Permalink
[oracle] Fix potential crash on exit
Browse files Browse the repository at this point in the history
  • Loading branch information
nyalldawson committed Jul 12, 2016
1 parent aaa654f commit 2ccc7e1
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 3 deletions.
12 changes: 10 additions & 2 deletions src/providers/oracle/qgsoracleconnpool.cpp
Expand Up @@ -16,11 +16,19 @@
#include "qgsoracleconnpool.h"
#include "qgsoracleconn.h"

QgsOracleConnPool QgsOracleConnPool::sInstance;
QgsOracleConnPool* QgsOracleConnPool::sInstance = nullptr;

QgsOracleConnPool* QgsOracleConnPool::instance()
{
return &sInstance;
if ( !sInstance )
sInstance = new QgsOracleConnPool();
return sInstance;
}

void QgsOracleConnPool::cleanupInstance()
{
delete sInstance;
sInstance = nullptr;
}

QgsOracleConnPool::QgsOracleConnPool() : QgsConnectionPool<QgsOracleConn*, QgsOracleConnPoolGroup>()
Expand Down
4 changes: 3 additions & 1 deletion src/providers/oracle/qgsoracleconnpool.h
Expand Up @@ -70,14 +70,16 @@ class QgsOracleConnPool : public QgsConnectionPool<QgsOracleConn*, QgsOracleConn
public:
static QgsOracleConnPool* instance();

static void cleanupInstance();

protected:
Q_DISABLE_COPY( QgsOracleConnPool )

private:
QgsOracleConnPool();
~QgsOracleConnPool();

static QgsOracleConnPool sInstance;
static QgsOracleConnPool* sInstance;
};


Expand Down
5 changes: 5 additions & 0 deletions src/providers/oracle/qgsoracleprovider.cpp
Expand Up @@ -3177,6 +3177,11 @@ QGISEXTERN bool deleteLayer( const QString& uri, QString& errCause )
return true;
}

QGISEXTERN void cleanupProvider()
{
QgsOracleConnPool::cleanupInstance();
}

// ----------


Expand Down

0 comments on commit 2ccc7e1

Please sign in to comment.