summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/broker/Broker.cpp
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2008-02-07 21:31:21 +0000
committerAlan Conway <aconway@apache.org>2008-02-07 21:31:21 +0000
commit910fa22beb64c0c4d64221d9485830035c1663ff (patch)
tree77fcbee2777dab502d2e093eaa1e467a363557a0 /cpp/src/qpid/broker/Broker.cpp
parentcbd253b15b5ff540c2766cb52e67e28b58b57364 (diff)
downloadqpid-python-910fa22beb64c0c4d64221d9485830035c1663ff.tar.gz
Clean shutdown of broker: Moved signal unsafe code from Broker::shutdown
to ~Broker, moved shutdown logging from shutdown handler to main() in qpidd.cpp git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@619646 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/broker/Broker.cpp')
-rw-r--r--cpp/src/qpid/broker/Broker.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/cpp/src/qpid/broker/Broker.cpp b/cpp/src/qpid/broker/Broker.cpp
index 57ff7a550c..1d55db0c0f 100644
--- a/cpp/src/qpid/broker/Broker.cpp
+++ b/cpp/src/qpid/broker/Broker.cpp
@@ -212,13 +212,16 @@ void Broker::run() {
}
void Broker::shutdown() {
+ // NB: this function must be async-signal safe, it must not
+ // call any function that is not async-signal safe.
+ // Any unsafe shutdown actions should be done in the destructor.
if (acceptor)
acceptor->shutdown();
- ManagementAgent::shutdown ();
}
Broker::~Broker() {
shutdown();
+ ManagementAgent::shutdown ();
delete store;
}