|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object fi.iki.hsivonen.gnu.xml.aelfred2.XmlReader
public final class XmlReader
This SAX2 parser optionally layers a validator over the Ælfred2 SAX2 parser. While this will not evaluate every XML validity constraint, it does support all the validity constraints that are of any real utility outside the strict SGML-compatible world. See the documentation for the SAXDriver class for information about the SAX2 features and properties that are supported, and documentation for the ValidationConsumer for information about what validity constraints may not be supported. (Ælfred2 tests some of those, even in non-validating mode, to achieve better conformance.)
Note that due to its internal construction, you can't change most handlers until parse() returns. This diverges slightly from SAX, which expects later binding to be supported. Early binding involves less runtime overhead, which is an issue for event pipelines as used inside this parser. Rather than relying on the parser to handle late binding to your own handlers, do it yourself.
SAXDriver
,
ValidationConsumer
Nested Class Summary | |
---|---|
(package private) static class |
XmlReader.FatalErrorHandler
|
Field Summary | |
---|---|
private boolean |
active
|
private SAXDriver |
aelfred2
|
private gnu.xml.pipeline.EventFilter |
filter
|
private boolean |
isValidating
|
Constructor Summary | |
---|---|
XmlReader()
Constructs a SAX Parser. |
|
XmlReader(boolean invalidIsFatal)
Constructs a SAX Parser, optionally treating validity errors as if they were fatal errors. |
Method Summary | |
---|---|
private void |
forceValidating()
|
ContentHandler |
getContentHandler()
SAX2: Returns the object used to report the logical content of an XML document. |
DTDHandler |
getDTDHandler()
SAX2: Returns the object used to process declarations related to notations and unparsed entities. |
EntityResolver |
getEntityResolver()
SAX2: Returns the object used when resolving external entities during parsing (both general and parameter entities). |
ErrorHandler |
getErrorHandler()
SAX2: Returns the object used to receive callbacks for XML errors of all levels (fatal, nonfatal, warning); this is never null; |
boolean |
getFeature(String featureId)
SAX2: Tells whether this parser supports the specified feature. |
Object |
getProperty(String propertyId)
SAX2: Returns the specified property. |
void |
parse(InputSource source)
SAX1: Underlying API to parse an XML document, used directly when no URI is available. |
void |
parse(String systemId)
SAX1: Preferred API to parse an XML document, using a system identifier (URI). |
void |
setContentHandler(ContentHandler handler)
SAX2: Assigns the object used to report the logical content of an XML document. |
void |
setDTDHandler(DTDHandler handler)
SAX1 Assigns DTD handler |
void |
setEntityResolver(EntityResolver handler)
SAX1 Assigns parser's entity resolver |
void |
setErrorHandler(ErrorHandler handler)
SAX1 Assigns error handler |
void |
setFeature(String featureId,
boolean state)
SAX2: Sets the state of features supported in this parser. |
void |
setLocale(Locale locale)
SAX1: Sets the locale used for diagnostics; currently, only locales using the English language are supported. |
void |
setProperty(String propertyId,
Object value)
SAX2: Assigns the specified property. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
private SAXDriver aelfred2
private gnu.xml.pipeline.EventFilter filter
private boolean isValidating
private boolean active
Constructor Detail |
---|
public XmlReader()
public XmlReader(boolean invalidIsFatal)
Method Detail |
---|
public ContentHandler getContentHandler()
getContentHandler
in interface XMLReader
public void setContentHandler(ContentHandler handler)
setContentHandler
in interface XMLReader
IllegalStateException
- if called mid-parsepublic DTDHandler getDTDHandler()
getDTDHandler
in interface XMLReader
public void setDTDHandler(DTDHandler handler)
setDTDHandler
in interface XMLReader
IllegalStateException
- if called mid-parsepublic EntityResolver getEntityResolver()
getEntityResolver
in interface XMLReader
public void setEntityResolver(EntityResolver handler)
setEntityResolver
in interface XMLReader
public ErrorHandler getErrorHandler()
getErrorHandler
in interface XMLReader
public void setErrorHandler(ErrorHandler handler)
setErrorHandler
in interface XMLReader
IllegalStateException
- if called mid-parsepublic void setProperty(String propertyId, Object value) throws SAXNotRecognizedException, SAXNotSupportedException
setProperty
in interface XMLReader
IllegalStateException
- if called mid-parse
SAXNotRecognizedException
SAXNotSupportedException
public Object getProperty(String propertyId) throws SAXNotRecognizedException
getProperty
in interface XMLReader
SAXNotRecognizedException
private void forceValidating() throws SAXNotRecognizedException, SAXNotSupportedException
SAXNotRecognizedException
SAXNotSupportedException
public void setFeature(String featureId, boolean state) throws SAXNotRecognizedException, SAXNotSupportedException
setFeature
in interface XMLReader
SAXNotRecognizedException
SAXNotSupportedException
public boolean getFeature(String featureId) throws SAXNotRecognizedException, SAXNotSupportedException
getFeature
in interface XMLReader
SAXNotRecognizedException
SAXNotSupportedException
SAXDriver
public void setLocale(Locale locale) throws SAXException
locale
- The locale for which diagnostics will be generated
SAXException
public void parse(String systemId) throws SAXException, IOException
parse
in interface XMLReader
SAXException
IOException
public void parse(InputSource source) throws SAXException, IOException
parse
in interface XMLReader
source
- The XML input source.
IllegalStateException
- if called mid-parse
SAXException
- The handlers may throw any SAXException,
and the parser normally throws SAXParseException objects.
IOException
- IOExceptions are normally through through
the parser if there are problems reading the source document.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |