mirror of
https://github.com/jezhiggins/arabica
synced 2025-01-15 15:40:56 +01:00
95 lines
4.8 KiB
C++
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
|