blob: 035bb0b6f119f616ddbd55fcf8ad61df58fd7dfa [file] [log] [blame]
/*
* Copyright 2004 The WebRTC Project Authors. All rights reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "webrtc/libjingle/xmpp/xmppstanzaparser.h"
#include "webrtc/libjingle/xmllite/xmlelement.h"
#include "webrtc/libjingle/xmpp/constants.h"
#include "webrtc/base/common.h"
#ifdef EXPAT_RELATIVE_PATH
#include "expat.h"
#else
#include "third_party/expat/v2_0_1/Source/lib/expat.h"
#endif
namespace buzz {
XmppStanzaParser::XmppStanzaParser(XmppStanzaParseHandler *psph) :
psph_(psph),
innerHandler_(this),
parser_(&innerHandler_),
depth_(0),
builder_() {
}
void
XmppStanzaParser::Reset() {
parser_.Reset();
depth_ = 0;
builder_.Reset();
}
void
XmppStanzaParser::IncomingStartElement(
XmlParseContext * pctx, const char * name, const char ** atts) {
if (depth_++ == 0) {
XmlElement * pelStream = XmlBuilder::BuildElement(pctx, name, atts);
if (pelStream == NULL) {
pctx->RaiseError(XML_ERROR_SYNTAX);
return;
}
psph_->StartStream(pelStream);
delete pelStream;
return;
}
builder_.StartElement(pctx, name, atts);
}
void
XmppStanzaParser::IncomingCharacterData(
XmlParseContext * pctx, const char * text, int len) {
if (depth_ > 1) {
builder_.CharacterData(pctx, text, len);
}
}
void
XmppStanzaParser::IncomingEndElement(
XmlParseContext * pctx, const char * name) {
if (--depth_ == 0) {
psph_->EndStream();
return;
}
builder_.EndElement(pctx, name);
if (depth_ == 1) {
XmlElement *element = builder_.CreateElement();
psph_->Stanza(element);
delete element;
}
}
void
XmppStanzaParser::IncomingError(
XmlParseContext * pctx, XML_Error errCode) {
RTC_UNUSED(pctx);
RTC_UNUSED(errCode);
psph_->XmlError();
}
}