summaryrefslogtreecommitdiff
path: root/qpid/cpp/src
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2012-05-14 15:55:03 +0000
committerAlan Conway <aconway@apache.org>2012-05-14 15:55:03 +0000
commit6bdb9fe2b2955a8ff5665ad2908136348c678383 (patch)
tree06ace33759e36c0228c832c780b1504dc6165c03 /qpid/cpp/src
parent64c967176bd2b2398bb3b2d69e2381f52be53747 (diff)
downloadqpid-python-6bdb9fe2b2955a8ff5665ad2908136348c678383.tar.gz
QPID-3603: Add finalizer for HaPlugin, fix hang on exit not responding to kill -TERM.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1338264 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src')
-rw-r--r--qpid/cpp/src/qpid/ha/HaPlugin.cpp11
1 files changed, 9 insertions, 2 deletions
diff --git a/qpid/cpp/src/qpid/ha/HaPlugin.cpp b/qpid/cpp/src/qpid/ha/HaPlugin.cpp
index 4da3b0d7d2..24977775bb 100644
--- a/qpid/cpp/src/qpid/ha/HaPlugin.cpp
+++ b/qpid/cpp/src/qpid/ha/HaPlugin.cpp
@@ -20,7 +20,7 @@
#include "qpid/Plugin.h"
#include "qpid/Options.h"
#include "qpid/broker/Broker.h"
-
+#include <boost/bind.hpp>
namespace qpid {
namespace ha {
@@ -66,7 +66,14 @@ struct HaPlugin : public Plugin {
void initialize(Plugin::Target& target) {
broker::Broker* broker = dynamic_cast<broker::Broker*>(&target);
- if (broker) haBroker.reset(new ha::HaBroker(*broker, settings));
+ if (broker) {
+ haBroker.reset(new ha::HaBroker(*broker, settings));
+ broker->addFinalizer(boost::bind(&HaPlugin::finalize, this));
+ }
+ }
+
+ void finalize() {
+ haBroker.reset();
}
};