diff options
| author | Remko Tronçon <git@el-tramo.be> | 2010-03-28 13:40:14 (GMT) | 
|---|---|---|
| committer | Remko Tronçon <git@el-tramo.be> | 2010-03-28 13:40:43 (GMT) | 
| commit | b61486fefe602e0d18fa5279021006f87b965307 (patch) | |
| tree | 437585cbef1179e1ec31f79789591d5610200c29 /Swiften/Server/ServerStanzaRouter.cpp | |
| parent | dae28dd45e43fc6e6ef2ec4c6c65d5d736ed86f8 (diff) | |
| download | swift-contrib-b61486fefe602e0d18fa5279021006f87b965307.zip swift-contrib-b61486fefe602e0d18fa5279021006f87b965307.tar.bz2 | |
Moved Swiften to a separate module.
Diffstat (limited to 'Swiften/Server/ServerStanzaRouter.cpp')
| m--------- | Swiften | 0 | ||||
| -rw-r--r-- | Swiften/Server/ServerStanzaRouter.cpp | 67 | 
2 files changed, 0 insertions, 67 deletions
| diff --git a/Swiften b/Swiften new file mode 160000 +Subproject 8213ba16d0043d2461f4b031c881d61dda5a38c diff --git a/Swiften/Server/ServerStanzaRouter.cpp b/Swiften/Server/ServerStanzaRouter.cpp deleted file mode 100644 index 5661de5..0000000 --- a/Swiften/Server/ServerStanzaRouter.cpp +++ /dev/null @@ -1,67 +0,0 @@ -#include "Swiften/Server/ServerStanzaRouter.h" -#include "Swiften/Server/ServerSession.h" - -#include <cassert> -#include <algorithm> - -namespace Swift { - -namespace { -	struct PriorityLessThan { -		bool operator()(const ServerSession* s1, const ServerSession* s2) const { -			return s1->getPriority() < s2->getPriority(); -		} -	}; - -	struct HasJID { -		HasJID(const JID& jid) : jid(jid) {} -		bool operator()(const ServerSession* session) const { -			return session->getJID().equals(jid, JID::WithResource); -		} -		JID jid; -	}; -} - -ServerStanzaRouter::ServerStanzaRouter() { -} - -bool ServerStanzaRouter::routeStanza(boost::shared_ptr<Stanza> stanza) { -	JID to = stanza->getTo(); -	assert(to.isValid()); - -	// For a full JID, first try to route to a session with the full JID -	if (!to.isBare()) { -		std::vector<ServerSession*>::const_iterator i = std::find_if(clientSessions_.begin(), clientSessions_.end(), HasJID(to)); -		if (i != clientSessions_.end()) { -			(*i)->sendStanza(stanza); -			return true; -		} -	} - -	// Look for candidate sessions -	to = to.toBare(); -	std::vector<ServerSession*> candidateSessions; -	for (std::vector<ServerSession*>::const_iterator i = clientSessions_.begin(); i != clientSessions_.end(); ++i) { -		if ((*i)->getJID().equals(to, JID::WithoutResource) && (*i)->getPriority() >= 0) { -			candidateSessions.push_back(*i); -		} -	} -	if (candidateSessions.empty()) { -		return false; -	} - -	// Find the session with the highest priority -	std::vector<ServerSession*>::const_iterator i = std::max_element(clientSessions_.begin(), clientSessions_.end(), PriorityLessThan()); -	(*i)->sendStanza(stanza); -	return true; -} - -void ServerStanzaRouter::addClientSession(ServerSession* clientSession) { -	clientSessions_.push_back(clientSession); -} - -void ServerStanzaRouter::removeClientSession(ServerSession* clientSession) { -	clientSessions_.erase(std::remove(clientSessions_.begin(), clientSessions_.end(), clientSession), clientSessions_.end()); -} - -} | 
 Swift
 Swift