From f0ddddce663e30a88c5c5246743145fe8dd8e11a Mon Sep 17 00:00:00 2001 From: Manjeet Dahiya Date: Thu, 23 Sep 2010 08:36:23 +0000 Subject: bugfixes and improvements --- examples/GuiClient/capabilitiesCollection.cpp | 30 ++++++++++++++++++++------- 1 file changed, 23 insertions(+), 7 deletions(-) (limited to 'examples/GuiClient/capabilitiesCollection.cpp') diff --git a/examples/GuiClient/capabilitiesCollection.cpp b/examples/GuiClient/capabilitiesCollection.cpp index 8b662342..ea3e5228 100644 --- a/examples/GuiClient/capabilitiesCollection.cpp +++ b/examples/GuiClient/capabilitiesCollection.cpp @@ -53,7 +53,21 @@ void capabilitiesCollection::requestInfo(const QString& jid, const QString& node QXmppDiscoveryManager* ext = m_client->findExtension(); if(ext) { - ext->requestInfo(jid, node); + bool alreadyRequested = false; + foreach(QString key, m_mapIdNodeVer.keys()) + { + if(m_mapIdNodeVer[key] == node) + { + alreadyRequested = true; + break; + } + } + + if(!alreadyRequested) + { + QString id = ext->requestInfo(jid, node); + m_mapIdNodeVer[id] = node; + } } } @@ -63,14 +77,16 @@ void capabilitiesCollection::infoReceived(const QXmppDiscoveryIq& discoIqRcv) if(discoIq.queryType() == QXmppDiscoveryIq::InfoQuery && discoIq.type() == QXmppIq::Result) { - if(!discoIq.queryNode().isEmpty()) + if(discoIq.queryNode().isEmpty()) { - discoIq.setTo(""); - discoIq.setFrom(""); - discoIq.setId(""); - m_mapCapabilities[discoIq.queryNode()] = discoIq; - saveToCache(discoIq.queryNode()); + discoIq.setQueryNode(m_mapIdNodeVer[discoIq.id()]); } + + discoIq.setTo(""); + discoIq.setFrom(""); + discoIq.setId(""); + m_mapCapabilities[discoIq.queryNode()] = discoIq; + saveToCache(discoIq.queryNode()); } } -- cgit v1.2.3