arabica/include/SAX/helpers/FeatureNames.hpp

95 lines
4.8 KiB
C++

#ifndef ARABICA_FEATURE_NAMES_H
#define ARABICA_FEATURE_NAMES_H
/*
* $Id$
*/
#include <SAX/ArabicaConfig.hpp>
#include <Utils/StringAdaptor.hpp>
namespace Arabica
{
namespace SAX
{
template<class string_type, class string_adaptor = Arabica::default_string_adaptor<string_type> >
struct FeatureNames
{
/** Reports whether this parser processes external general entities; always
* true if validating. */
const string_type external_general;
/** Reports whether this parser processes external parameter entities; always
* true if validating. */
const string_type external_parameter;
/** May be examined only during a parse, after the startDocument() callback has
* been completed; read-only. The value is true if the document specified the
* "standalone" flag in its XML declaration, and otherwise is false. */
const string_type is_standalone;
/** True indicates that the LexicalHandler will report the beginning and end
* of parameter entities. */
const string_type lexical_parameter;
/** True indicates namespace URIs and unprefixed local names for element and
* attribute names will be available.*/
const string_type namespaces;
/** True indicates XML 1.0 names (with prefixes) and attributes (including
* xmlns* attributes) will be available. */
const string_type namespace_prefixes;
/** A value of "true" indicates that system IDs in declarations will be
* absolutized (relative to their base URIs) before reporting. (That is the
* default behavior for all SAX2 XML parsers.) A value of "false" indicates
* those IDs will not be absolutized; parsers will provide the base URI from
* Locator.getSystemId(). This applies to system IDs passed in
*
* - DTDHandler.notationDecl(),
* - DTDHandler.unparsedEntityDecl(), and
* - DeclHandler.externalEntityDecl().
*
*It does not apply to EntityResolver.resolveEntity(), which is not used to
report declarations, or to LexicalHandler.startDTD(), which already provides
the non-absolutized URI. */
const string_type resolve_dtd_uris;
/** Returns true if the Attributes objects passed by this parser in
* ContentHandler.startElement() implement the org.xml.sax.ext.Attributes2
* interface. That interface exposes additional DTD-related information, such
* as whether the attribute was specified in the source text rather than
* defaulted. */
const string_type use_attributes2;
/** Returns true if the Locator objects passed by this parser in
* ContentHandler.setDocumentLocator() implement the org.xml.sax.ext.Locator2
* interface. That interface exposes additional entity information, such as
* the character encoding and XML version used. */
const string_type use_locator2;
/** Controls whether the parser is reporting all validity errors; if true,
* all external entities will be read. */
const string_type validation;
/** Controls whether, when the namespace-prefixes feature is set, the parser
* treats namespace declaration attributes as being in the
* http://www.w3.org/2000/xmlns/ namespace. By default, SAX2 conforms to the
* original "Namespaces in XML" Recommendation, which explicitly states that
* such attributes are not in any namespace. Setting this optional flag to
* true makes the SAX2 events conform to a later backwards-incompatible
* revision of that recommendation, placing those attributes in a namespace.
* */
const string_type xmlns_uris;
FeatureNames() :
external_general(string_adaptor::construct_from_utf8("http://xml.org/sax/features/external-general-entities")),
external_parameter(string_adaptor::construct_from_utf8("http://xml.org/sax/features/external-parameter-entities")),
is_standalone(string_adaptor::construct_from_utf8("http://xml.org/sax/features/is-standalone")),
lexical_parameter(string_adaptor::construct_from_utf8("http://xml.org/sax/features/lexical-handler/parameter-entities")),
namespaces(string_adaptor::construct_from_utf8("http://xml.org/sax/features/namespaces")),
namespace_prefixes(string_adaptor::construct_from_utf8("http://xml.org/sax/features/namespace-prefixes")),
resolve_dtd_uris(string_adaptor::construct_from_utf8("http://xml.org/sax/features/resolve-dtd-uris")),
use_attributes2(string_adaptor::construct_from_utf8("http://xml.org/sax/features/use-attributes2")),
use_locator2(string_adaptor::construct_from_utf8("http://xml.org/sax/features/use-locator2")),
validation(string_adaptor::construct_from_utf8("http://xml.org/sax/features/validation")),
xmlns_uris(string_adaptor::construct_from_utf8("http://xml.org/sax/features/xmlns-uris"))
{
} // FeatureNames
}; // class FeatureNames
} // namespace SAX
} // namespace Arabica
#endif
// end of file