diff options
| author | João Barbosa <[email protected]> | 2015-11-01 18:09:17 +0000 |
|---|---|---|
| committer | João Barbosa <[email protected]> | 2015-11-04 10:36:00 +0000 |
| commit | de0499d3b8352334357c8d60931cd5d2be5ab61d (patch) | |
| tree | debaa2e8f9671650860d827cedbdac27ca79b243 /src/zmq/zmqnotificationinterface.cpp | |
| parent | qt: translation update prior to opening 0.12 translations (diff) | |
| download | discoin-de0499d3b8352334357c8d60931cd5d2be5ab61d.tar.xz discoin-de0499d3b8352334357c8d60931cd5d2be5ab61d.zip | |
Fix ZMQ Notification initialization and shutdown
Moves the call Initialize() from init.cpp to CreateWithArguments() and handles the
return value. Moves the call Shutdown() from init.cpp to destructor.
Changes Initialize() and Shutdown() to protected members.
Diffstat (limited to 'src/zmq/zmqnotificationinterface.cpp')
| -rw-r--r-- | src/zmq/zmqnotificationinterface.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/zmq/zmqnotificationinterface.cpp b/src/zmq/zmqnotificationinterface.cpp index 388b86707..09fe3aeb4 100644 --- a/src/zmq/zmqnotificationinterface.cpp +++ b/src/zmq/zmqnotificationinterface.cpp @@ -21,8 +21,7 @@ CZMQNotificationInterface::CZMQNotificationInterface() : pcontext(NULL) CZMQNotificationInterface::~CZMQNotificationInterface() { - // ensure Shutdown if Initialize is called - assert(!pcontext); + Shutdown(); for (std::list<CZMQAbstractNotifier*>::iterator i=notifiers.begin(); i!=notifiers.end(); ++i) { @@ -59,6 +58,12 @@ CZMQNotificationInterface* CZMQNotificationInterface::CreateWithArguments(const { notificationInterface = new CZMQNotificationInterface(); notificationInterface->notifiers = notifiers; + + if (!notificationInterface->Initialize()) + { + delete notificationInterface; + notificationInterface = NULL; + } } return notificationInterface; @@ -99,7 +104,7 @@ bool CZMQNotificationInterface::Initialize() return false; } - return false; + return true; } // Called during shutdown sequence |