diff options
Diffstat (limited to 'Swiften/Parser/PayloadParsers/MAMFinParser.cpp')
-rw-r--r-- | Swiften/Parser/PayloadParsers/MAMFinParser.cpp | 64 |
1 files changed, 32 insertions, 32 deletions
diff --git a/Swiften/Parser/PayloadParsers/MAMFinParser.cpp b/Swiften/Parser/PayloadParsers/MAMFinParser.cpp index e972381..a29a7c4 100644 --- a/Swiften/Parser/PayloadParsers/MAMFinParser.cpp +++ b/Swiften/Parser/PayloadParsers/MAMFinParser.cpp @@ -20,42 +20,42 @@ MAMFinParser::MAMFinParser() : level_(TopLevel) { } void MAMFinParser::handleStartElement(const std::string& element, const std::string& ns, const AttributeMap& attributes) { - if (level_ == TopLevel) { - getPayloadInternal()->setComplete(attributes.getBoolAttribute("complete", false)); - getPayloadInternal()->setStable(attributes.getBoolAttribute("stable", true)); - boost::optional<std::string> attributeValue; - if ((attributeValue = attributes.getAttributeValue("queryid"))) { - getPayloadInternal()->setQueryID(*attributeValue); - } - } - else if (level_ == PayloadLevel) { - if (element == "set" && ns == "http://jabber.org/protocol/rsm") { - resultSetParser_ = boost::make_shared<ResultSetParser>(); - } - } - - if (resultSetParser_) { /* parsing a nested ResultSet */ - resultSetParser_->handleStartElement(element, ns, attributes); - } - - ++level_; + if (level_ == TopLevel) { + getPayloadInternal()->setComplete(attributes.getBoolAttribute("complete", false)); + getPayloadInternal()->setStable(attributes.getBoolAttribute("stable", true)); + boost::optional<std::string> attributeValue; + if ((attributeValue = attributes.getAttributeValue("queryid"))) { + getPayloadInternal()->setQueryID(*attributeValue); + } + } + else if (level_ == PayloadLevel) { + if (element == "set" && ns == "http://jabber.org/protocol/rsm") { + resultSetParser_ = boost::make_shared<ResultSetParser>(); + } + } + + if (resultSetParser_) { /* parsing a nested ResultSet */ + resultSetParser_->handleStartElement(element, ns, attributes); + } + + ++level_; } void MAMFinParser::handleEndElement(const std::string& element, const std::string& ns) { - --level_; - - if (resultSetParser_ && level_ >= PayloadLevel) { - resultSetParser_->handleEndElement(element, ns); - } - if (resultSetParser_ && level_ == PayloadLevel) { - /* done parsing nested ResultSet */ - getPayloadInternal()->setResultSet(boost::dynamic_pointer_cast<ResultSet>(resultSetParser_->getPayload())); - resultSetParser_.reset(); - } + --level_; + + if (resultSetParser_ && level_ >= PayloadLevel) { + resultSetParser_->handleEndElement(element, ns); + } + if (resultSetParser_ && level_ == PayloadLevel) { + /* done parsing nested ResultSet */ + getPayloadInternal()->setResultSet(boost::dynamic_pointer_cast<ResultSet>(resultSetParser_->getPayload())); + resultSetParser_.reset(); + } } void MAMFinParser::handleCharacterData(const std::string& data) { - if (resultSetParser_) { - resultSetParser_->handleCharacterData(data); - } + if (resultSetParser_) { + resultSetParser_->handleCharacterData(data); + } } |