public abstract class BasicParserConfiguration extends ParserConfigurationSettings implements org.apache.xerces.xni.parser.XMLParserConfiguration
The basic parser configuration does not mandate
any particular pipeline configuration or the use of specific
components except for the symbol table. If even this is too much
for a basic parser configuration, the programmer can create a new
configuration class that implements the
XMLParserConfiguration
interface.
Subclasses of the basic parser configuration can add their own
recognized features and properties by calling the
addRecognizedFeature
and
addRecognizedProperty
methods, respectively.
The basic parser configuration assumes that the configuration
will be made up of various parser components that implement the
XMLComponent
interface. If subclasses of this
configuration create their own components for use in the
parser configuration, then each component should be added to
the list of components by calling the addComponent
method. The basic parser configuration will make sure to call
the reset
method of each registered component
before parsing an instance document.
This class recognizes the following features and properties:
Modifier and Type | Field and Description |
---|---|
protected static java.lang.String |
ENTITY_RESOLVER
Property identifier: entity resolver.
|
protected static java.lang.String |
ERROR_HANDLER
Property identifier: error handler.
|
protected static java.lang.String |
EXTERNAL_GENERAL_ENTITIES
Feature identifier: external general entities.
|
protected static java.lang.String |
EXTERNAL_PARAMETER_ENTITIES
Feature identifier: external parameter entities.
|
protected java.util.ArrayList |
fComponents
Components.
|
protected org.apache.xerces.xni.XMLDocumentHandler |
fDocumentHandler
The document handler.
|
protected org.apache.xerces.xni.XMLDTDContentModelHandler |
fDTDContentModelHandler
The DTD content model handler.
|
protected org.apache.xerces.xni.XMLDTDHandler |
fDTDHandler
The DTD handler.
|
protected org.apache.xerces.xni.parser.XMLDocumentSource |
fLastComponent
Last component in the document pipeline
|
protected java.util.Locale |
fLocale
Locale.
|
protected SymbolTable |
fSymbolTable
Symbol table.
|
protected static java.lang.String |
NAMESPACES
Feature identifier: namespaces.
|
protected static java.lang.String |
SYMBOL_TABLE
Property identifier: symbol table.
|
protected static java.lang.String |
VALIDATION
Feature identifier: validation.
|
protected static java.lang.String |
XML_STRING
Property identifier: xml string.
|
fFeatures, fParentSettings, fProperties, fRecognizedFeatures, fRecognizedProperties, PARSER_SETTINGS
Modifier | Constructor and Description |
---|---|
protected |
BasicParserConfiguration()
Default Constructor.
|
protected |
BasicParserConfiguration(SymbolTable symbolTable)
Constructs a parser configuration using the specified symbol table.
|
protected |
BasicParserConfiguration(SymbolTable symbolTable,
org.apache.xerces.xni.parser.XMLComponentManager parentSettings)
Constructs a parser configuration using the specified symbol table
and parent settings.
|
Modifier and Type | Method and Description |
---|---|
protected void |
addComponent(org.apache.xerces.xni.parser.XMLComponent component)
Adds a component to the parser configuration.
|
protected void |
checkFeature(java.lang.String featureId)
Check a feature.
|
protected void |
checkProperty(java.lang.String propertyId)
Check a property.
|
org.apache.xerces.xni.XMLDocumentHandler |
getDocumentHandler()
Returns the registered document handler.
|
org.apache.xerces.xni.XMLDTDContentModelHandler |
getDTDContentModelHandler()
Returns the registered DTD content model handler.
|
org.apache.xerces.xni.XMLDTDHandler |
getDTDHandler()
Returns the registered DTD handler.
|
org.apache.xerces.xni.parser.XMLEntityResolver |
getEntityResolver()
Return the current entity resolver.
|
org.apache.xerces.xni.parser.XMLErrorHandler |
getErrorHandler()
Return the current error handler.
|
java.util.Locale |
getLocale()
Returns the locale.
|
abstract void |
parse(org.apache.xerces.xni.parser.XMLInputSource inputSource)
Parse an XML document.
|
protected void |
reset()
reset all components before parsing and namespace context
|
void |
setDocumentHandler(org.apache.xerces.xni.XMLDocumentHandler documentHandler)
Sets the document handler on the last component in the pipeline
to receive information about the document.
|
void |
setDTDContentModelHandler(org.apache.xerces.xni.XMLDTDContentModelHandler handler)
Sets the DTD content model handler.
|
void |
setDTDHandler(org.apache.xerces.xni.XMLDTDHandler dtdHandler)
Sets the DTD handler.
|
void |
setEntityResolver(org.apache.xerces.xni.parser.XMLEntityResolver resolver)
Sets the resolver used to resolve external entities.
|
void |
setErrorHandler(org.apache.xerces.xni.parser.XMLErrorHandler errorHandler)
Allow an application to register an error event handler.
|
void |
setFeature(java.lang.String featureId,
boolean state)
Set the state of a feature.
|
void |
setLocale(java.util.Locale locale)
Set the locale to use for messages.
|
void |
setProperty(java.lang.String propertyId,
java.lang.Object value)
setProperty
|
addRecognizedFeatures, addRecognizedProperties, getFeature, getProperty
protected static final java.lang.String VALIDATION
protected static final java.lang.String NAMESPACES
protected static final java.lang.String EXTERNAL_GENERAL_ENTITIES
protected static final java.lang.String EXTERNAL_PARAMETER_ENTITIES
protected static final java.lang.String XML_STRING
protected static final java.lang.String SYMBOL_TABLE
protected static final java.lang.String ERROR_HANDLER
protected static final java.lang.String ENTITY_RESOLVER
protected SymbolTable fSymbolTable
protected java.util.Locale fLocale
protected java.util.ArrayList fComponents
protected org.apache.xerces.xni.XMLDocumentHandler fDocumentHandler
protected org.apache.xerces.xni.XMLDTDHandler fDTDHandler
protected org.apache.xerces.xni.XMLDTDContentModelHandler fDTDContentModelHandler
protected org.apache.xerces.xni.parser.XMLDocumentSource fLastComponent
protected BasicParserConfiguration()
protected BasicParserConfiguration(SymbolTable symbolTable)
symbolTable
- The symbol table to use.protected BasicParserConfiguration(SymbolTable symbolTable, org.apache.xerces.xni.parser.XMLComponentManager parentSettings)
symbolTable
- The symbol table to use.parentSettings
- The parent settings.protected void addComponent(org.apache.xerces.xni.parser.XMLComponent component)
component
- The component to add.public abstract void parse(org.apache.xerces.xni.parser.XMLInputSource inputSource) throws org.apache.xerces.xni.XNIException, java.io.IOException
The parser can use this method to instruct this configuration to begin parsing an XML document from any valid input source (a character stream, a byte stream, or a URI).
Parsers may not invoke this method while a parse is in progress. Once a parse is complete, the parser may then parse another XML document.
This method is synchronous: it will not return until parsing has ended. If a client application wants to terminate parsing early, it should throw an exception.
parse
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
inputSource
- The input source for the top-level of the
XML document.org.apache.xerces.xni.XNIException
- Any XNI exception, possibly wrapping
another exception.java.io.IOException
- An IO exception from the parser, possibly
from a byte stream or character stream
supplied by the parser.public void setDocumentHandler(org.apache.xerces.xni.XMLDocumentHandler documentHandler)
setDocumentHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
documentHandler
- The document handler.public org.apache.xerces.xni.XMLDocumentHandler getDocumentHandler()
getDocumentHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
public void setDTDHandler(org.apache.xerces.xni.XMLDTDHandler dtdHandler)
setDTDHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
dtdHandler
- The DTD handler.public org.apache.xerces.xni.XMLDTDHandler getDTDHandler()
getDTDHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
public void setDTDContentModelHandler(org.apache.xerces.xni.XMLDTDContentModelHandler handler)
setDTDContentModelHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
handler
- The DTD content model handler.public org.apache.xerces.xni.XMLDTDContentModelHandler getDTDContentModelHandler()
getDTDContentModelHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
public void setEntityResolver(org.apache.xerces.xni.parser.XMLEntityResolver resolver)
setEntityResolver
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
resolver
- The new entity resolver. Passing a null value will
uninstall the currently installed resolver.public org.apache.xerces.xni.parser.XMLEntityResolver getEntityResolver()
getEntityResolver
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
setEntityResolver(org.apache.xerces.xni.parser.XMLEntityResolver)
public void setErrorHandler(org.apache.xerces.xni.parser.XMLErrorHandler errorHandler)
If the application does not register an error handler, all error events reported by the SAX parser will be silently ignored; however, normal processing may not continue. It is highly recommended that all SAX applications implement an error handler to avoid unexpected bugs.
Applications may register a new or different handler in the middle of a parse, and the SAX parser must begin using the new handler immediately.
setErrorHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
errorHandler
- The error handler.java.lang.NullPointerException
- If the handler
argument is null.getErrorHandler()
public org.apache.xerces.xni.parser.XMLErrorHandler getErrorHandler()
getErrorHandler
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
setErrorHandler(org.apache.xerces.xni.parser.XMLErrorHandler)
public void setFeature(java.lang.String featureId, boolean state) throws org.apache.xerces.xni.parser.XMLConfigurationException
setFeature
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
setFeature
in class ParserConfigurationSettings
featureId
- The unique identifier (URI) of the feature.state
- The requested state of the feature (true or false).org.apache.xerces.xni.parser.XMLConfigurationException
- If the
requested feature is not known.public void setProperty(java.lang.String propertyId, java.lang.Object value) throws org.apache.xerces.xni.parser.XMLConfigurationException
setProperty
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
setProperty
in class ParserConfigurationSettings
propertyId
- value
- org.apache.xerces.xni.parser.XMLConfigurationException
- Thrown if there is a configuration
error.public void setLocale(java.util.Locale locale) throws org.apache.xerces.xni.XNIException
setLocale
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
locale
- The locale object to use for localization of messages.org.apache.xerces.xni.XNIException
- Thrown if the parser does not support the
specified locale.public java.util.Locale getLocale()
getLocale
in interface org.apache.xerces.xni.parser.XMLParserConfiguration
protected void reset() throws org.apache.xerces.xni.XNIException
org.apache.xerces.xni.XNIException
protected void checkProperty(java.lang.String propertyId) throws org.apache.xerces.xni.parser.XMLConfigurationException
checkProperty
in class ParserConfigurationSettings
propertyId
- The unique identifier (URI) of the property
being set.org.apache.xerces.xni.parser.XMLConfigurationException
- If the
requested feature is not known or supported.protected void checkFeature(java.lang.String featureId) throws org.apache.xerces.xni.parser.XMLConfigurationException
checkFeature
in class ParserConfigurationSettings
featureId
- The unique identifier (URI) of the feature.org.apache.xerces.xni.parser.XMLConfigurationException
- Thrown for configuration error.
In general, components should
only throw this exception if
it is really
a critical error.Copyright © 1999-2022 The Apache Software Foundation. All Rights Reserved.