nidas v1.2.3
Public Member Functions | Static Public Member Functions | Protected Attributes | Private Member Functions | List of all members
nidas::core::XMLParser Class Reference

Wrapper class around xerces-c DOMBuilder to parse XML. More...

#include <XMLParser.h>

Inheritance diagram for nidas::core::XMLParser:
Inheritance graph
[legend]

Public Member Functions

 XMLParser ()
 Constructor.
 
virtual ~XMLParser ()
 Nuke the parser.
 
void setDOMValidation (bool val)
 DOMBuilder::setFilter is not yet implemented in xerces c++ 2.6.0 void setFilter(xercesc::DOMBuilderFilter* filter)
 
void setDOMValidateIfSchema (bool val)
 Enable/disable schema validation.
 
void setDOMNamespaces (bool val)
 Enable/disable namespace processing.
 
void setXercesSchema (bool val)
 Enable/disable schema support.
 
void setXercesSchemaFullChecking (bool val)
 Enable/disable full schema constraint checking, including checking which may be time-consuming or memory intensive.
 
void setDOMDatatypeNormalization (bool val)
 Enable/disable datatype normalization.
 
void setXercesUserAdoptsDOMDocument (bool val)
 Control who owns DOMDocument pointer.
 
void setXercesHandleMultipleImports (bool val)
 
void setXercesDoXInclude (bool val)
 
xercesc::DOMDocument * parse (const std::string &xmlFile, bool verbose=true)
 
xercesc::DOMDocument * parse (xercesc::InputSource &source)
 
xercesc::DOMDocument * parseString (const std::string &xml)
 Parse XML string into a document.
 

Static Public Member Functions

static xercesc::DOMDocument * ParseString (const std::string &xml)
 Call parseString() on a default XMLParser instance.
 

Protected Attributes

xercesc::DOMImplementation * _impl
 
xercesc::DOMLSParser * _parser
 
XMLErrorHandler _errorHandler
 

Private Member Functions

 XMLParser (const XMLParser &)
 No copying.
 
XMLParseroperator= (const XMLParser &)
 No assignment.
 

Detailed Description

Wrapper class around xerces-c DOMBuilder to parse XML.

Constructor & Destructor Documentation

◆ XMLParser() [1/2]

XMLParser::XMLParser ( )

◆ ~XMLParser()

XMLParser::~XMLParser ( )
virtual

Nuke the parser.

This does a release() (delete) of the associated DOMBuilder.

References _parser.

◆ XMLParser() [2/2]

nidas::core::XMLParser::XMLParser ( const XMLParser & )
private

No copying.

Member Function Documentation

◆ operator=()

XMLParser & nidas::core::XMLParser::operator= ( const XMLParser & )
private

No assignment.

◆ parse() [1/2]

xercesc::DOMDocument * XMLParser::parse ( const std::string & xmlFile,
bool verbose = true )

◆ parse() [2/2]

xercesc::DOMDocument * XMLParser::parse ( xercesc::InputSource & source)

◆ parseString()

xercesc::DOMDocument * XMLParser::parseString ( const std::string & xml)

Parse XML string into a document.

The returned DOMDocument pointer needs to be deleted, and before the XMLImplementation is terminated.

Parameters
xml
Returns
xercesc::DOMDocument*

References nidas::core::getSample(), and parse().

◆ ParseString()

xercesc::DOMDocument * XMLParser::ParseString ( const std::string & xml)
static

Call parseString() on a default XMLParser instance.

Parameters
xml
Returns
xercesc::DOMDocument*

References nidas::core::getSample().

Referenced by DataPrep::run().

◆ setDOMDatatypeNormalization()

void XMLParser::setDOMDatatypeNormalization ( bool val)

Enable/disable datatype normalization.

See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valIf true let the validation process do its datatype normalization that is defined in the used schema language. If false disable datatype normalization. The XML 1.0 attribute value normalization always occurs though.
Default: false.

References _parser.

◆ setDOMNamespaces()

void XMLParser::setDOMNamespaces ( bool val)

Enable/disable namespace processing.

See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valIf true perform namespace processing. Default: false.

References _parser.

◆ setDOMValidateIfSchema()

void XMLParser::setDOMValidateIfSchema ( bool val)

Enable/disable schema validation.

See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valIf true the parser will validate the document only if a grammar is specified. If false validation is determined by the state of the validation feature, see setDOMValidation().
Default: false.

References _parser.

◆ setDOMValidation()

void XMLParser::setDOMValidation ( bool val)

DOMBuilder::setFilter is not yet implemented in xerces c++ 2.6.0 void setFilter(xercesc::DOMBuilderFilter* filter)

Enable/disable validation. See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valBoolean value specifying whether to report all validation errors. Default: false.

References _parser.

◆ setXercesDoXInclude()

void XMLParser::setXercesDoXInclude ( bool val)

References _parser.

◆ setXercesHandleMultipleImports()

void XMLParser::setXercesHandleMultipleImports ( bool val)

References _parser.

◆ setXercesSchema()

void XMLParser::setXercesSchema ( bool val)

Enable/disable schema support.

See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valIf true enable the parser's schema support. Default: false.

References _parser.

◆ setXercesSchemaFullChecking()

void XMLParser::setXercesSchemaFullChecking ( bool val)

Enable/disable full schema constraint checking, including checking which may be time-consuming or memory intensive.

Currently, particle unique attribution constraint checking and particle derivation restriction checking are controlled by this option.
See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valIf true enable schema constraint checking. Default: false.

References _parser.

◆ setXercesUserAdoptsDOMDocument()

void XMLParser::setXercesUserAdoptsDOMDocument ( bool val)

Control who owns DOMDocument pointer.

See /link http://xml.apache.org/xerces-c/program-dom.html#DOMBuilderFeatures

Parameters
valIf true the caller will adopt the DOMDocument that is returned from the parse method and thus is responsible to call DOMDocument::release() to release the associated memory. The parser will not release it. The ownership is transferred from the parser to the caller. If false the returned DOMDocument from the parse method is owned by the parser and thus will be deleted when the parser is released.

References _parser.

Referenced by XMLParser().

Member Data Documentation

◆ _errorHandler

XMLErrorHandler nidas::core::XMLParser::_errorHandler
protected

Referenced by parse(), parse(), and XMLParser().

◆ _impl

xercesc::DOMImplementation* nidas::core::XMLParser::_impl
protected

Referenced by XMLParser().

◆ _parser

xercesc::DOMLSParser* nidas::core::XMLParser::_parser
protected

The documentation for this class was generated from the following files: