diff options
author | Kevin Smith <git@kismith.co.uk> | 2010-04-12 14:16:23 (GMT) |
---|---|---|
committer | Kevin Smith <git@kismith.co.uk> | 2010-04-12 14:16:23 (GMT) |
commit | 9470b2eb602489b290f8df1aaf515712d9ea3dbf (patch) | |
tree | 8c222a8a00dc6f6f7d7fd22fd98fa66e5bd003a2 /Swift/Controllers | |
parent | a65372d1a0a85d04329cd91bcf6bdff2de492c80 (diff) | |
download | swift-contrib-9470b2eb602489b290f8df1aaf515712d9ea3dbf.zip swift-contrib-9470b2eb602489b290f8df1aaf515712d9ea3dbf.tar.bz2 |
Populate ErrorEvent for server disconnections.
Resolves: #303
Diffstat (limited to 'Swift/Controllers')
-rw-r--r-- | Swift/Controllers/MainController.cpp | 8 | ||||
-rw-r--r-- | Swift/Controllers/MainController.h | 2 |
2 files changed, 10 insertions, 0 deletions
diff --git a/Swift/Controllers/MainController.cpp b/Swift/Controllers/MainController.cpp index 1c83d1d..e20e9f8 100644 --- a/Swift/Controllers/MainController.cpp +++ b/Swift/Controllers/MainController.cpp @@ -161,6 +161,10 @@ void MainController::resetClient() { void MainController::handleConnected() { loginWindow_->setIsLoggingIn(false); + if (lastDisconnectError_) { + lastDisconnectError_->conclude(); + lastDisconnectError_ = boost::shared_ptr<ErrorEvent>(); + } //FIXME: this freshLogin thing is temporary so I can see what's what before I split into a seperate method. bool freshLogin = rosterController_ == NULL; if (freshLogin) { @@ -348,6 +352,10 @@ void MainController::handleError(const ClientError& error) { if (!rosterController_) { //hasn't been logged in yet signOut(); loginWindow_->setMessage(message); + } else { + message = "Disconnected from " + jid_.getDomain() + ": "; + lastDisconnectError_ = boost::shared_ptr<ErrorEvent>(new ErrorEvent(JID(jid_.getDomain()), message)); + eventController_->handleIncomingEvent(lastDisconnectError_); } logout(); if (rosterController_) { diff --git a/Swift/Controllers/MainController.h b/Swift/Controllers/MainController.h index 0056c21..5ed3641 100644 --- a/Swift/Controllers/MainController.h +++ b/Swift/Controllers/MainController.h @@ -23,6 +23,7 @@ #include "Swiften/Elements/Presence.h" #include "Swiften/Settings/SettingsProvider.h" #include "Swiften/Elements/CapsInfo.h" +#include "Swiften/Events/ErrorEvent.h" #include "Swiften/Roster/XMPPRoster.h" namespace Swift { @@ -125,5 +126,6 @@ namespace Swift { String password_; String certificateFile_; ChatListWindowFactory* chatListWindowFactory_; + boost::shared_ptr<ErrorEvent> lastDisconnectError_; }; } |