diff options
author | Remko Tronçon <git@el-tramo.be> | 2010-10-15 16:09:08 (GMT) |
---|---|---|
committer | Remko Tronçon <git@el-tramo.be> | 2010-10-15 16:09:08 (GMT) |
commit | f52aa93c3d6d5976b072d31f3d3336beb1596ece (patch) | |
tree | 2435122519eda9e9612e18c32997b0510528e032 /Swift/Controllers/XMPPEvents/EventController.cpp | |
parent | cb32ea0954558da4bec9d4e9f13710a7f1a17d5a (diff) | |
download | swift-contrib-f52aa93c3d6d5976b072d31f3d3336beb1596ece.zip swift-contrib-f52aa93c3d6d5976b072d31f3d3336beb1596ece.tar.bz2 |
Fixed a segfault with pending events.
Release-Notes: Fixed a potential crash on signout when events are pending.
Diffstat (limited to 'Swift/Controllers/XMPPEvents/EventController.cpp')
-rw-r--r-- | Swift/Controllers/XMPPEvents/EventController.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/Swift/Controllers/XMPPEvents/EventController.cpp b/Swift/Controllers/XMPPEvents/EventController.cpp index 381a5a1..f2fdcfe 100644 --- a/Swift/Controllers/XMPPEvents/EventController.cpp +++ b/Swift/Controllers/XMPPEvents/EventController.cpp @@ -18,6 +18,12 @@ namespace Swift { EventController::EventController() { } +EventController::~EventController() { + foreach(boost::shared_ptr<StanzaEvent> event, events_) { + event->onConclusion.disconnect(boost::bind(&EventController::handleEventConcluded, this, event)); + } +} + void EventController::handleIncomingEvent(boost::shared_ptr<StanzaEvent> sourceEvent) { boost::shared_ptr<MessageEvent> messageEvent = boost::dynamic_pointer_cast<MessageEvent>(sourceEvent); boost::shared_ptr<SubscriptionRequestEvent> subscriptionEvent = boost::dynamic_pointer_cast<SubscriptionRequestEvent>(sourceEvent); |