libdap Updated for version 3.21.1
libdap4 is an implementation of OPeNDAP's DAP protocol.
libdap::D4ParserSax2 Class Reference

#include <D4ParserSax2.h>

Collaboration diagram for libdap::D4ParserSax2:
Collaboration graph

Parser Actions

These methods are the 'actions' carried out by the start_element and end_element callbacks. Most of what takes place in those has been factored out to this set of functions.

class D4ParserSax2Test
 
 D4ParserSax2 ()
 
void intern (istream &f, DMR *dest_dmr, bool debug=false)
 
void intern (const string &document, DMR *dest_dmr, bool debug=false)
 
void intern (const char *buffer, int size, DMR *dest_dmr, bool debug=false)
 
void set_strict (bool s)
 Set the 'strict' mode to true or false.
 
bool get_strict () const
 Get the setting of the 'strict' mode.
 

SAX Parser Callbacks

These methods are declared static in the class header. This gives them C linkage which allows them to be used as callbacks by the SAX parser engine.

static void dmr_start_document (void *parser)
 
static void dmr_end_document (void *parser)
 
static void dmr_start_element (void *parser, const xmlChar *localname, const xmlChar *prefix, const xmlChar *URI, int nb_namespaces, const xmlChar **namespaces, int nb_attributes, int nb_defaulted, const xmlChar **attributes)
 
static void dmr_end_element (void *parser, const xmlChar *localname, const xmlChar *prefix, const xmlChar *URI)
 
static void dmr_get_characters (void *parser, const xmlChar *ch, int len)
 
static void dmr_ignoreable_whitespace (void *parser, const xmlChar *ch, int len)
 
static void dmr_get_cdata (void *parser, const xmlChar *value, int len)
 
static xmlEntityPtr dmr_get_entity (void *parser, const xmlChar *name)
 
static void dmr_fatal_error (void *parser, const char *msg,...)
 
static void dmr_error (void *parser, const char *msg,...)
 

Detailed Description

Parse the XML text which encodes the network/persistent representation of the DMR object. In the current implementation, the DMR is held by an instance of the class DDS which in turn holds variables which include attributes.

This parser for the DMR document uses the SAX interface of libxml2. Static methods are used as callbacks for the SAX parser. These static methods are public because making them private complicates compilation. They should not be called by anything other than the intern method. They do not throw exceptions because exceptions from within callbacks are not reliable or portable. To signal errors, the methods record information in the D4ParserSax2 object. Once the error handler is called, construction of an DMR object ends even though the SAX parser still calls the various callback functions. The parser treats warnings, errors and fatal_errors the same way; when any are found parsing stops. The intern method throws an Error of InternalErr exception if an error was found.

Note that this class uses the C++-supplied default definitions for the default and copy constructors as well as the destructor and assignment operator.

See also
DMR

Definition at line 76 of file D4ParserSax2.h.

Constructor & Destructor Documentation

◆ D4ParserSax2()

libdap::D4ParserSax2::D4ParserSax2 ( )
inline

Definition at line 255 of file D4ParserSax2.h.

Member Function Documentation

◆ intern() [1/3]

void libdap::D4ParserSax2::intern ( const char * buffer,
int size,
DMR * dest_dmr,
bool debug = false )

Parse a DMR document stored in a char *buffer.

Parameters
documentRead the DMR from this string.
dest_dmrValue/result parameter; dumps the information to this DMR instance.
debugIf true, ouput helpful debugging messages, False by default
Exceptions
ErrorThrown if the XML document could not be read or parsed.
InternalErrThrown if an internal error is found.

Definition at line 1371 of file D4ParserSax2.cc.

◆ intern() [2/3]

void libdap::D4ParserSax2::intern ( const string & document,
DMR * dest_dmr,
bool debug = false )

Parse a DMR document stored in a string.

Parameters
documentRead the DMR from this string.
dest_dmrValue/result parameter; dumps the information to this DMR instance.
debugIf true, output helpful debugging messages, False by default
Exceptions
ErrorThrown if the XML document could not be read or parsed.
InternalErrThrown if an internal error is found.
Deprecated
Remove this; it's confusing (looks like it's reading from a file with the name stored in 'document') and offers nothing more than the call below with the char* buffer.

Definition at line 1357 of file D4ParserSax2.cc.

◆ intern() [3/3]

void libdap::D4ParserSax2::intern ( istream & f,
DMR * dest_dmr,
bool debug = false )

Read the DMR from a stream.

Parameters
fThe input stream
dest_dmrValue-result parameter. Pass a pointer to a DMR in and the information in the DMR will be added to it.
boundaryIf not empty, use this as the boundary tag in a MPM document that marks the end of the part hat holds the DMR. Stop reading when the boundary is found.
debugIf true, ouput helpful debugging messages, False by default.
Exceptions
ErrorThrown if the XML document could not be read or parsed.
InternalErrThrown if an internal error is found.

Definition at line 1251 of file D4ParserSax2.cc.

Friends And Related Symbol Documentation

◆ D4ParserSax2Test

friend class D4ParserSax2Test
friend

Definition at line 252 of file D4ParserSax2.h.


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