From 9a6d7a8c18024b400174be8008b9f19c18a8131f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Remko=20Tron=C3=A7on?= Date: Sat, 14 May 2011 00:20:04 +0200 Subject: Cut dependency from AdHocCommandSession on DiscoItem. diff --git a/Swift/Controllers/AdHocManager.cpp b/Swift/Controllers/AdHocManager.cpp index 834aaec..e926138 100644 --- a/Swift/Controllers/AdHocManager.cpp +++ b/Swift/Controllers/AdHocManager.cpp @@ -8,6 +8,7 @@ #include #include +#include #include #include @@ -62,7 +63,7 @@ void AdHocManager::handleServerDiscoItemsResponse(boost::shared_ptr void AdHocManager::handleUIEvent(boost::shared_ptr event) { boost::shared_ptr adHocEvent = boost::dynamic_pointer_cast(event); if (adHocEvent) { - factory_->createAdHocCommandWindow(boost::shared_ptr(new OutgoingAdHocCommandSession(adHocEvent->getCommand(), iqRouter_))); + factory_->createAdHocCommandWindow(boost::make_shared(adHocEvent->getCommand().getJID(), adHocEvent->getCommand().getNode(), iqRouter_)); } } diff --git a/Swiften/AdHoc/OutgoingAdHocCommandSession.cpp b/Swiften/AdHoc/OutgoingAdHocCommandSession.cpp index 0632bbf..ecc6cd0 100644 --- a/Swiften/AdHoc/OutgoingAdHocCommandSession.cpp +++ b/Swiften/AdHoc/OutgoingAdHocCommandSession.cpp @@ -13,7 +13,7 @@ #include namespace Swift { -OutgoingAdHocCommandSession::OutgoingAdHocCommandSession(const DiscoItems::Item& command, IQRouter* iqRouter) : command_(command), iqRouter_(iqRouter), isMultiStage_(false) { +OutgoingAdHocCommandSession::OutgoingAdHocCommandSession(const JID& to, const std::string& commandNode, IQRouter* iqRouter) : to_(to), commandNode_(commandNode), iqRouter_(iqRouter), isMultiStage_(false) { } @@ -57,7 +57,7 @@ bool OutgoingAdHocCommandSession::getIsMultiStage() const { } void OutgoingAdHocCommandSession::start() { - boost::shared_ptr > commandRequest = boost::make_shared< GenericRequest >(IQ::Set, command_.getJID(), boost::make_shared(command_.getNode()), iqRouter_); + boost::shared_ptr > commandRequest = boost::make_shared< GenericRequest >(IQ::Set, to_, boost::make_shared(commandNode_), iqRouter_); commandRequest->onResponse.connect(boost::bind(&OutgoingAdHocCommandSession::handleResponse, this, _1, _2)); commandRequest->send(); } @@ -81,9 +81,9 @@ void OutgoingAdHocCommandSession::goNext(Form::ref form) { } void OutgoingAdHocCommandSession::submitForm(Form::ref form, Command::Action action) { - boost::shared_ptr command(boost::make_shared(command_.getNode(), sessionID_, action)); + boost::shared_ptr command(boost::make_shared(commandNode_, sessionID_, action)); command->setForm(form); - boost::shared_ptr > commandRequest = boost::make_shared< GenericRequest >(IQ::Set, command_.getJID(), command, iqRouter_); + boost::shared_ptr > commandRequest = boost::make_shared< GenericRequest >(IQ::Set, to_, command, iqRouter_); commandRequest->onResponse.connect(boost::bind(&OutgoingAdHocCommandSession::handleResponse, this, _1, _2)); commandRequest->send(); } diff --git a/Swiften/AdHoc/OutgoingAdHocCommandSession.h b/Swiften/AdHoc/OutgoingAdHocCommandSession.h index 6b80300..5c27022 100644 --- a/Swiften/AdHoc/OutgoingAdHocCommandSession.h +++ b/Swiften/AdHoc/OutgoingAdHocCommandSession.h @@ -29,7 +29,7 @@ namespace Swift { Enabled /** Action is applicable and currently available */ = 2, EnabledAndPresent = 3}; - OutgoingAdHocCommandSession(const DiscoItems::Item& command, IQRouter* iqRouter); + OutgoingAdHocCommandSession(const JID& to, const std::string& commandNode, IQRouter* iqRouter); /** * Send initial request to the target. */ @@ -82,7 +82,8 @@ namespace Swift { void submitForm(Form::ref, Command::Action action); private: - DiscoItems::Item command_; + JID to_; + std::string commandNode_; IQRouter* iqRouter_; bool isMultiStage_; std::string sessionID_; -- cgit v0.10.2-6-g49f6