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 | |
parent | cb32ea0954558da4bec9d4e9f13710a7f1a17d5a (diff) | |
download | swift-f52aa93c3d6d5976b072d31f3d3336beb1596ece.zip swift-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')
-rw-r--r-- | Swift/Controllers/XMPPEvents/EventController.cpp | 6 | ||||
-rw-r--r-- | Swift/Controllers/XMPPEvents/EventController.h | 4 |
2 files changed, 9 insertions, 1 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); diff --git a/Swift/Controllers/XMPPEvents/EventController.h b/Swift/Controllers/XMPPEvents/EventController.h index 61c5c47..1e0a069 100644 --- a/Swift/Controllers/XMPPEvents/EventController.h +++ b/Swift/Controllers/XMPPEvents/EventController.h @@ -17,10 +17,12 @@ namespace Swift { typedef std::vector<boost::shared_ptr<StanzaEvent> > EventList; - class EventController : public boost::bsignals::trackable{ + class EventController { public: EventController(); + ~EventController(); + void handleIncomingEvent(boost::shared_ptr<StanzaEvent> sourceEvent); boost::signal<void (int)> onEventQueueLengthChange; boost::signal<void (boost::shared_ptr<StanzaEvent>)> onEventQueueEventAdded; |