Я использую анализатор DOM Xerces C ++ для чтения некоторых файлов XML в проекте Visual C ++.У меня есть класс с методом parse()
, который должен прочитать и проверить мой исходный файл XML.Вот как выглядит метод:
#include <xercesc/util/PlatformUtils.hpp>
#include <xercesc/dom/DOM.hpp>
#include <xercesc/parsers/XercesDOMParser.hpp>
#include <xercesc/framework/LocalFileInputSource.hpp>
using namespace std;
XERCES_CPP_NAMESPACE_USE
unsigned long RulesParser::parse( const wstring &xmlFile )
{
if( parserInitialized_ == false ) {
try {
XMLPlatformUtils::Initialize(); /* initialize xerces */
} catch( XMLException const &e ) {
return Status::PARSER_INIT_FAIL;
}
}
parserInitialized_ = true; /* indicate xerces has been
successfully initialized */
if( pDOMParser_ != NULL ) {
delete pDOMParser_;
}
pDOMParser_ = new XercesDOMParser; /* create a DOM parser instance */
/* set xerces options */
pDOMParser_->setDoNamespaces( true ); /* enable namespace processing */
pDOMParser_->setDoSchema( true ); /* enable schema processing */
pDOMParser_->setValidationScheme( XercesDOMParser::Val_Always ); /* parser always validates */
pDOMParser_->setValidationSchemaFullChecking( true ); /* enable full schema checking */
auto_ptr< LocalFileInputSource > srcFile; /* XML source file loader */
try {
srcFile.reset( new LocalFileInputSource( xmlFile.c_str() ) );
} catch( const XMLException &e ) {
return Status::XML_SOURCE_LOAD_ERROR;
}
/* parse the file */
try {
pDOMParser_->parse( *srcFile );
} catch( const XMLException &e ) {
return Status::XML_SOURCE_PARSE_ERROR;
} catch( const DOMException &e ) {
return Status::XML_SOURCE_PARSE_DOM_ERROR;
}
return Status::OK;
}
Документация для LocalFileInputSource
говорит, что конструктор выдает XMLException
, если путь не разрешен к файлу.Однако я могу вызвать этот метод с любой произвольной строкой, и он выполняется до конца без каких-либо исключений.Что я делаю не так?
Кроме того, документация для XercesDOMParser::parse()
говорит, что SAXException
- это один из типов исключений, которые он может генерировать.Я нахожу это сбивающим с толку, потому что из того, что я понимаю, парсеры DOM и SAX являются двумя разными животными, так почему парсер DOM генерирует исключение SAX?