mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-13 22:01:44 +08:00
Makefile.am (ordinary_java_source_files): Add org/xml/sax/helpers/NewInstance.java.
2002-12-19 Anthony Green <green@redhat.com> * Makefile.am (ordinary_java_source_files): Add org/xml/sax/helpers/NewInstance.java. * Makefile.in: Rebuilt. * org/xml/sax/package.html, org/xml/sax/ext/package.html, org/xml/sax/helpers/package.html: New files. * org/xml/sax/*: Upgrade to SAX 2.0.1 release from http://www.saxproject.org. From-SVN: r60350
This commit is contained in:
parent
51d6eed48e
commit
7a163ec05c
@ -1,3 +1,13 @@
|
||||
2002-12-19 Anthony Green <green@redhat.com>
|
||||
|
||||
* Makefile.am (ordinary_java_source_files): Add
|
||||
org/xml/sax/helpers/NewInstance.java.
|
||||
* Makefile.in: Rebuilt.
|
||||
* org/xml/sax/package.html, org/xml/sax/ext/package.html,
|
||||
org/xml/sax/helpers/package.html: New files.
|
||||
* org/xml/sax/*: Upgrade to SAX 2.0.1 release from
|
||||
http://www.saxproject.org.
|
||||
|
||||
2002-12-19 Andrew Haley <aph@redhat.com>
|
||||
|
||||
* java/util/natResourceBundle.cc: Include
|
||||
|
@ -2252,6 +2252,7 @@ org/xml/sax/helpers/AttributesImpl.java \
|
||||
org/xml/sax/helpers/DefaultHandler.java \
|
||||
org/xml/sax/helpers/LocatorImpl.java \
|
||||
org/xml/sax/helpers/NamespaceSupport.java \
|
||||
org/xml/sax/helpers/NewInstance.java \
|
||||
org/xml/sax/helpers/ParserAdapter.java \
|
||||
org/xml/sax/helpers/ParserFactory.java \
|
||||
org/xml/sax/helpers/XMLFilterImpl.java \
|
||||
|
@ -2002,6 +2002,7 @@ org/xml/sax/helpers/AttributesImpl.java \
|
||||
org/xml/sax/helpers/DefaultHandler.java \
|
||||
org/xml/sax/helpers/LocatorImpl.java \
|
||||
org/xml/sax/helpers/NamespaceSupport.java \
|
||||
org/xml/sax/helpers/NewInstance.java \
|
||||
org/xml/sax/helpers/ParserAdapter.java \
|
||||
org/xml/sax/helpers/ParserFactory.java \
|
||||
org/xml/sax/helpers/XMLFilterImpl.java \
|
||||
@ -3701,6 +3702,7 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \
|
||||
.deps/org/xml/sax/helpers/DefaultHandler.P \
|
||||
.deps/org/xml/sax/helpers/LocatorImpl.P \
|
||||
.deps/org/xml/sax/helpers/NamespaceSupport.P \
|
||||
.deps/org/xml/sax/helpers/NewInstance.P \
|
||||
.deps/org/xml/sax/helpers/ParserAdapter.P \
|
||||
.deps/org/xml/sax/helpers/ParserFactory.P \
|
||||
.deps/org/xml/sax/helpers/XMLFilterImpl.P \
|
||||
|
@ -1,191 +1,193 @@
|
||||
// SAX Attribute List Interface.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: AttributeList.java,v 1.1 2000/10/02 02:43:16 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Interface for an element's attribute specifications.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is the original SAX1 interface for reporting an element's
|
||||
* attributes. Unlike the new {@link org.xml.sax.Attributes Attributes}
|
||||
* interface, it does not support Namespace-related information.</p>
|
||||
*
|
||||
* <p>When an attribute list is supplied as part of a
|
||||
* {@link org.xml.sax.DocumentHandler#startElement startElement}
|
||||
* event, the list will return valid results only during the
|
||||
* scope of the event; once the event handler returns control
|
||||
* to the parser, the attribute list is invalid. To save a
|
||||
* persistent copy of the attribute list, use the SAX1
|
||||
* {@link org.xml.sax.helpers.AttributeListImpl AttributeListImpl}
|
||||
* helper class.</p>
|
||||
*
|
||||
* <p>An attribute list includes only attributes that have been
|
||||
* specified or defaulted: #IMPLIED attributes will not be included.</p>
|
||||
*
|
||||
* <p>There are two ways for the SAX application to obtain information
|
||||
* from the AttributeList. First, it can iterate through the entire
|
||||
* list:</p>
|
||||
*
|
||||
* <pre>
|
||||
* public void startElement (String name, AttributeList atts) {
|
||||
* for (int i = 0; i < atts.getLength(); i++) {
|
||||
* String name = atts.getName(i);
|
||||
* String type = atts.getType(i);
|
||||
* String value = atts.getValue(i);
|
||||
* [...]
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>(Note that the result of getLength() will be zero if there
|
||||
* are no attributes.)
|
||||
*
|
||||
* <p>As an alternative, the application can request the value or
|
||||
* type of specific attributes:</p>
|
||||
*
|
||||
* <pre>
|
||||
* public void startElement (String name, AttributeList atts) {
|
||||
* String identifier = atts.getValue("id");
|
||||
* String label = atts.getValue("label");
|
||||
* [...]
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* @deprecated This interface has been replaced by the SAX2
|
||||
* {@link org.xml.sax.Attributes Attributes}
|
||||
* interface, which includes Namespace support.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.DocumentHandler#startElement startElement
|
||||
* @see org.xml.sax.helpers.AttributeListImpl AttributeListImpl
|
||||
*/
|
||||
public interface AttributeList {
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Iteration methods.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the number of attributes in this list.
|
||||
*
|
||||
* <p>The SAX parser may provide attributes in any
|
||||
* arbitrary order, regardless of the order in which they were
|
||||
* declared or specified. The number of attributes may be
|
||||
* zero.</p>
|
||||
*
|
||||
* @return The number of attributes in the list.
|
||||
*/
|
||||
public abstract int getLength ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the name of an attribute in this list (by position).
|
||||
*
|
||||
* <p>The names must be unique: the SAX parser shall not include the
|
||||
* same attribute twice. Attributes without values (those declared
|
||||
* #IMPLIED without a value specified in the start tag) will be
|
||||
* omitted from the list.</p>
|
||||
*
|
||||
* <p>If the attribute name has a namespace prefix, the prefix
|
||||
* will still be attached.</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list (starting at 0).
|
||||
* @return The name of the indexed attribute, or null
|
||||
* if the index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getName (int i);
|
||||
|
||||
|
||||
/**
|
||||
* Return the type of an attribute in the list (by position).
|
||||
*
|
||||
* <p>The attribute type is one of the strings "CDATA", "ID",
|
||||
* "IDREF", "IDREFS", "NMTOKEN", "NMTOKENS", "ENTITY", "ENTITIES",
|
||||
* or "NOTATION" (always in upper case).</p>
|
||||
*
|
||||
* <p>If the parser has not read a declaration for the attribute,
|
||||
* or if the parser does not report attribute types, then it must
|
||||
* return the value "CDATA" as stated in the XML 1.0 Recommentation
|
||||
* (clause 3.3.3, "Attribute-Value Normalization").</p>
|
||||
*
|
||||
* <p>For an enumerated attribute that is not a notation, the
|
||||
* parser will report the type as "NMTOKEN".</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list (starting at 0).
|
||||
* @return The attribute type as a string, or
|
||||
* null if the index is out of range.
|
||||
* @see #getLength
|
||||
* @see #getType(java.lang.String)
|
||||
*/
|
||||
public abstract String getType (int i);
|
||||
|
||||
|
||||
/**
|
||||
* Return the value of an attribute in the list (by position).
|
||||
*
|
||||
* <p>If the attribute value is a list of tokens (IDREFS,
|
||||
* ENTITIES, or NMTOKENS), the tokens will be concatenated
|
||||
* into a single string separated by whitespace.</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list (starting at 0).
|
||||
* @return The attribute value as a string, or
|
||||
* null if the index is out of range.
|
||||
* @see #getLength
|
||||
* @see #getValue(java.lang.String)
|
||||
*/
|
||||
public abstract String getValue (int i);
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Lookup methods.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the type of an attribute in the list (by name).
|
||||
*
|
||||
* <p>The return value is the same as the return value for
|
||||
* getType(int).</p>
|
||||
*
|
||||
* <p>If the attribute name has a namespace prefix in the document,
|
||||
* the application must include the prefix here.</p>
|
||||
*
|
||||
* @param name The name of the attribute.
|
||||
* @return The attribute type as a string, or null if no
|
||||
* such attribute exists.
|
||||
* @see #getType(int)
|
||||
*/
|
||||
public abstract String getType (String name);
|
||||
|
||||
|
||||
/**
|
||||
* Return the value of an attribute in the list (by name).
|
||||
*
|
||||
* <p>The return value is the same as the return value for
|
||||
* getValue(int).</p>
|
||||
*
|
||||
* <p>If the attribute name has a namespace prefix in the document,
|
||||
* the application must include the prefix here.</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list.
|
||||
* @return The attribute value as a string, or null if
|
||||
* no such attribute exists.
|
||||
* @see #getValue(int)
|
||||
*/
|
||||
public abstract String getValue (String name);
|
||||
|
||||
}
|
||||
|
||||
// end of AttributeList.java
|
||||
// SAX Attribute List Interface.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: AttributeList.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Interface for an element's attribute specifications.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is the original SAX1 interface for reporting an element's
|
||||
* attributes. Unlike the new {@link org.xml.sax.Attributes Attributes}
|
||||
* interface, it does not support Namespace-related information.</p>
|
||||
*
|
||||
* <p>When an attribute list is supplied as part of a
|
||||
* {@link org.xml.sax.DocumentHandler#startElement startElement}
|
||||
* event, the list will return valid results only during the
|
||||
* scope of the event; once the event handler returns control
|
||||
* to the parser, the attribute list is invalid. To save a
|
||||
* persistent copy of the attribute list, use the SAX1
|
||||
* {@link org.xml.sax.helpers.AttributeListImpl AttributeListImpl}
|
||||
* helper class.</p>
|
||||
*
|
||||
* <p>An attribute list includes only attributes that have been
|
||||
* specified or defaulted: #IMPLIED attributes will not be included.</p>
|
||||
*
|
||||
* <p>There are two ways for the SAX application to obtain information
|
||||
* from the AttributeList. First, it can iterate through the entire
|
||||
* list:</p>
|
||||
*
|
||||
* <pre>
|
||||
* public void startElement (String name, AttributeList atts) {
|
||||
* for (int i = 0; i < atts.getLength(); i++) {
|
||||
* String name = atts.getName(i);
|
||||
* String type = atts.getType(i);
|
||||
* String value = atts.getValue(i);
|
||||
* [...]
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>(Note that the result of getLength() will be zero if there
|
||||
* are no attributes.)
|
||||
*
|
||||
* <p>As an alternative, the application can request the value or
|
||||
* type of specific attributes:</p>
|
||||
*
|
||||
* <pre>
|
||||
* public void startElement (String name, AttributeList atts) {
|
||||
* String identifier = atts.getValue("id");
|
||||
* String label = atts.getValue("label");
|
||||
* [...]
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* @deprecated This interface has been replaced by the SAX2
|
||||
* {@link org.xml.sax.Attributes Attributes}
|
||||
* interface, which includes Namespace support.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.DocumentHandler#startElement startElement
|
||||
* @see org.xml.sax.helpers.AttributeListImpl AttributeListImpl
|
||||
*/
|
||||
public interface AttributeList {
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Iteration methods.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the number of attributes in this list.
|
||||
*
|
||||
* <p>The SAX parser may provide attributes in any
|
||||
* arbitrary order, regardless of the order in which they were
|
||||
* declared or specified. The number of attributes may be
|
||||
* zero.</p>
|
||||
*
|
||||
* @return The number of attributes in the list.
|
||||
*/
|
||||
public abstract int getLength ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the name of an attribute in this list (by position).
|
||||
*
|
||||
* <p>The names must be unique: the SAX parser shall not include the
|
||||
* same attribute twice. Attributes without values (those declared
|
||||
* #IMPLIED without a value specified in the start tag) will be
|
||||
* omitted from the list.</p>
|
||||
*
|
||||
* <p>If the attribute name has a namespace prefix, the prefix
|
||||
* will still be attached.</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list (starting at 0).
|
||||
* @return The name of the indexed attribute, or null
|
||||
* if the index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getName (int i);
|
||||
|
||||
|
||||
/**
|
||||
* Return the type of an attribute in the list (by position).
|
||||
*
|
||||
* <p>The attribute type is one of the strings "CDATA", "ID",
|
||||
* "IDREF", "IDREFS", "NMTOKEN", "NMTOKENS", "ENTITY", "ENTITIES",
|
||||
* or "NOTATION" (always in upper case).</p>
|
||||
*
|
||||
* <p>If the parser has not read a declaration for the attribute,
|
||||
* or if the parser does not report attribute types, then it must
|
||||
* return the value "CDATA" as stated in the XML 1.0 Recommentation
|
||||
* (clause 3.3.3, "Attribute-Value Normalization").</p>
|
||||
*
|
||||
* <p>For an enumerated attribute that is not a notation, the
|
||||
* parser will report the type as "NMTOKEN".</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list (starting at 0).
|
||||
* @return The attribute type as a string, or
|
||||
* null if the index is out of range.
|
||||
* @see #getLength
|
||||
* @see #getType(java.lang.String)
|
||||
*/
|
||||
public abstract String getType (int i);
|
||||
|
||||
|
||||
/**
|
||||
* Return the value of an attribute in the list (by position).
|
||||
*
|
||||
* <p>If the attribute value is a list of tokens (IDREFS,
|
||||
* ENTITIES, or NMTOKENS), the tokens will be concatenated
|
||||
* into a single string separated by whitespace.</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list (starting at 0).
|
||||
* @return The attribute value as a string, or
|
||||
* null if the index is out of range.
|
||||
* @see #getLength
|
||||
* @see #getValue(java.lang.String)
|
||||
*/
|
||||
public abstract String getValue (int i);
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Lookup methods.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the type of an attribute in the list (by name).
|
||||
*
|
||||
* <p>The return value is the same as the return value for
|
||||
* getType(int).</p>
|
||||
*
|
||||
* <p>If the attribute name has a namespace prefix in the document,
|
||||
* the application must include the prefix here.</p>
|
||||
*
|
||||
* @param name The name of the attribute.
|
||||
* @return The attribute type as a string, or null if no
|
||||
* such attribute exists.
|
||||
* @see #getType(int)
|
||||
*/
|
||||
public abstract String getType (String name);
|
||||
|
||||
|
||||
/**
|
||||
* Return the value of an attribute in the list (by name).
|
||||
*
|
||||
* <p>The return value is the same as the return value for
|
||||
* getValue(int).</p>
|
||||
*
|
||||
* <p>If the attribute name has a namespace prefix in the document,
|
||||
* the application must include the prefix here.</p>
|
||||
*
|
||||
* @param i The index of the attribute in the list.
|
||||
* @return The attribute value as a string, or null if
|
||||
* no such attribute exists.
|
||||
* @see #getValue(int)
|
||||
*/
|
||||
public abstract String getValue (String name);
|
||||
|
||||
}
|
||||
|
||||
// end of AttributeList.java
|
||||
|
@ -1,243 +1,252 @@
|
||||
// Attributes.java - attribute list with Namespace support
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the public domain.
|
||||
|
||||
// $Id: Attributes.java,v 1.1 2000/10/02 02:43:16 sboag Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for a list of XML attributes.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This interface allows access to a list of attributes in
|
||||
* three different ways:</p>
|
||||
*
|
||||
* <ol>
|
||||
* <li>by attribute index;</li>
|
||||
* <li>by Namespace-qualified name; or</li>
|
||||
* <li>by qualified (prefixed) name.</li>
|
||||
* </ol>
|
||||
*
|
||||
* <p>The list will not contain attributes that were declared
|
||||
* #IMPLIED but not specified in the start tag. It will also not
|
||||
* contain attributes used as Namespace declarations (xmlns*) unless
|
||||
* the <code>http://xml.org/sax/features/namespace-prefixes</code>
|
||||
* feature is set to <var>true</var> (it is <var>false</var> by
|
||||
* default).</p>
|
||||
*
|
||||
* <p>If the namespace-prefixes feature (see above) is <var>false</var>,
|
||||
* access by qualified name may not be available; if the
|
||||
* <code>http://xml.org/sax/features/namespaces</code>
|
||||
* feature is <var>false</var>, access by Namespace-qualified names
|
||||
* may not be available.</p>
|
||||
*
|
||||
* <p>This interface replaces the now-deprecated SAX1 {@link
|
||||
* org.xml.sax.AttributeList AttributeList} interface, which does not
|
||||
* contain Namespace support. In addition to Namespace support, it
|
||||
* adds the <var>getIndex</var> methods (below).</p>
|
||||
*
|
||||
* <p>The order of attributes in the list is unspecified, and will
|
||||
* vary from implementation to implementation.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.helpers.AttributeListImpl
|
||||
*/
|
||||
public interface Attributes
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Indexed access.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the number of attributes in the list.
|
||||
*
|
||||
* <p>Once you know the number of attributes, you can iterate
|
||||
* through the list.</p>
|
||||
*
|
||||
* @return The number of attributes in the list.
|
||||
* @see #getURI(int)
|
||||
* @see #getLocalName(int)
|
||||
* @see #getQName(int)
|
||||
* @see #getType(int)
|
||||
* @see #getValue(int)
|
||||
*/
|
||||
public abstract int getLength ();
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's Namespace URI by index.
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The Namespace URI, or the empty string if none
|
||||
* is available, or null if the index is out of
|
||||
* range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getURI (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's local name by index.
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The local name, or the empty string if Namespace
|
||||
* processing is not being performed, or null
|
||||
* if the index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getLocalName (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's XML 1.0 qualified name by index.
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The XML 1.0 qualified name, or the empty string
|
||||
* if none is available, or null if the index
|
||||
* is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getQName (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's type by index.
|
||||
*
|
||||
* <p>The attribute type is one of the strings "CDATA", "ID",
|
||||
* "IDREF", "IDREFS", "NMTOKEN", "NMTOKENS", "ENTITY", "ENTITIES",
|
||||
* or "NOTATION" (always in upper case).</p>
|
||||
*
|
||||
* <p>If the parser has not read a declaration for the attribute,
|
||||
* or if the parser does not report attribute types, then it must
|
||||
* return the value "CDATA" as stated in the XML 1.0 Recommentation
|
||||
* (clause 3.3.3, "Attribute-Value Normalization").</p>
|
||||
*
|
||||
* <p>For an enumerated attribute that is not a notation, the
|
||||
* parser will report the type as "NMTOKEN".</p>
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The attribute's type as a string, or null if the
|
||||
* index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getType (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's value by index.
|
||||
*
|
||||
* <p>If the attribute value is a list of tokens (IDREFS,
|
||||
* ENTITIES, or NMTOKENS), the tokens will be concatenated
|
||||
* into a single string with each token separated by a
|
||||
* single space.</p>
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The attribute's value as a string, or null if the
|
||||
* index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getValue (int index);
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Name-based query.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Look up the index of an attribute by Namespace name.
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if
|
||||
* the name has no Namespace URI.
|
||||
* @param localName The attribute's local name.
|
||||
* @return The index of the attribute, or -1 if it does not
|
||||
* appear in the list.
|
||||
*/
|
||||
public int getIndex (String uri, String localPart);
|
||||
|
||||
|
||||
/**
|
||||
* Look up the index of an attribute by XML 1.0 qualified name.
|
||||
*
|
||||
* @param qName The qualified (prefixed) name.
|
||||
* @return The index of the attribute, or -1 if it does not
|
||||
* appear in the list.
|
||||
*/
|
||||
public int getIndex (String qName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's type by Namespace name.
|
||||
*
|
||||
* <p>See {@link #getType(int) getType(int)} for a description
|
||||
* of the possible types.</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty String if the
|
||||
* name has no Namespace URI.
|
||||
* @param localName The local name of the attribute.
|
||||
* @return The attribute type as a string, or null if the
|
||||
* attribute is not in the list or if Namespace
|
||||
* processing is not being performed.
|
||||
*/
|
||||
public abstract String getType (String uri, String localName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's type by XML 1.0 qualified name.
|
||||
*
|
||||
* <p>See {@link #getType(int) getType(int)} for a description
|
||||
* of the possible types.</p>
|
||||
*
|
||||
* @param qName The XML 1.0 qualified name.
|
||||
* @return The attribute type as a string, or null if the
|
||||
* attribute is not in the list or if qualified names
|
||||
* are not available.
|
||||
*/
|
||||
public abstract String getType (String qName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's value by Namespace name.
|
||||
*
|
||||
* <p>See {@link #getValue(int) getValue(int)} for a description
|
||||
* of the possible values.</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty String if the
|
||||
* name has no Namespace URI.
|
||||
* @param localName The local name of the attribute.
|
||||
* @return The attribute value as a string, or null if the
|
||||
* attribute is not in the list.
|
||||
*/
|
||||
public abstract String getValue (String uri, String localName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's value by XML 1.0 qualified name.
|
||||
*
|
||||
* <p>See {@link #getValue(int) getValue(int)} for a description
|
||||
* of the possible values.</p>
|
||||
*
|
||||
* @param qName The XML 1.0 qualified name.
|
||||
* @return The attribute value as a string, or null if the
|
||||
* attribute is not in the list or if qualified names
|
||||
* are not available.
|
||||
*/
|
||||
public abstract String getValue (String qName);
|
||||
|
||||
}
|
||||
|
||||
// end of Attributes.java
|
||||
// Attributes.java - attribute list with Namespace support
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the public domain.
|
||||
|
||||
// $Id: Attributes.java,v 1.5.2.4 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for a list of XML attributes.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This interface allows access to a list of attributes in
|
||||
* three different ways:</p>
|
||||
*
|
||||
* <ol>
|
||||
* <li>by attribute index;</li>
|
||||
* <li>by Namespace-qualified name; or</li>
|
||||
* <li>by qualified (prefixed) name.</li>
|
||||
* </ol>
|
||||
*
|
||||
* <p>The list will not contain attributes that were declared
|
||||
* #IMPLIED but not specified in the start tag. It will also not
|
||||
* contain attributes used as Namespace declarations (xmlns*) unless
|
||||
* the <code>http://xml.org/sax/features/namespace-prefixes</code>
|
||||
* feature is set to <var>true</var> (it is <var>false</var> by
|
||||
* default).
|
||||
* Because SAX2 conforms to the "Namespaces in XML" specification,
|
||||
* it does not give namespace declaration attributes a namespace URI.
|
||||
* Some other W3C specifications are in conflict with that, expecting
|
||||
* these declarations to be in a namespace.
|
||||
* Handler code may need to resolve that conflict.
|
||||
* </p>
|
||||
*
|
||||
* <p>If the namespace-prefixes feature (see above) is <var>false</var>,
|
||||
* access by qualified name may not be available; if the
|
||||
* <code>http://xml.org/sax/features/namespaces</code>
|
||||
* feature is <var>false</var>, access by Namespace-qualified names
|
||||
* may not be available.</p>
|
||||
*
|
||||
* <p>This interface replaces the now-deprecated SAX1 {@link
|
||||
* org.xml.sax.AttributeList AttributeList} interface, which does not
|
||||
* contain Namespace support. In addition to Namespace support, it
|
||||
* adds the <var>getIndex</var> methods (below).</p>
|
||||
*
|
||||
* <p>The order of attributes in the list is unspecified, and will
|
||||
* vary from implementation to implementation.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.helpers.AttributesImpl
|
||||
* @see org.xml.sax.ext.DeclHandler#attributeDecl
|
||||
*/
|
||||
public interface Attributes
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Indexed access.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the number of attributes in the list.
|
||||
*
|
||||
* <p>Once you know the number of attributes, you can iterate
|
||||
* through the list.</p>
|
||||
*
|
||||
* @return The number of attributes in the list.
|
||||
* @see #getURI(int)
|
||||
* @see #getLocalName(int)
|
||||
* @see #getQName(int)
|
||||
* @see #getType(int)
|
||||
* @see #getValue(int)
|
||||
*/
|
||||
public abstract int getLength ();
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's Namespace URI by index.
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The Namespace URI, or the empty string if none
|
||||
* is available, or null if the index is out of
|
||||
* range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getURI (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's local name by index.
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The local name, or the empty string if Namespace
|
||||
* processing is not being performed, or null
|
||||
* if the index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getLocalName (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's XML 1.0 qualified name by index.
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The XML 1.0 qualified name, or the empty string
|
||||
* if none is available, or null if the index
|
||||
* is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getQName (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's type by index.
|
||||
*
|
||||
* <p>The attribute type is one of the strings "CDATA", "ID",
|
||||
* "IDREF", "IDREFS", "NMTOKEN", "NMTOKENS", "ENTITY", "ENTITIES",
|
||||
* or "NOTATION" (always in upper case).</p>
|
||||
*
|
||||
* <p>If the parser has not read a declaration for the attribute,
|
||||
* or if the parser does not report attribute types, then it must
|
||||
* return the value "CDATA" as stated in the XML 1.0 Recommentation
|
||||
* (clause 3.3.3, "Attribute-Value Normalization").</p>
|
||||
*
|
||||
* <p>For an enumerated attribute that is not a notation, the
|
||||
* parser will report the type as "NMTOKEN".</p>
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The attribute's type as a string, or null if the
|
||||
* index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getType (int index);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's value by index.
|
||||
*
|
||||
* <p>If the attribute value is a list of tokens (IDREFS,
|
||||
* ENTITIES, or NMTOKENS), the tokens will be concatenated
|
||||
* into a single string with each token separated by a
|
||||
* single space.</p>
|
||||
*
|
||||
* @param index The attribute index (zero-based).
|
||||
* @return The attribute's value as a string, or null if the
|
||||
* index is out of range.
|
||||
* @see #getLength
|
||||
*/
|
||||
public abstract String getValue (int index);
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Name-based query.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Look up the index of an attribute by Namespace name.
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if
|
||||
* the name has no Namespace URI.
|
||||
* @param localName The attribute's local name.
|
||||
* @return The index of the attribute, or -1 if it does not
|
||||
* appear in the list.
|
||||
*/
|
||||
public int getIndex (String uri, String localName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up the index of an attribute by XML 1.0 qualified name.
|
||||
*
|
||||
* @param qName The qualified (prefixed) name.
|
||||
* @return The index of the attribute, or -1 if it does not
|
||||
* appear in the list.
|
||||
*/
|
||||
public int getIndex (String qName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's type by Namespace name.
|
||||
*
|
||||
* <p>See {@link #getType(int) getType(int)} for a description
|
||||
* of the possible types.</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty String if the
|
||||
* name has no Namespace URI.
|
||||
* @param localName The local name of the attribute.
|
||||
* @return The attribute type as a string, or null if the
|
||||
* attribute is not in the list or if Namespace
|
||||
* processing is not being performed.
|
||||
*/
|
||||
public abstract String getType (String uri, String localName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's type by XML 1.0 qualified name.
|
||||
*
|
||||
* <p>See {@link #getType(int) getType(int)} for a description
|
||||
* of the possible types.</p>
|
||||
*
|
||||
* @param qName The XML 1.0 qualified name.
|
||||
* @return The attribute type as a string, or null if the
|
||||
* attribute is not in the list or if qualified names
|
||||
* are not available.
|
||||
*/
|
||||
public abstract String getType (String qName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's value by Namespace name.
|
||||
*
|
||||
* <p>See {@link #getValue(int) getValue(int)} for a description
|
||||
* of the possible values.</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty String if the
|
||||
* name has no Namespace URI.
|
||||
* @param localName The local name of the attribute.
|
||||
* @return The attribute value as a string, or null if the
|
||||
* attribute is not in the list.
|
||||
*/
|
||||
public abstract String getValue (String uri, String localName);
|
||||
|
||||
|
||||
/**
|
||||
* Look up an attribute's value by XML 1.0 qualified name.
|
||||
*
|
||||
* <p>See {@link #getValue(int) getValue(int)} for a description
|
||||
* of the possible values.</p>
|
||||
*
|
||||
* @param qName The XML 1.0 qualified name.
|
||||
* @return The attribute value as a string, or null if the
|
||||
* attribute is not in the list or if qualified names
|
||||
* are not available.
|
||||
*/
|
||||
public abstract String getValue (String qName);
|
||||
|
||||
}
|
||||
|
||||
// end of Attributes.java
|
||||
|
@ -1,374 +1,408 @@
|
||||
// ContentHandler.java - handle main document content.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the public domain.
|
||||
|
||||
// $Id: ContentHandler.java,v 1.1 2000/10/02 02:43:16 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the logical content of a document.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is the main interface that most SAX applications
|
||||
* implement: if the application needs to be informed of basic parsing
|
||||
* events, it implements this interface and registers an instance with
|
||||
* the SAX parser using the {@link org.xml.sax.XMLReader#setContentHandler
|
||||
* setContentHandler} method. The parser uses the instance to report
|
||||
* basic document-related events like the start and end of elements
|
||||
* and character data.</p>
|
||||
*
|
||||
* <p>The order of events in this interface is very important, and
|
||||
* mirrors the order of information in the document itself. For
|
||||
* example, all of an element's content (character data, processing
|
||||
* instructions, and/or subelements) will appear, in order, between
|
||||
* the startElement event and the corresponding endElement event.</p>
|
||||
*
|
||||
* <p>This interface is similar to the now-deprecated SAX 1.0
|
||||
* DocumentHandler interface, but it adds support for Namespaces
|
||||
* and for reporting skipped entities (in non-validating XML
|
||||
* processors).</p>
|
||||
*
|
||||
* <p>Implementors should note that there is also a Java class
|
||||
* {@link java.net.ContentHandler ContentHandler} in the java.net
|
||||
* package; that means that it's probably a bad idea to do</p>
|
||||
*
|
||||
* <blockquote>
|
||||
* import java.net.*;
|
||||
* import org.xml.sax.*;
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>In fact, "import ...*" is usually a sign of sloppy programming
|
||||
* anyway, so the user should consider this a feature rather than a
|
||||
* bug.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.XMLReader
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public interface ContentHandler
|
||||
{
|
||||
|
||||
/**
|
||||
* Receive an object for locating the origin of SAX document events.
|
||||
*
|
||||
* <p>SAX parsers are strongly encouraged (though not absolutely
|
||||
* required) to supply a locator: if it does so, it must supply
|
||||
* the locator to the application by invoking this method before
|
||||
* invoking any of the other methods in the ContentHandler
|
||||
* interface.</p>
|
||||
*
|
||||
* <p>The locator allows the application to determine the end
|
||||
* position of any document-related event, even if the parser is
|
||||
* not reporting an error. Typically, the application will
|
||||
* use this information for reporting its own errors (such as
|
||||
* character content that does not match an application's
|
||||
* business rules). The information returned by the locator
|
||||
* is probably not sufficient for use with a search engine.</p>
|
||||
*
|
||||
* <p>Note that the locator will return correct information only
|
||||
* during the invocation of the events in this interface. The
|
||||
* application should not attempt to use it at any other time.</p>
|
||||
*
|
||||
* @param locator An object that can return the location of
|
||||
* any SAX document event.
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void setDocumentLocator (Locator locator);
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, before any
|
||||
* other methods in this interface or in {@link org.xml.sax.DTDHandler
|
||||
* DTDHandler} (except for {@link #setDocumentLocator
|
||||
* setDocumentLocator}).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #endDocument
|
||||
*/
|
||||
public void startDocument ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, and it will
|
||||
* be the last method invoked during the parse. The parser shall
|
||||
* not invoke this method until it has either abandoned parsing
|
||||
* (because of an unrecoverable error) or reached the end of
|
||||
* input.</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #startDocument
|
||||
*/
|
||||
public void endDocument()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Begin the scope of a prefix-URI Namespace mapping.
|
||||
*
|
||||
* <p>The information from this event is not necessary for
|
||||
* normal Namespace processing: the SAX XML reader will
|
||||
* automatically replace prefixes for element and attribute
|
||||
* names when the <code>http://xml.org/sax/features/namespaces</code>
|
||||
* feature is <var>true</var> (the default).</p>
|
||||
*
|
||||
* <p>There are cases, however, when applications need to
|
||||
* use prefixes in character data or in attribute values,
|
||||
* where they cannot safely be expanded automatically; the
|
||||
* start/endPrefixMapping event supplies the information
|
||||
* to the application to expand prefixes in those contexts
|
||||
* itself, if necessary.</p>
|
||||
*
|
||||
* <p>Note that start/endPrefixMapping events are not
|
||||
* guaranteed to be properly nested relative to each-other:
|
||||
* all startPrefixMapping events will occur before the
|
||||
* corresponding {@link #startElement startElement} event,
|
||||
* and all {@link #endPrefixMapping endPrefixMapping}
|
||||
* events will occur after the corresponding {@link #endElement
|
||||
* endElement} event, but their order is not otherwise
|
||||
* guaranteed.</p>
|
||||
*
|
||||
* <p>There should never be start/endPrefixMapping events for the
|
||||
* "xml" prefix, since it is predeclared and immutable.</p>
|
||||
*
|
||||
* @param prefix The Namespace prefix being declared.
|
||||
* @param uri The Namespace URI the prefix is mapped to.
|
||||
* @exception org.xml.sax.SAXException The client may throw
|
||||
* an exception during processing.
|
||||
* @see #endPrefixMapping
|
||||
* @see #startElement
|
||||
*/
|
||||
public void startPrefixMapping (String prefix, String uri)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* End the scope of a prefix-URI mapping.
|
||||
*
|
||||
* <p>See {@link #startPrefixMapping startPrefixMapping} for
|
||||
* details. This event will always occur after the corresponding
|
||||
* {@link #endElement endElement} event, but the order of
|
||||
* {@link #endPrefixMapping endPrefixMapping} events is not otherwise
|
||||
* guaranteed.</p>
|
||||
*
|
||||
* @param prefix The prefix that was being mapping.
|
||||
* @exception org.xml.sax.SAXException The client may throw
|
||||
* an exception during processing.
|
||||
* @see #startPrefixMapping
|
||||
* @see #endElement
|
||||
*/
|
||||
public void endPrefixMapping (String prefix)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of an element.
|
||||
*
|
||||
* <p>The Parser will invoke this method at the beginning of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* {@link #endElement endElement} event for every startElement event
|
||||
* (even when the element is empty). All of the element's content will be
|
||||
* reported, in order, before the corresponding endElement
|
||||
* event.</p>
|
||||
*
|
||||
* <p>This event allows up to three name components for each
|
||||
* element:</p>
|
||||
*
|
||||
* <ol>
|
||||
* <li>the Namespace URI;</li>
|
||||
* <li>the local name; and</li>
|
||||
* <li>the qualified (prefixed) name.</li>
|
||||
* </ol>
|
||||
*
|
||||
* <p>Any or all of these may be provided, depending on the
|
||||
* values of the <var>http://xml.org/sax/features/namespaces</var>
|
||||
* and the <var>http://xml.org/sax/features/namespace-prefixes</var>
|
||||
* properties:</p>
|
||||
*
|
||||
* <ul>
|
||||
* <li>the Namespace URI and local name are required when
|
||||
* the namespaces property is <var>true</var> (the default), and are
|
||||
* optional when the namespaces property is <var>false</var> (if one is
|
||||
* specified, both must be);</li>
|
||||
* <li>the qualified name is required when the namespace-prefixes property
|
||||
* is <var>true</var>, and is optional when the namespace-prefixes property
|
||||
* is <var>false</var> (the default).</li>
|
||||
* </ul>
|
||||
*
|
||||
* <p>Note that the attribute list provided will contain only
|
||||
* attributes with explicit values (specified or defaulted):
|
||||
* #IMPLIED attributes will be omitted. The attribute list
|
||||
* will contain attributes used for Namespace declarations
|
||||
* (xmlns* attributes) only if the
|
||||
* <code>http://xml.org/sax/features/namespace-prefixes</code>
|
||||
* property is true (it is false by default, and support for a
|
||||
* true value is optional).</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if the
|
||||
* element has no Namespace URI or if Namespace
|
||||
* processing is not being performed.
|
||||
* @param localName The local name (without prefix), or the
|
||||
* empty string if Namespace processing is not being
|
||||
* performed.
|
||||
* @param qName The qualified name (with prefix), or the
|
||||
* empty string if qualified names are not available.
|
||||
* @param atts The attributes attached to the element. If
|
||||
* there are no attributes, it shall be an empty
|
||||
* Attributes object.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #endElement
|
||||
* @see org.xml.sax.Attributes
|
||||
*/
|
||||
public void startElement (String namespaceURI, String localName,
|
||||
String qName, Attributes atts)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method at the end of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* {@link #startElement startElement} event for every endElement
|
||||
* event (even when the element is empty).</p>
|
||||
*
|
||||
* <p>For information on the names, see startElement.</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if the
|
||||
* element has no Namespace URI or if Namespace
|
||||
* processing is not being performed.
|
||||
* @param localName The local name (without prefix), or the
|
||||
* empty string if Namespace processing is not being
|
||||
* performed.
|
||||
* @param qName The qualified XML 1.0 name (with prefix), or the
|
||||
* empty string if qualified names are not available.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public void endElement (String namespaceURI, String localName,
|
||||
String qName)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data.
|
||||
*
|
||||
* <p>The Parser will call this method to report each chunk of
|
||||
* character data. SAX parsers may return all contiguous character
|
||||
* data in a single chunk, or they may split it into several
|
||||
* chunks; however, all of the characters in any single event
|
||||
* must come from the same external entity so that the Locator
|
||||
* provides useful information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* <p>Note that some parsers will report whitespace in element
|
||||
* content using the {@link #ignorableWhitespace ignorableWhitespace}
|
||||
* method rather than this one (validating parsers <em>must</em>
|
||||
* do so).</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #ignorableWhitespace
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void characters (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>Validating Parsers must use this method to report each chunk
|
||||
* of whitespace in element content (see the W3C XML 1.0 recommendation,
|
||||
* section 2.10): non-validating parsers may also use this method
|
||||
* if they are capable of parsing and using content models.</p>
|
||||
*
|
||||
* <p>SAX parsers may return all contiguous whitespace in a single
|
||||
* chunk, or they may split it into several chunks; however, all of
|
||||
* the characters in any single event must come from the same
|
||||
* external entity, so that the Locator provides useful
|
||||
* information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #characters
|
||||
*/
|
||||
public void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>The Parser will invoke this method once for each processing
|
||||
* instruction found: note that processing instructions may occur
|
||||
* before or after the main document element.</p>
|
||||
*
|
||||
* <p>A SAX parser must never report an XML declaration (XML 1.0,
|
||||
* section 2.8) or a text declaration (XML 1.0, section 4.3.1)
|
||||
* using this method.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none was supplied. The data does not include any
|
||||
* whitespace separating it from the target.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public void processingInstruction (String target, String data)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a skipped entity.
|
||||
*
|
||||
* <p>The Parser will invoke this method once for each entity
|
||||
* skipped. Non-validating processors may skip entities if they
|
||||
* have not seen the declarations (because, for example, the
|
||||
* entity was declared in an external DTD subset). All processors
|
||||
* may skip external entities, depending on the values of the
|
||||
* <code>http://xml.org/sax/features/external-general-entities</code>
|
||||
* and the
|
||||
* <code>http://xml.org/sax/features/external-parameter-entities</code>
|
||||
* properties.</p>
|
||||
*
|
||||
* @param name The name of the skipped entity. If it is a
|
||||
* parameter entity, the name will begin with '%', and if
|
||||
* it is the external DTD subset, it will be the string
|
||||
* "[dtd]".
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public void skippedEntity (String name)
|
||||
throws SAXException;
|
||||
}
|
||||
|
||||
// end of ContentHandler.java
|
||||
// ContentHandler.java - handle main document content.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the public domain.
|
||||
|
||||
// $Id: ContentHandler.java,v 1.4.2.9 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the logical content of a document.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is the main interface that most SAX applications
|
||||
* implement: if the application needs to be informed of basic parsing
|
||||
* events, it implements this interface and registers an instance with
|
||||
* the SAX parser using the {@link org.xml.sax.XMLReader#setContentHandler
|
||||
* setContentHandler} method. The parser uses the instance to report
|
||||
* basic document-related events like the start and end of elements
|
||||
* and character data.</p>
|
||||
*
|
||||
* <p>The order of events in this interface is very important, and
|
||||
* mirrors the order of information in the document itself. For
|
||||
* example, all of an element's content (character data, processing
|
||||
* instructions, and/or subelements) will appear, in order, between
|
||||
* the startElement event and the corresponding endElement event.</p>
|
||||
*
|
||||
* <p>This interface is similar to the now-deprecated SAX 1.0
|
||||
* DocumentHandler interface, but it adds support for Namespaces
|
||||
* and for reporting skipped entities (in non-validating XML
|
||||
* processors).</p>
|
||||
*
|
||||
* <p>Implementors should note that there is also a Java class
|
||||
* {@link java.net.ContentHandler ContentHandler} in the java.net
|
||||
* package; that means that it's probably a bad idea to do</p>
|
||||
*
|
||||
* <blockquote>
|
||||
* import java.net.*;
|
||||
* import org.xml.sax.*;
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>In fact, "import ...*" is usually a sign of sloppy programming
|
||||
* anyway, so the user should consider this a feature rather than a
|
||||
* bug.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.XMLReader
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public interface ContentHandler
|
||||
{
|
||||
|
||||
/**
|
||||
* Receive an object for locating the origin of SAX document events.
|
||||
*
|
||||
* <p>SAX parsers are strongly encouraged (though not absolutely
|
||||
* required) to supply a locator: if it does so, it must supply
|
||||
* the locator to the application by invoking this method before
|
||||
* invoking any of the other methods in the ContentHandler
|
||||
* interface.</p>
|
||||
*
|
||||
* <p>The locator allows the application to determine the end
|
||||
* position of any document-related event, even if the parser is
|
||||
* not reporting an error. Typically, the application will
|
||||
* use this information for reporting its own errors (such as
|
||||
* character content that does not match an application's
|
||||
* business rules). The information returned by the locator
|
||||
* is probably not sufficient for use with a search engine.</p>
|
||||
*
|
||||
* <p>Note that the locator will return correct information only
|
||||
* during the invocation of the events in this interface. The
|
||||
* application should not attempt to use it at any other time.</p>
|
||||
*
|
||||
* @param locator An object that can return the location of
|
||||
* any SAX document event.
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void setDocumentLocator (Locator locator);
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, before any
|
||||
* other event callbacks (except for {@link #setDocumentLocator
|
||||
* setDocumentLocator}).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #endDocument
|
||||
*/
|
||||
public void startDocument ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, and it will
|
||||
* be the last method invoked during the parse. The parser shall
|
||||
* not invoke this method until it has either abandoned parsing
|
||||
* (because of an unrecoverable error) or reached the end of
|
||||
* input.</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #startDocument
|
||||
*/
|
||||
public void endDocument()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Begin the scope of a prefix-URI Namespace mapping.
|
||||
*
|
||||
* <p>The information from this event is not necessary for
|
||||
* normal Namespace processing: the SAX XML reader will
|
||||
* automatically replace prefixes for element and attribute
|
||||
* names when the <code>http://xml.org/sax/features/namespaces</code>
|
||||
* feature is <var>true</var> (the default).</p>
|
||||
*
|
||||
* <p>There are cases, however, when applications need to
|
||||
* use prefixes in character data or in attribute values,
|
||||
* where they cannot safely be expanded automatically; the
|
||||
* start/endPrefixMapping event supplies the information
|
||||
* to the application to expand prefixes in those contexts
|
||||
* itself, if necessary.</p>
|
||||
*
|
||||
* <p>Note that start/endPrefixMapping events are not
|
||||
* guaranteed to be properly nested relative to each other:
|
||||
* all startPrefixMapping events will occur immediately before the
|
||||
* corresponding {@link #startElement startElement} event,
|
||||
* and all {@link #endPrefixMapping endPrefixMapping}
|
||||
* events will occur immediately after the corresponding
|
||||
* {@link #endElement endElement} event,
|
||||
* but their order is not otherwise
|
||||
* guaranteed.</p>
|
||||
*
|
||||
* <p>There should never be start/endPrefixMapping events for the
|
||||
* "xml" prefix, since it is predeclared and immutable.</p>
|
||||
*
|
||||
* @param prefix The Namespace prefix being declared.
|
||||
* An empty string is used for the default element namespace,
|
||||
* which has no prefix.
|
||||
* @param uri The Namespace URI the prefix is mapped to.
|
||||
* @exception org.xml.sax.SAXException The client may throw
|
||||
* an exception during processing.
|
||||
* @see #endPrefixMapping
|
||||
* @see #startElement
|
||||
*/
|
||||
public void startPrefixMapping (String prefix, String uri)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* End the scope of a prefix-URI mapping.
|
||||
*
|
||||
* <p>See {@link #startPrefixMapping startPrefixMapping} for
|
||||
* details. These events will always occur immediately after the
|
||||
* corresponding {@link #endElement endElement} event, but the order of
|
||||
* {@link #endPrefixMapping endPrefixMapping} events is not otherwise
|
||||
* guaranteed.</p>
|
||||
*
|
||||
* @param prefix The prefix that was being mapping.
|
||||
* This is the empty string when a default mapping scope ends.
|
||||
* @exception org.xml.sax.SAXException The client may throw
|
||||
* an exception during processing.
|
||||
* @see #startPrefixMapping
|
||||
* @see #endElement
|
||||
*/
|
||||
public void endPrefixMapping (String prefix)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of an element.
|
||||
*
|
||||
* <p>The Parser will invoke this method at the beginning of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* {@link #endElement endElement} event for every startElement event
|
||||
* (even when the element is empty). All of the element's content will be
|
||||
* reported, in order, before the corresponding endElement
|
||||
* event.</p>
|
||||
*
|
||||
* <p>This event allows up to three name components for each
|
||||
* element:</p>
|
||||
*
|
||||
* <ol>
|
||||
* <li>the Namespace URI;</li>
|
||||
* <li>the local name; and</li>
|
||||
* <li>the qualified (prefixed) name.</li>
|
||||
* </ol>
|
||||
*
|
||||
* <p>Any or all of these may be provided, depending on the
|
||||
* values of the <var>http://xml.org/sax/features/namespaces</var>
|
||||
* and the <var>http://xml.org/sax/features/namespace-prefixes</var>
|
||||
* properties:</p>
|
||||
*
|
||||
* <ul>
|
||||
* <li>the Namespace URI and local name are required when
|
||||
* the namespaces property is <var>true</var> (the default), and are
|
||||
* optional when the namespaces property is <var>false</var> (if one is
|
||||
* specified, both must be);</li>
|
||||
* <li>the qualified name is required when the namespace-prefixes property
|
||||
* is <var>true</var>, and is optional when the namespace-prefixes property
|
||||
* is <var>false</var> (the default).</li>
|
||||
* </ul>
|
||||
*
|
||||
* <p>Note that the attribute list provided will contain only
|
||||
* attributes with explicit values (specified or defaulted):
|
||||
* #IMPLIED attributes will be omitted. The attribute list
|
||||
* will contain attributes used for Namespace declarations
|
||||
* (xmlns* attributes) only if the
|
||||
* <code>http://xml.org/sax/features/namespace-prefixes</code>
|
||||
* property is true (it is false by default, and support for a
|
||||
* true value is optional).</p>
|
||||
*
|
||||
* <p>Like {@link #characters characters()}, attribute values may have
|
||||
* characters that need more than one <code>char</code> value. </p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if the
|
||||
* element has no Namespace URI or if Namespace
|
||||
* processing is not being performed.
|
||||
* @param localName The local name (without prefix), or the
|
||||
* empty string if Namespace processing is not being
|
||||
* performed.
|
||||
* @param qName The qualified name (with prefix), or the
|
||||
* empty string if qualified names are not available.
|
||||
* @param atts The attributes attached to the element. If
|
||||
* there are no attributes, it shall be an empty
|
||||
* Attributes object.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #endElement
|
||||
* @see org.xml.sax.Attributes
|
||||
*/
|
||||
public void startElement (String uri, String localName,
|
||||
String qName, Attributes atts)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method at the end of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* {@link #startElement startElement} event for every endElement
|
||||
* event (even when the element is empty).</p>
|
||||
*
|
||||
* <p>For information on the names, see startElement.</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if the
|
||||
* element has no Namespace URI or if Namespace
|
||||
* processing is not being performed.
|
||||
* @param localName The local name (without prefix), or the
|
||||
* empty string if Namespace processing is not being
|
||||
* performed.
|
||||
* @param qName The qualified XML 1.0 name (with prefix), or the
|
||||
* empty string if qualified names are not available.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public void endElement (String uri, String localName,
|
||||
String qName)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data.
|
||||
*
|
||||
* <p>The Parser will call this method to report each chunk of
|
||||
* character data. SAX parsers may return all contiguous character
|
||||
* data in a single chunk, or they may split it into several
|
||||
* chunks; however, all of the characters in any single event
|
||||
* must come from the same external entity so that the Locator
|
||||
* provides useful information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* <p>Individual characters may consist of more than one Java
|
||||
* <code>char</code> value. There are two important cases where this
|
||||
* happens, because characters can't be represented in just sixteen bits.
|
||||
* In one case, characters are represented in a <em>Surrogate Pair</em>,
|
||||
* using two special Unicode values. Such characters are in the so-called
|
||||
* "Astral Planes", with a code point above U+FFFF. A second case involves
|
||||
* composite characters, such as a base character combining with one or
|
||||
* more accent characters. </p>
|
||||
*
|
||||
* <p> Your code should not assume that algorithms using
|
||||
* <code>char</code>-at-a-time idioms will be working in character
|
||||
* units; in some cases they will split characters. This is relevant
|
||||
* wherever XML permits arbitrary characters, such as attribute values,
|
||||
* processing instruction data, and comments as well as in data reported
|
||||
* from this method. It's also generally relevant whenever Java code
|
||||
* manipulates internationalized text; the issue isn't unique to XML.</p>
|
||||
*
|
||||
* <p>Note that some parsers will report whitespace in element
|
||||
* content using the {@link #ignorableWhitespace ignorableWhitespace}
|
||||
* method rather than this one (validating parsers <em>must</em>
|
||||
* do so).</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #ignorableWhitespace
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void characters (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>Validating Parsers must use this method to report each chunk
|
||||
* of whitespace in element content (see the W3C XML 1.0 recommendation,
|
||||
* section 2.10): non-validating parsers may also use this method
|
||||
* if they are capable of parsing and using content models.</p>
|
||||
*
|
||||
* <p>SAX parsers may return all contiguous whitespace in a single
|
||||
* chunk, or they may split it into several chunks; however, all of
|
||||
* the characters in any single event must come from the same
|
||||
* external entity, so that the Locator provides useful
|
||||
* information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #characters
|
||||
*/
|
||||
public void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>The Parser will invoke this method once for each processing
|
||||
* instruction found: note that processing instructions may occur
|
||||
* before or after the main document element.</p>
|
||||
*
|
||||
* <p>A SAX parser must never report an XML declaration (XML 1.0,
|
||||
* section 2.8) or a text declaration (XML 1.0, section 4.3.1)
|
||||
* using this method.</p>
|
||||
*
|
||||
* <p>Like {@link #characters characters()}, processing instruction
|
||||
* data may have characters that need more than one <code>char</code>
|
||||
* value. </p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none was supplied. The data does not include any
|
||||
* whitespace separating it from the target.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public void processingInstruction (String target, String data)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a skipped entity.
|
||||
* This is not called for entity references within markup constructs
|
||||
* such as element start tags or markup declarations. (The XML
|
||||
* recommendation requires reporting skipped external entities.
|
||||
* SAX also reports internal entity expansion/non-expansion, except
|
||||
* within markup constructs.)
|
||||
*
|
||||
* <p>The Parser will invoke this method each time the entity is
|
||||
* skipped. Non-validating processors may skip entities if they
|
||||
* have not seen the declarations (because, for example, the
|
||||
* entity was declared in an external DTD subset). All processors
|
||||
* may skip external entities, depending on the values of the
|
||||
* <code>http://xml.org/sax/features/external-general-entities</code>
|
||||
* and the
|
||||
* <code>http://xml.org/sax/features/external-parameter-entities</code>
|
||||
* properties.</p>
|
||||
*
|
||||
* @param name The name of the skipped entity. If it is a
|
||||
* parameter entity, the name will begin with '%', and if
|
||||
* it is the external DTD subset, it will be the string
|
||||
* "[dtd]".
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public void skippedEntity (String name)
|
||||
throws SAXException;
|
||||
}
|
||||
|
||||
// end of ContentHandler.java
|
||||
|
@ -1,108 +1,117 @@
|
||||
// SAX DTD handler.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: DTDHandler.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Receive notification of basic DTD-related events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX application needs information about notations and
|
||||
* unparsed entities, then the application implements this
|
||||
* interface and registers an instance with the SAX parser using
|
||||
* the parser's setDTDHandler method. The parser uses the
|
||||
* instance to report notation and unparsed entity declarations to
|
||||
* the application.</p>
|
||||
*
|
||||
* <p>Note that this interface includes only those DTD events that
|
||||
* the XML recommendation <em>requires</em> processors to report:
|
||||
* notation and unparsed entity declarations.</p>
|
||||
*
|
||||
* <p>The SAX parser may report these events in any order, regardless
|
||||
* of the order in which the notations and unparsed entities were
|
||||
* declared; however, all DTD events must be reported after the
|
||||
* document handler's startDocument event, and before the first
|
||||
* startElement event.</p>
|
||||
*
|
||||
* <p>It is up to the application to store the information for
|
||||
* future use (perhaps in a hash table or object tree).
|
||||
* If the application encounters attributes of type "NOTATION",
|
||||
* "ENTITY", or "ENTITIES", it can use the information that it
|
||||
* obtained through this interface to find the entity and/or
|
||||
* notation corresponding with the attribute value.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Parser#setDTDHandler
|
||||
* @see org.xml.sax.HandlerBase
|
||||
*/
|
||||
public interface DTDHandler {
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a notation declaration event.
|
||||
*
|
||||
* <p>It is up to the application to record the notation for later
|
||||
* reference, if necessary.</p>
|
||||
*
|
||||
* <p>At least one of publicId and systemId must be non-null.
|
||||
* If a system identifier is present, and it is a URL, the SAX
|
||||
* parser must resolve it fully before passing it to the
|
||||
* application through this event.</p>
|
||||
*
|
||||
* <p>There is no guarantee that the notation declaration will be
|
||||
* reported before any unparsed entities that use it.</p>
|
||||
*
|
||||
* @param name The notation name.
|
||||
* @param publicId The notation's public identifier, or null if
|
||||
* none was given.
|
||||
* @param systemId The notation's system identifier, or null if
|
||||
* none was given.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #unparsedEntityDecl
|
||||
* @see org.xml.sax.AttributeList
|
||||
*/
|
||||
public abstract void notationDecl (String name,
|
||||
String publicId,
|
||||
String systemId)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of an unparsed entity declaration event.
|
||||
*
|
||||
* <p>Note that the notation name corresponds to a notation
|
||||
* reported by the {@link #notationDecl notationDecl} event.
|
||||
* It is up to the application to record the entity for later
|
||||
* reference, if necessary.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the parser must resolve it
|
||||
* fully before passing it to the application.</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @param name The unparsed entity's name.
|
||||
* @param publicId The entity's public identifier, or null if none
|
||||
* was given.
|
||||
* @param systemId The entity's system identifier.
|
||||
* @param notation name The name of the associated notation.
|
||||
* @see #notationDecl
|
||||
* @see org.xml.sax.AttributeList
|
||||
*/
|
||||
public abstract void unparsedEntityDecl (String name,
|
||||
String publicId,
|
||||
String systemId,
|
||||
String notationName)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of DTDHandler.java
|
||||
// SAX DTD handler.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: DTDHandler.java,v 1.5.2.4 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Receive notification of basic DTD-related events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX application needs information about notations and
|
||||
* unparsed entities, then the application implements this
|
||||
* interface and registers an instance with the SAX parser using
|
||||
* the parser's setDTDHandler method. The parser uses the
|
||||
* instance to report notation and unparsed entity declarations to
|
||||
* the application.</p>
|
||||
*
|
||||
* <p>Note that this interface includes only those DTD events that
|
||||
* the XML recommendation <em>requires</em> processors to report:
|
||||
* notation and unparsed entity declarations.</p>
|
||||
*
|
||||
* <p>The SAX parser may report these events in any order, regardless
|
||||
* of the order in which the notations and unparsed entities were
|
||||
* declared; however, all DTD events must be reported after the
|
||||
* document handler's startDocument event, and before the first
|
||||
* startElement event.
|
||||
* (If the {@link org.xml.sax.ext.LexicalHandler LexicalHandler} is
|
||||
* used, these events must also be reported before the endDTD event.)
|
||||
* </p>
|
||||
*
|
||||
* <p>It is up to the application to store the information for
|
||||
* future use (perhaps in a hash table or object tree).
|
||||
* If the application encounters attributes of type "NOTATION",
|
||||
* "ENTITY", or "ENTITIES", it can use the information that it
|
||||
* obtained through this interface to find the entity and/or
|
||||
* notation corresponding with the attribute value.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.XMLReader#setDTDHandler
|
||||
*/
|
||||
public interface DTDHandler {
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a notation declaration event.
|
||||
*
|
||||
* <p>It is up to the application to record the notation for later
|
||||
* reference, if necessary;
|
||||
* notations may appear as attribute values and in unparsed entity
|
||||
* declarations, and are sometime used with processing instruction
|
||||
* target names.</p>
|
||||
*
|
||||
* <p>At least one of publicId and systemId must be non-null.
|
||||
* If a system identifier is present, and it is a URL, the SAX
|
||||
* parser must resolve it fully before passing it to the
|
||||
* application through this event.</p>
|
||||
*
|
||||
* <p>There is no guarantee that the notation declaration will be
|
||||
* reported before any unparsed entities that use it.</p>
|
||||
*
|
||||
* @param name The notation name.
|
||||
* @param publicId The notation's public identifier, or null if
|
||||
* none was given.
|
||||
* @param systemId The notation's system identifier, or null if
|
||||
* none was given.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #unparsedEntityDecl
|
||||
* @see org.xml.sax.Attributes
|
||||
*/
|
||||
public abstract void notationDecl (String name,
|
||||
String publicId,
|
||||
String systemId)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of an unparsed entity declaration event.
|
||||
*
|
||||
* <p>Note that the notation name corresponds to a notation
|
||||
* reported by the {@link #notationDecl notationDecl} event.
|
||||
* It is up to the application to record the entity for later
|
||||
* reference, if necessary;
|
||||
* unparsed entities may appear as attribute values.
|
||||
* </p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the parser must resolve it
|
||||
* fully before passing it to the application.</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @param name The unparsed entity's name.
|
||||
* @param publicId The entity's public identifier, or null if none
|
||||
* was given.
|
||||
* @param systemId The entity's system identifier.
|
||||
* @param notationName The name of the associated notation.
|
||||
* @see #notationDecl
|
||||
* @see org.xml.sax.Attributes
|
||||
*/
|
||||
public abstract void unparsedEntityDecl (String name,
|
||||
String publicId,
|
||||
String systemId,
|
||||
String notationName)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of DTDHandler.java
|
||||
|
@ -1,230 +1,232 @@
|
||||
// SAX document handler.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: DocumentHandler.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Receive notification of general document events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This was the main event-handling interface for SAX1; in
|
||||
* SAX2, it has been replaced by {@link org.xml.sax.ContentHandler
|
||||
* ContentHandler}, which provides Namespace support and reporting
|
||||
* of skipped entities. This interface is included in SAX2 only
|
||||
* to support legacy SAX1 applications.</p>
|
||||
*
|
||||
* <p>The order of events in this interface is very important, and
|
||||
* mirrors the order of information in the document itself. For
|
||||
* example, all of an element's content (character data, processing
|
||||
* instructions, and/or subelements) will appear, in order, between
|
||||
* the startElement event and the corresponding endElement event.</p>
|
||||
*
|
||||
* <p>Application writers who do not want to implement the entire
|
||||
* interface can derive a class from HandlerBase, which implements
|
||||
* the default functionality; parser writers can instantiate
|
||||
* HandlerBase to obtain a default handler. The application can find
|
||||
* the location of any document event using the Locator interface
|
||||
* supplied by the Parser through the setDocumentLocator method.</p>
|
||||
*
|
||||
* @deprecated This interface has been replaced by the SAX2
|
||||
* {@link org.xml.sax.ContentHandler ContentHandler}
|
||||
* interface, which includes Namespace support.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Parser#setDocumentHandler
|
||||
* @see org.xml.sax.Locator
|
||||
* @see org.xml.sax.HandlerBase
|
||||
*/
|
||||
public interface DocumentHandler {
|
||||
|
||||
|
||||
/**
|
||||
* Receive an object for locating the origin of SAX document events.
|
||||
*
|
||||
* <p>SAX parsers are strongly encouraged (though not absolutely
|
||||
* required) to supply a locator: if it does so, it must supply
|
||||
* the locator to the application by invoking this method before
|
||||
* invoking any of the other methods in the DocumentHandler
|
||||
* interface.</p>
|
||||
*
|
||||
* <p>The locator allows the application to determine the end
|
||||
* position of any document-related event, even if the parser is
|
||||
* not reporting an error. Typically, the application will
|
||||
* use this information for reporting its own errors (such as
|
||||
* character content that does not match an application's
|
||||
* business rules). The information returned by the locator
|
||||
* is probably not sufficient for use with a search engine.</p>
|
||||
*
|
||||
* <p>Note that the locator will return correct information only
|
||||
* during the invocation of the events in this interface. The
|
||||
* application should not attempt to use it at any other time.</p>
|
||||
*
|
||||
* @param locator An object that can return the location of
|
||||
* any SAX document event.
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public abstract void setDocumentLocator (Locator locator);
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, before any
|
||||
* other methods in this interface or in DTDHandler (except for
|
||||
* setDocumentLocator).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void startDocument ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, and it will
|
||||
* be the last method invoked during the parse. The parser shall
|
||||
* not invoke this method until it has either abandoned parsing
|
||||
* (because of an unrecoverable error) or reached the end of
|
||||
* input.</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void endDocument ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of an element.
|
||||
*
|
||||
* <p>The Parser will invoke this method at the beginning of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* endElement() event for every startElement() event (even when the
|
||||
* element is empty). All of the element's content will be
|
||||
* reported, in order, before the corresponding endElement()
|
||||
* event.</p>
|
||||
*
|
||||
* <p>If the element name has a namespace prefix, the prefix will
|
||||
* still be attached. Note that the attribute list provided will
|
||||
* contain only attributes with explicit values (specified or
|
||||
* defaulted): #IMPLIED attributes will be omitted.</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param atts The attributes attached to the element, if any.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #endElement
|
||||
* @see org.xml.sax.AttributeList
|
||||
*/
|
||||
public abstract void startElement (String name, AttributeList atts)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method at the end of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* startElement() event for every endElement() event (even when the
|
||||
* element is empty).</p>
|
||||
*
|
||||
* <p>If the element name has a namespace prefix, the prefix will
|
||||
* still be attached to the name.</p>
|
||||
*
|
||||
* @param name The element type name
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void endElement (String name)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data.
|
||||
*
|
||||
* <p>The Parser will call this method to report each chunk of
|
||||
* character data. SAX parsers may return all contiguous character
|
||||
* data in a single chunk, or they may split it into several
|
||||
* chunks; however, all of the characters in any single event
|
||||
* must come from the same external entity, so that the Locator
|
||||
* provides useful information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* <p>Note that some parsers will report whitespace using the
|
||||
* ignorableWhitespace() method rather than this one (validating
|
||||
* parsers must do so).</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #ignorableWhitespace
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public abstract void characters (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>Validating Parsers must use this method to report each chunk
|
||||
* of ignorable whitespace (see the W3C XML 1.0 recommendation,
|
||||
* section 2.10): non-validating parsers may also use this method
|
||||
* if they are capable of parsing and using content models.</p>
|
||||
*
|
||||
* <p>SAX parsers may return all contiguous whitespace in a single
|
||||
* chunk, or they may split it into several chunks; however, all of
|
||||
* the characters in any single event must come from the same
|
||||
* external entity, so that the Locator provides useful
|
||||
* information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #characters
|
||||
*/
|
||||
public abstract void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>The Parser will invoke this method once for each processing
|
||||
* instruction found: note that processing instructions may occur
|
||||
* before or after the main document element.</p>
|
||||
*
|
||||
* <p>A SAX parser should never report an XML declaration (XML 1.0,
|
||||
* section 2.8) or a text declaration (XML 1.0, section 4.3.1)
|
||||
* using this method.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none was supplied.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void processingInstruction (String target, String data)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of DocumentHandler.java
|
||||
// SAX document handler.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: DocumentHandler.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Receive notification of general document events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This was the main event-handling interface for SAX1; in
|
||||
* SAX2, it has been replaced by {@link org.xml.sax.ContentHandler
|
||||
* ContentHandler}, which provides Namespace support and reporting
|
||||
* of skipped entities. This interface is included in SAX2 only
|
||||
* to support legacy SAX1 applications.</p>
|
||||
*
|
||||
* <p>The order of events in this interface is very important, and
|
||||
* mirrors the order of information in the document itself. For
|
||||
* example, all of an element's content (character data, processing
|
||||
* instructions, and/or subelements) will appear, in order, between
|
||||
* the startElement event and the corresponding endElement event.</p>
|
||||
*
|
||||
* <p>Application writers who do not want to implement the entire
|
||||
* interface can derive a class from HandlerBase, which implements
|
||||
* the default functionality; parser writers can instantiate
|
||||
* HandlerBase to obtain a default handler. The application can find
|
||||
* the location of any document event using the Locator interface
|
||||
* supplied by the Parser through the setDocumentLocator method.</p>
|
||||
*
|
||||
* @deprecated This interface has been replaced by the SAX2
|
||||
* {@link org.xml.sax.ContentHandler ContentHandler}
|
||||
* interface, which includes Namespace support.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.Parser#setDocumentHandler
|
||||
* @see org.xml.sax.Locator
|
||||
* @see org.xml.sax.HandlerBase
|
||||
*/
|
||||
public interface DocumentHandler {
|
||||
|
||||
|
||||
/**
|
||||
* Receive an object for locating the origin of SAX document events.
|
||||
*
|
||||
* <p>SAX parsers are strongly encouraged (though not absolutely
|
||||
* required) to supply a locator: if it does so, it must supply
|
||||
* the locator to the application by invoking this method before
|
||||
* invoking any of the other methods in the DocumentHandler
|
||||
* interface.</p>
|
||||
*
|
||||
* <p>The locator allows the application to determine the end
|
||||
* position of any document-related event, even if the parser is
|
||||
* not reporting an error. Typically, the application will
|
||||
* use this information for reporting its own errors (such as
|
||||
* character content that does not match an application's
|
||||
* business rules). The information returned by the locator
|
||||
* is probably not sufficient for use with a search engine.</p>
|
||||
*
|
||||
* <p>Note that the locator will return correct information only
|
||||
* during the invocation of the events in this interface. The
|
||||
* application should not attempt to use it at any other time.</p>
|
||||
*
|
||||
* @param locator An object that can return the location of
|
||||
* any SAX document event.
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public abstract void setDocumentLocator (Locator locator);
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, before any
|
||||
* other methods in this interface or in DTDHandler (except for
|
||||
* setDocumentLocator).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void startDocument ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of a document.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method only once, and it will
|
||||
* be the last method invoked during the parse. The parser shall
|
||||
* not invoke this method until it has either abandoned parsing
|
||||
* (because of an unrecoverable error) or reached the end of
|
||||
* input.</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void endDocument ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of an element.
|
||||
*
|
||||
* <p>The Parser will invoke this method at the beginning of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* endElement() event for every startElement() event (even when the
|
||||
* element is empty). All of the element's content will be
|
||||
* reported, in order, before the corresponding endElement()
|
||||
* event.</p>
|
||||
*
|
||||
* <p>If the element name has a namespace prefix, the prefix will
|
||||
* still be attached. Note that the attribute list provided will
|
||||
* contain only attributes with explicit values (specified or
|
||||
* defaulted): #IMPLIED attributes will be omitted.</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param atts The attributes attached to the element, if any.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #endElement
|
||||
* @see org.xml.sax.AttributeList
|
||||
*/
|
||||
public abstract void startElement (String name, AttributeList atts)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>The SAX parser will invoke this method at the end of every
|
||||
* element in the XML document; there will be a corresponding
|
||||
* startElement() event for every endElement() event (even when the
|
||||
* element is empty).</p>
|
||||
*
|
||||
* <p>If the element name has a namespace prefix, the prefix will
|
||||
* still be attached to the name.</p>
|
||||
*
|
||||
* @param name The element type name
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void endElement (String name)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data.
|
||||
*
|
||||
* <p>The Parser will call this method to report each chunk of
|
||||
* character data. SAX parsers may return all contiguous character
|
||||
* data in a single chunk, or they may split it into several
|
||||
* chunks; however, all of the characters in any single event
|
||||
* must come from the same external entity, so that the Locator
|
||||
* provides useful information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* <p>Note that some parsers will report whitespace using the
|
||||
* ignorableWhitespace() method rather than this one (validating
|
||||
* parsers must do so).</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #ignorableWhitespace
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public abstract void characters (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>Validating Parsers must use this method to report each chunk
|
||||
* of ignorable whitespace (see the W3C XML 1.0 recommendation,
|
||||
* section 2.10): non-validating parsers may also use this method
|
||||
* if they are capable of parsing and using content models.</p>
|
||||
*
|
||||
* <p>SAX parsers may return all contiguous whitespace in a single
|
||||
* chunk, or they may split it into several chunks; however, all of
|
||||
* the characters in any single event must come from the same
|
||||
* external entity, so that the Locator provides useful
|
||||
* information.</p>
|
||||
*
|
||||
* <p>The application must not attempt to read from the array
|
||||
* outside of the specified range.</p>
|
||||
*
|
||||
* @param ch The characters from the XML document.
|
||||
* @param start The start position in the array.
|
||||
* @param length The number of characters to read from the array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see #characters
|
||||
*/
|
||||
public abstract void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>The Parser will invoke this method once for each processing
|
||||
* instruction found: note that processing instructions may occur
|
||||
* before or after the main document element.</p>
|
||||
*
|
||||
* <p>A SAX parser should never report an XML declaration (XML 1.0,
|
||||
* section 2.8) or a text declaration (XML 1.0, section 4.3.1)
|
||||
* using this method.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none was supplied.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
*/
|
||||
public abstract void processingInstruction (String target, String data)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of DocumentHandler.java
|
||||
|
@ -1,110 +1,119 @@
|
||||
// SAX entity resolver.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: EntityResolver.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
||||
/**
|
||||
* Basic interface for resolving entities.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX application needs to implement customized handling
|
||||
* for external entities, it must implement this interface and
|
||||
* register an instance with the SAX driver using the
|
||||
* {@link org.xml.sax.XMLReader#setEntityResolver setEntityResolver}
|
||||
* method.</p>
|
||||
*
|
||||
* <p>The XML reader will then allow the application to intercept any
|
||||
* external entities (including the external DTD subset and external
|
||||
* parameter entities, if any) before including them.</p>
|
||||
*
|
||||
* <p>Many SAX applications will not need to implement this interface,
|
||||
* but it will be especially useful for applications that build
|
||||
* XML documents from databases or other specialised input sources,
|
||||
* or for applications that use URI types other than URLs.</p>
|
||||
*
|
||||
* <p>The following resolver would provide the application
|
||||
* with a special character stream for the entity with the system
|
||||
* identifier "http://www.myhost.com/today":</p>
|
||||
*
|
||||
* <pre>
|
||||
* import org.xml.sax.EntityResolver;
|
||||
* import org.xml.sax.InputSource;
|
||||
*
|
||||
* public class MyResolver implements EntityResolver {
|
||||
* public InputSource resolveEntity (String publicId, String systemId)
|
||||
* {
|
||||
* if (systemId.equals("http://www.myhost.com/today")) {
|
||||
* // return a special input source
|
||||
* MyReader reader = new MyReader();
|
||||
* return new InputSource(reader);
|
||||
* } else {
|
||||
* // use the default behaviour
|
||||
* return null;
|
||||
* }
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>The application can also use this interface to redirect system
|
||||
* identifiers to local URIs or to look up replacements in a catalog
|
||||
* (possibly by using the public identifier).</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Parser#setEntityResolver
|
||||
* @see org.xml.sax.InputSource
|
||||
*/
|
||||
public interface EntityResolver {
|
||||
|
||||
|
||||
/**
|
||||
* Allow the application to resolve external entities.
|
||||
*
|
||||
* <p>The Parser will call this method before opening any external
|
||||
* entity except the top-level document entity (including the
|
||||
* external DTD subset, external entities referenced within the
|
||||
* DTD, and external entities referenced within the document
|
||||
* element): the application may request that the parser resolve
|
||||
* the entity itself, that it use an alternative URI, or that it
|
||||
* use an entirely different input source.</p>
|
||||
*
|
||||
* <p>Application writers can use this method to redirect external
|
||||
* system identifiers to secure and/or local URIs, to look up
|
||||
* public identifiers in a catalogue, or to read an entity from a
|
||||
* database or other input source (including, for example, a dialog
|
||||
* box).</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the SAX parser must
|
||||
* resolve it fully before reporting it to the application.</p>
|
||||
*
|
||||
* @param publicId The public identifier of the external entity
|
||||
* being referenced, or null if none was supplied.
|
||||
* @param systemId The system identifier of the external entity
|
||||
* being referenced.
|
||||
* @return An InputSource object describing the new input source,
|
||||
* or null to request that the parser open a regular
|
||||
* URI connection to the system identifier.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException A Java-specific IO exception,
|
||||
* possibly the result of creating a new InputStream
|
||||
* or Reader for the InputSource.
|
||||
* @see org.xml.sax.InputSource
|
||||
*/
|
||||
public abstract InputSource resolveEntity (String publicId,
|
||||
String systemId)
|
||||
throws SAXException, IOException;
|
||||
|
||||
}
|
||||
|
||||
// end of EntityResolver.java
|
||||
// SAX entity resolver.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: EntityResolver.java,v 1.7.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
||||
/**
|
||||
* Basic interface for resolving entities.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX application needs to implement customized handling
|
||||
* for external entities, it must implement this interface and
|
||||
* register an instance with the SAX driver using the
|
||||
* {@link org.xml.sax.XMLReader#setEntityResolver setEntityResolver}
|
||||
* method.</p>
|
||||
*
|
||||
* <p>The XML reader will then allow the application to intercept any
|
||||
* external entities (including the external DTD subset and external
|
||||
* parameter entities, if any) before including them.</p>
|
||||
*
|
||||
* <p>Many SAX applications will not need to implement this interface,
|
||||
* but it will be especially useful for applications that build
|
||||
* XML documents from databases or other specialised input sources,
|
||||
* or for applications that use URI types other than URLs.</p>
|
||||
*
|
||||
* <p>The following resolver would provide the application
|
||||
* with a special character stream for the entity with the system
|
||||
* identifier "http://www.myhost.com/today":</p>
|
||||
*
|
||||
* <pre>
|
||||
* import org.xml.sax.EntityResolver;
|
||||
* import org.xml.sax.InputSource;
|
||||
*
|
||||
* public class MyResolver implements EntityResolver {
|
||||
* public InputSource resolveEntity (String publicId, String systemId)
|
||||
* {
|
||||
* if (systemId.equals("http://www.myhost.com/today")) {
|
||||
* // return a special input source
|
||||
* MyReader reader = new MyReader();
|
||||
* return new InputSource(reader);
|
||||
* } else {
|
||||
* // use the default behaviour
|
||||
* return null;
|
||||
* }
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>The application can also use this interface to redirect system
|
||||
* identifiers to local URIs or to look up replacements in a catalog
|
||||
* (possibly by using the public identifier).</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.XMLReader#setEntityResolver
|
||||
* @see org.xml.sax.InputSource
|
||||
*/
|
||||
public interface EntityResolver {
|
||||
|
||||
|
||||
/**
|
||||
* Allow the application to resolve external entities.
|
||||
*
|
||||
* <p>The parser will call this method before opening any external
|
||||
* entity except the top-level document entity. Such entities include
|
||||
* the external DTD subset and external parameter entities referenced
|
||||
* within the DTD (in either case, only if the parser reads external
|
||||
* parameter entities), and external general entities referenced
|
||||
* within the document element (if the parser reads external general
|
||||
* entities). The application may request that the parser locate
|
||||
* the entity itself, that it use an alternative URI, or that it
|
||||
* use data provided by the application (as a character or byte
|
||||
* input stream).</p>
|
||||
*
|
||||
* <p>Application writers can use this method to redirect external
|
||||
* system identifiers to secure and/or local URIs, to look up
|
||||
* public identifiers in a catalogue, or to read an entity from a
|
||||
* database or other input source (including, for example, a dialog
|
||||
* box). Neither XML nor SAX specifies a preferred policy for using
|
||||
* public or system IDs to resolve resources. However, SAX specifies
|
||||
* how to interpret any InputSource returned by this method, and that
|
||||
* if none is returned, then the system ID will be dereferenced as
|
||||
* a URL. </p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the SAX parser must
|
||||
* resolve it fully before reporting it to the application.</p>
|
||||
*
|
||||
* @param publicId The public identifier of the external entity
|
||||
* being referenced, or null if none was supplied.
|
||||
* @param systemId The system identifier of the external entity
|
||||
* being referenced.
|
||||
* @return An InputSource object describing the new input source,
|
||||
* or null to request that the parser open a regular
|
||||
* URI connection to the system identifier.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException A Java-specific IO exception,
|
||||
* possibly the result of creating a new InputStream
|
||||
* or Reader for the InputSource.
|
||||
* @see org.xml.sax.InputSource
|
||||
*/
|
||||
public abstract InputSource resolveEntity (String publicId,
|
||||
String systemId)
|
||||
throws SAXException, IOException;
|
||||
|
||||
}
|
||||
|
||||
// end of EntityResolver.java
|
||||
|
@ -1,123 +1,125 @@
|
||||
// SAX error handler.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: ErrorHandler.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Basic interface for SAX error handlers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX application needs to implement customized error
|
||||
* handling, it must implement this interface and then register an
|
||||
* instance with the XML reader using the
|
||||
* {@link org.xml.sax.XMLReader#setErrorHandler setErrorHandler}
|
||||
* method. The parser will then report all errors and warnings
|
||||
* through this interface.</p>
|
||||
*
|
||||
* <p><strong>WARNING:</strong> If an application does <em>not</em>
|
||||
* register an ErrorHandler, XML parsing errors will go unreported
|
||||
* and bizarre behaviour may result.</p>
|
||||
*
|
||||
* <p>For XML processing errors, a SAX driver must use this interface
|
||||
* instead of throwing an exception: it is up to the application
|
||||
* to decide whether to throw an exception for different types of
|
||||
* errors and warnings. Note, however, that there is no requirement that
|
||||
* the parser continue to provide useful information after a call to
|
||||
* {@link #fatalError fatalError} (in other words, a SAX driver class
|
||||
* could catch an exception and report a fatalError).</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Parser#setErrorHandler
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public interface ErrorHandler {
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a warning.
|
||||
*
|
||||
* <p>SAX parsers will use this method to report conditions that
|
||||
* are not errors or fatal errors as defined by the XML 1.0
|
||||
* recommendation. The default behaviour is to take no action.</p>
|
||||
*
|
||||
* <p>The SAX parser must continue to provide normal parsing events
|
||||
* after invoking this method: it should still be possible for the
|
||||
* application to process the document through to the end.</p>
|
||||
*
|
||||
* <p>Filters may use this method to report other, non-XML warnings
|
||||
* as well.</p>
|
||||
*
|
||||
* @param exception The warning information encapsulated in a
|
||||
* SAX parse exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void warning (SAXParseException exception)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a recoverable error.
|
||||
*
|
||||
* <p>This corresponds to the definition of "error" in section 1.2
|
||||
* of the W3C XML 1.0 Recommendation. For example, a validating
|
||||
* parser would use this callback to report the violation of a
|
||||
* validity constraint. The default behaviour is to take no
|
||||
* action.</p>
|
||||
*
|
||||
* <p>The SAX parser must continue to provide normal parsing events
|
||||
* after invoking this method: it should still be possible for the
|
||||
* application to process the document through to the end. If the
|
||||
* application cannot do so, then the parser should report a fatal
|
||||
* error even if the XML 1.0 recommendation does not require it to
|
||||
* do so.</p>
|
||||
*
|
||||
* <p>Filters may use this method to report other, non-XML errors
|
||||
* as well.</p>
|
||||
*
|
||||
* @param exception The error information encapsulated in a
|
||||
* SAX parse exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void error (SAXParseException exception)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a non-recoverable error.
|
||||
*
|
||||
* <p>This corresponds to the definition of "fatal error" in
|
||||
* section 1.2 of the W3C XML 1.0 Recommendation. For example, a
|
||||
* parser would use this callback to report the violation of a
|
||||
* well-formedness constraint.</p>
|
||||
*
|
||||
* <p>The application must assume that the document is unusable
|
||||
* after the parser has invoked this method, and should continue
|
||||
* (if at all) only for the sake of collecting addition error
|
||||
* messages: in fact, SAX parsers are free to stop reporting any
|
||||
* other events once this method has been invoked.</p>
|
||||
*
|
||||
* @param exception The error information encapsulated in a
|
||||
* SAX parse exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void fatalError (SAXParseException exception)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of ErrorHandler.java
|
||||
// SAX error handler.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: ErrorHandler.java,v 1.4.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Basic interface for SAX error handlers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX application needs to implement customized error
|
||||
* handling, it must implement this interface and then register an
|
||||
* instance with the XML reader using the
|
||||
* {@link org.xml.sax.XMLReader#setErrorHandler setErrorHandler}
|
||||
* method. The parser will then report all errors and warnings
|
||||
* through this interface.</p>
|
||||
*
|
||||
* <p><strong>WARNING:</strong> If an application does <em>not</em>
|
||||
* register an ErrorHandler, XML parsing errors will go unreported
|
||||
* and bizarre behaviour may result.</p>
|
||||
*
|
||||
* <p>For XML processing errors, a SAX driver must use this interface
|
||||
* instead of throwing an exception: it is up to the application
|
||||
* to decide whether to throw an exception for different types of
|
||||
* errors and warnings. Note, however, that there is no requirement that
|
||||
* the parser continue to provide useful information after a call to
|
||||
* {@link #fatalError fatalError} (in other words, a SAX driver class
|
||||
* could catch an exception and report a fatalError).</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.XMLReader#setErrorHandler
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public interface ErrorHandler {
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a warning.
|
||||
*
|
||||
* <p>SAX parsers will use this method to report conditions that
|
||||
* are not errors or fatal errors as defined by the XML 1.0
|
||||
* recommendation. The default behaviour is to take no action.</p>
|
||||
*
|
||||
* <p>The SAX parser must continue to provide normal parsing events
|
||||
* after invoking this method: it should still be possible for the
|
||||
* application to process the document through to the end.</p>
|
||||
*
|
||||
* <p>Filters may use this method to report other, non-XML warnings
|
||||
* as well.</p>
|
||||
*
|
||||
* @param exception The warning information encapsulated in a
|
||||
* SAX parse exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void warning (SAXParseException exception)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a recoverable error.
|
||||
*
|
||||
* <p>This corresponds to the definition of "error" in section 1.2
|
||||
* of the W3C XML 1.0 Recommendation. For example, a validating
|
||||
* parser would use this callback to report the violation of a
|
||||
* validity constraint. The default behaviour is to take no
|
||||
* action.</p>
|
||||
*
|
||||
* <p>The SAX parser must continue to provide normal parsing events
|
||||
* after invoking this method: it should still be possible for the
|
||||
* application to process the document through to the end. If the
|
||||
* application cannot do so, then the parser should report a fatal
|
||||
* error even if the XML 1.0 recommendation does not require it to
|
||||
* do so.</p>
|
||||
*
|
||||
* <p>Filters may use this method to report other, non-XML errors
|
||||
* as well.</p>
|
||||
*
|
||||
* @param exception The error information encapsulated in a
|
||||
* SAX parse exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void error (SAXParseException exception)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a non-recoverable error.
|
||||
*
|
||||
* <p>This corresponds to the definition of "fatal error" in
|
||||
* section 1.2 of the W3C XML 1.0 Recommendation. For example, a
|
||||
* parser would use this callback to report the violation of a
|
||||
* well-formedness constraint.</p>
|
||||
*
|
||||
* <p>The application must assume that the document is unusable
|
||||
* after the parser has invoked this method, and should continue
|
||||
* (if at all) only for the sake of collecting addition error
|
||||
* messages: in fact, SAX parsers are free to stop reporting any
|
||||
* other events once this method has been invoked.</p>
|
||||
*
|
||||
* @param exception The error information encapsulated in a
|
||||
* SAX parse exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void fatalError (SAXParseException exception)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of ErrorHandler.java
|
||||
|
@ -1,368 +1,370 @@
|
||||
// SAX default handler base class.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: HandlerBase.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Default base class for handlers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class implements the default behaviour for four SAX1
|
||||
* interfaces: EntityResolver, DTDHandler, DocumentHandler,
|
||||
* and ErrorHandler. It is now obsolete, but is included in SAX2 to
|
||||
* support legacy SAX1 applications. SAX2 applications should use
|
||||
* the {@link org.xml.sax.helpers.DefaultHandler DefaultHandler}
|
||||
* class instead.</p>
|
||||
*
|
||||
* <p>Application writers can extend this class when they need to
|
||||
* implement only part of an interface; parser writers can
|
||||
* instantiate this class to provide default handlers when the
|
||||
* application has not supplied its own.</p>
|
||||
*
|
||||
* <p>Note that the use of this class is optional.</p>
|
||||
*
|
||||
* @deprecated This class works with the deprecated
|
||||
* {@link org.xml.sax.DocumentHandler DocumentHandler}
|
||||
* interface. It has been replaced by the SAX2
|
||||
* {@link org.xml.sax.helpers.DefaultHandler DefaultHandler}
|
||||
* class.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.EntityResolver
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.DocumentHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public class HandlerBase
|
||||
implements EntityResolver, DTDHandler, DocumentHandler, ErrorHandler
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the EntityResolver interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
* Resolve an external entity.
|
||||
*
|
||||
* <p>Always return null, so that the parser will use the system
|
||||
* identifier provided in the XML document. This method implements
|
||||
* the SAX default behaviour: application writers can override it
|
||||
* in a subclass to do special translations such as catalog lookups
|
||||
* or URI redirection.</p>
|
||||
*
|
||||
* @param publicId The public identifier, or null if none is
|
||||
* available.
|
||||
* @param systemId The system identifier provided in the XML
|
||||
* document.
|
||||
* @return The new input source, or null to require the
|
||||
* default behaviour.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.EntityResolver#resolveEntity
|
||||
*/
|
||||
public InputSource resolveEntity (String publicId, String systemId)
|
||||
throws SAXException
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of DTDHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a notation declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to keep track of the notations
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The notation name.
|
||||
* @param publicId The notation public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The notation system identifier.
|
||||
* @see org.xml.sax.DTDHandler#notationDecl
|
||||
*/
|
||||
public void notationDecl (String name, String publicId, String systemId)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of an unparsed entity declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to keep track of the unparsed entities
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The entity name.
|
||||
* @param publicId The entity public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The entity system identifier.
|
||||
* @param notationName The name of the associated notation.
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public void unparsedEntityDecl (String name, String publicId,
|
||||
String systemId, String notationName)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of DocumentHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive a Locator object for document events.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to store the locator for use
|
||||
* with other document events.</p>
|
||||
*
|
||||
* @param locator A locator for all SAX document events.
|
||||
* @see org.xml.sax.DocumentHandler#setDocumentLocator
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void setDocumentLocator (Locator locator)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the beginning
|
||||
* of a document (such as allocating the root node of a tree or
|
||||
* creating an output file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#startDocument
|
||||
*/
|
||||
public void startDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the beginning
|
||||
* of a document (such as finalising a tree or closing an output
|
||||
* file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#endDocument
|
||||
*/
|
||||
public void endDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the start of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the start of
|
||||
* each element (such as allocating a new tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param attributes The specified or defaulted attributes.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public void startElement (String name, AttributeList attributes)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end of
|
||||
* each element (such as finalising a tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param attributes The specified or defaulted attributes.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#endElement
|
||||
*/
|
||||
public void endElement (String name)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data inside an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of character data
|
||||
* (such as adding the data to a node or buffer, or printing it to
|
||||
* a file).</p>
|
||||
*
|
||||
* @param ch The characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#characters
|
||||
*/
|
||||
public void characters (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of ignorable
|
||||
* whitespace (such as adding data to a node or buffer, or printing
|
||||
* it to a file).</p>
|
||||
*
|
||||
* @param ch The whitespace characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#ignorableWhitespace
|
||||
*/
|
||||
public void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions for each
|
||||
* processing instruction, such as setting status variables or
|
||||
* invoking other methods.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none is supplied.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#processingInstruction
|
||||
*/
|
||||
public void processingInstruction (String target, String data)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the ErrorHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a parser warning.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each warning, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void warning (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a recoverable parser error.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each error, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void error (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Report a fatal XML parsing error.
|
||||
*
|
||||
* <p>The default implementation throws a SAXParseException.
|
||||
* Application writers may override this method in a subclass if
|
||||
* they need to take specific actions for each fatal error (such as
|
||||
* collecting all of the errors into a single report): in any case,
|
||||
* the application must stop all regular processing when this
|
||||
* method is invoked, since the document is no longer reliable, and
|
||||
* the parser may no longer report parsing events.</p>
|
||||
*
|
||||
* @param e The error information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#fatalError
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void fatalError (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
throw e;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of HandlerBase.java
|
||||
// SAX default handler base class.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: HandlerBase.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Default base class for handlers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class implements the default behaviour for four SAX1
|
||||
* interfaces: EntityResolver, DTDHandler, DocumentHandler,
|
||||
* and ErrorHandler. It is now obsolete, but is included in SAX2 to
|
||||
* support legacy SAX1 applications. SAX2 applications should use
|
||||
* the {@link org.xml.sax.helpers.DefaultHandler DefaultHandler}
|
||||
* class instead.</p>
|
||||
*
|
||||
* <p>Application writers can extend this class when they need to
|
||||
* implement only part of an interface; parser writers can
|
||||
* instantiate this class to provide default handlers when the
|
||||
* application has not supplied its own.</p>
|
||||
*
|
||||
* <p>Note that the use of this class is optional.</p>
|
||||
*
|
||||
* @deprecated This class works with the deprecated
|
||||
* {@link org.xml.sax.DocumentHandler DocumentHandler}
|
||||
* interface. It has been replaced by the SAX2
|
||||
* {@link org.xml.sax.helpers.DefaultHandler DefaultHandler}
|
||||
* class.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.EntityResolver
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.DocumentHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public class HandlerBase
|
||||
implements EntityResolver, DTDHandler, DocumentHandler, ErrorHandler
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the EntityResolver interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
* Resolve an external entity.
|
||||
*
|
||||
* <p>Always return null, so that the parser will use the system
|
||||
* identifier provided in the XML document. This method implements
|
||||
* the SAX default behaviour: application writers can override it
|
||||
* in a subclass to do special translations such as catalog lookups
|
||||
* or URI redirection.</p>
|
||||
*
|
||||
* @param publicId The public identifer, or null if none is
|
||||
* available.
|
||||
* @param systemId The system identifier provided in the XML
|
||||
* document.
|
||||
* @return The new input source, or null to require the
|
||||
* default behaviour.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.EntityResolver#resolveEntity
|
||||
*/
|
||||
public InputSource resolveEntity (String publicId, String systemId)
|
||||
throws SAXException
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of DTDHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a notation declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to keep track of the notations
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The notation name.
|
||||
* @param publicId The notation public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The notation system identifier.
|
||||
* @see org.xml.sax.DTDHandler#notationDecl
|
||||
*/
|
||||
public void notationDecl (String name, String publicId, String systemId)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of an unparsed entity declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to keep track of the unparsed entities
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The entity name.
|
||||
* @param publicId The entity public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The entity system identifier.
|
||||
* @param notationName The name of the associated notation.
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public void unparsedEntityDecl (String name, String publicId,
|
||||
String systemId, String notationName)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of DocumentHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive a Locator object for document events.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to store the locator for use
|
||||
* with other document events.</p>
|
||||
*
|
||||
* @param locator A locator for all SAX document events.
|
||||
* @see org.xml.sax.DocumentHandler#setDocumentLocator
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void setDocumentLocator (Locator locator)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the beginning
|
||||
* of a document (such as allocating the root node of a tree or
|
||||
* creating an output file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#startDocument
|
||||
*/
|
||||
public void startDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the beginning
|
||||
* of a document (such as finalising a tree or closing an output
|
||||
* file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#endDocument
|
||||
*/
|
||||
public void endDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the start of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the start of
|
||||
* each element (such as allocating a new tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param attributes The specified or defaulted attributes.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public void startElement (String name, AttributeList attributes)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end of
|
||||
* each element (such as finalising a tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param attributes The specified or defaulted attributes.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#endElement
|
||||
*/
|
||||
public void endElement (String name)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data inside an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of character data
|
||||
* (such as adding the data to a node or buffer, or printing it to
|
||||
* a file).</p>
|
||||
*
|
||||
* @param ch The characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#characters
|
||||
*/
|
||||
public void characters (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of ignorable
|
||||
* whitespace (such as adding data to a node or buffer, or printing
|
||||
* it to a file).</p>
|
||||
*
|
||||
* @param ch The whitespace characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#ignorableWhitespace
|
||||
*/
|
||||
public void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions for each
|
||||
* processing instruction, such as setting status variables or
|
||||
* invoking other methods.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none is supplied.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DocumentHandler#processingInstruction
|
||||
*/
|
||||
public void processingInstruction (String target, String data)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the ErrorHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a parser warning.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each warning, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void warning (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a recoverable parser error.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each error, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void error (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Report a fatal XML parsing error.
|
||||
*
|
||||
* <p>The default implementation throws a SAXParseException.
|
||||
* Application writers may override this method in a subclass if
|
||||
* they need to take specific actions for each fatal error (such as
|
||||
* collecting all of the errors into a single report): in any case,
|
||||
* the application must stop all regular processing when this
|
||||
* method is invoked, since the document is no longer reliable, and
|
||||
* the parser may no longer report parsing events.</p>
|
||||
*
|
||||
* @param e The error information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#fatalError
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void fatalError (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
throw e;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of HandlerBase.java
|
||||
|
@ -1,321 +1,336 @@
|
||||
// SAX input source.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: InputSource.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.Reader;
|
||||
import java.io.InputStream;
|
||||
|
||||
/**
|
||||
* A single input source for an XML entity.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class allows a SAX application to encapsulate information
|
||||
* about an input source in a single object, which may include
|
||||
* a public identifier, a system identifier, a byte stream (possibly
|
||||
* with a specified encoding), and/or a character stream.</p>
|
||||
*
|
||||
* <p>There are two places that the application will deliver this
|
||||
* input source to the parser: as the argument to the Parser.parse
|
||||
* method, or as the return value of the EntityResolver.resolveEntity
|
||||
* method.</p>
|
||||
*
|
||||
* <p>The SAX parser will use the InputSource object to determine how
|
||||
* to read XML input. If there is a character stream available, the
|
||||
* parser will read that stream directly; if not, the parser will use
|
||||
* a byte stream, if available; if neither a character stream nor a
|
||||
* byte stream is available, the parser will attempt to open a URI
|
||||
* connection to the resource identified by the system
|
||||
* identifier.</p>
|
||||
*
|
||||
* <p>An InputSource object belongs to the application: the SAX parser
|
||||
* shall never modify it in any way (it may modify a copy if
|
||||
* necessary).</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Parser#parse
|
||||
* @see org.xml.sax.EntityResolver#resolveEntity
|
||||
* @see java.io.InputStream
|
||||
* @see java.io.Reader
|
||||
*/
|
||||
public class InputSource {
|
||||
|
||||
/**
|
||||
* Zero-argument default constructor.
|
||||
*
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #setCharacterStream
|
||||
* @see #setEncoding
|
||||
*/
|
||||
public InputSource ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new input source with a system identifier.
|
||||
*
|
||||
* <p>Applications may use setPublicId to include a
|
||||
* public identifier as well, or setEncoding to specify
|
||||
* the character encoding, if known.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be full resolved.</p>
|
||||
*
|
||||
* @param systemId The system identifier (URI).
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #setEncoding
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public InputSource (String systemId)
|
||||
{
|
||||
setSystemId(systemId);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new input source with a byte stream.
|
||||
*
|
||||
* <p>Application writers may use setSystemId to provide a base
|
||||
* for resolving relative URIs, setPublicId to include a
|
||||
* public identifier, and/or setEncoding to specify the object's
|
||||
* character encoding.</p>
|
||||
*
|
||||
* @param byteStream The raw byte stream containing the document.
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setEncoding
|
||||
* @see #setByteStream
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public InputSource (InputStream byteStream)
|
||||
{
|
||||
setByteStream(byteStream);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new input source with a character stream.
|
||||
*
|
||||
* <p>Application writers may use setSystemId() to provide a base
|
||||
* for resolving relative URIs, and setPublicId to include a
|
||||
* public identifier.</p>
|
||||
*
|
||||
* <p>The character stream shall not include a byte order mark.</p>
|
||||
*
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public InputSource (Reader characterStream)
|
||||
{
|
||||
setCharacterStream(characterStream);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the public identifier for this input source.
|
||||
*
|
||||
* <p>The public identifier is always optional: if the application
|
||||
* writer includes one, it will be provided as part of the
|
||||
* location information.</p>
|
||||
*
|
||||
* @param publicId The public identifier as a string.
|
||||
* @see #getPublicId
|
||||
* @see org.xml.sax.Locator#getPublicId
|
||||
* @see org.xml.sax.SAXParseException#getPublicId
|
||||
*/
|
||||
public void setPublicId (String publicId)
|
||||
{
|
||||
this.publicId = publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the public identifier for this input source.
|
||||
*
|
||||
* @return The public identifier, or null if none was supplied.
|
||||
* @see #setPublicId
|
||||
*/
|
||||
public String getPublicId ()
|
||||
{
|
||||
return publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the system identifier for this input source.
|
||||
*
|
||||
* <p>The system identifier is optional if there is a byte stream
|
||||
* or a character stream, but it is still useful to provide one,
|
||||
* since the application can use it to resolve relative URIs
|
||||
* and can include it in error messages and warnings (the parser
|
||||
* will attempt to open a connection to the URI only if
|
||||
* there is no byte stream or character stream specified).</p>
|
||||
*
|
||||
* <p>If the application knows the character encoding of the
|
||||
* object pointed to by the system identifier, it can register
|
||||
* the encoding using the setEncoding method.</p>
|
||||
*
|
||||
* <p>If the system ID is a URL, it must be fully resolved.</p>
|
||||
*
|
||||
* @param systemId The system identifier as a string.
|
||||
* @see #setEncoding
|
||||
* @see #getSystemId
|
||||
* @see org.xml.sax.Locator#getSystemId
|
||||
* @see org.xml.sax.SAXParseException#getSystemId
|
||||
*/
|
||||
public void setSystemId (String systemId)
|
||||
{
|
||||
this.systemId = systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the system identifier for this input source.
|
||||
*
|
||||
* <p>The getEncoding method will return the character encoding
|
||||
* of the object pointed to, or null if unknown.</p>
|
||||
*
|
||||
* <p>If the system ID is a URL, it will be fully resolved.</p>
|
||||
*
|
||||
* @return The system identifier.
|
||||
* @see #setSystemId
|
||||
* @see #getEncoding
|
||||
*/
|
||||
public String getSystemId ()
|
||||
{
|
||||
return systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the byte stream for this input source.
|
||||
*
|
||||
* <p>The SAX parser will ignore this if there is also a character
|
||||
* stream specified, but it will use a byte stream in preference
|
||||
* to opening a URI connection itself.</p>
|
||||
*
|
||||
* <p>If the application knows the character encoding of the
|
||||
* byte stream, it should set it with the setEncoding method.</p>
|
||||
*
|
||||
* @param byteStream A byte stream containing an XML document or
|
||||
* other entity.
|
||||
* @see #setEncoding
|
||||
* @see #getByteStream
|
||||
* @see #getEncoding
|
||||
* @see java.io.InputStream
|
||||
*/
|
||||
public void setByteStream (InputStream byteStream)
|
||||
{
|
||||
this.byteStream = byteStream;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the byte stream for this input source.
|
||||
*
|
||||
* <p>The getEncoding method will return the character
|
||||
* encoding for this byte stream, or null if unknown.</p>
|
||||
*
|
||||
* @return The byte stream, or null if none was supplied.
|
||||
* @see #getEncoding
|
||||
* @see #setByteStream
|
||||
*/
|
||||
public InputStream getByteStream ()
|
||||
{
|
||||
return byteStream;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the character encoding, if known.
|
||||
*
|
||||
* <p>The encoding must be a string acceptable for an
|
||||
* XML encoding declaration (see section 4.3.3 of the XML 1.0
|
||||
* recommendation).</p>
|
||||
*
|
||||
* <p>This method has no effect when the application provides a
|
||||
* character stream.</p>
|
||||
*
|
||||
* @param encoding A string describing the character encoding.
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #getEncoding
|
||||
*/
|
||||
public void setEncoding (String encoding)
|
||||
{
|
||||
this.encoding = encoding;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the character encoding for a byte stream or URI.
|
||||
*
|
||||
* @return The encoding, or null if none was supplied.
|
||||
* @see #setByteStream
|
||||
* @see #getSystemId
|
||||
* @see #getByteStream
|
||||
*/
|
||||
public String getEncoding ()
|
||||
{
|
||||
return encoding;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the character stream for this input source.
|
||||
*
|
||||
* <p>If there is a character stream specified, the SAX parser
|
||||
* will ignore any byte stream and will not attempt to open
|
||||
* a URI connection to the system identifier.</p>
|
||||
*
|
||||
* @param characterStream The character stream containing the
|
||||
* XML document or other entity.
|
||||
* @see #getCharacterStream
|
||||
* @see java.io.Reader
|
||||
*/
|
||||
public void setCharacterStream (Reader characterStream)
|
||||
{
|
||||
this.characterStream = characterStream;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the character stream for this input source.
|
||||
*
|
||||
* @return The character stream, or null if none was supplied.
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public Reader getCharacterStream ()
|
||||
{
|
||||
return characterStream;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
private String publicId;
|
||||
private String systemId;
|
||||
private InputStream byteStream;
|
||||
private String encoding;
|
||||
private Reader characterStream;
|
||||
|
||||
}
|
||||
|
||||
// end of InputSource.java
|
||||
// SAX input source.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: InputSource.java,v 1.5.2.4 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.Reader;
|
||||
import java.io.InputStream;
|
||||
|
||||
/**
|
||||
* A single input source for an XML entity.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class allows a SAX application to encapsulate information
|
||||
* about an input source in a single object, which may include
|
||||
* a public identifier, a system identifier, a byte stream (possibly
|
||||
* with a specified encoding), and/or a character stream.</p>
|
||||
*
|
||||
* <p>There are two places that the application can deliver an
|
||||
* input source to the parser: as the argument to the Parser.parse
|
||||
* method, or as the return value of the EntityResolver.resolveEntity
|
||||
* method.</p>
|
||||
*
|
||||
* <p>The SAX parser will use the InputSource object to determine how
|
||||
* to read XML input. If there is a character stream available, the
|
||||
* parser will read that stream directly, disregarding any text
|
||||
* encoding declaration found in that stream.
|
||||
* If there is no character stream, but there is
|
||||
* a byte stream, the parser will use that byte stream, using the
|
||||
* encoding specified in the InputSource or else (if no encoding is
|
||||
* specified) autodetecting the character encoding using an algorithm
|
||||
* such as the one in the XML specification. If neither a character
|
||||
* stream nor a
|
||||
* byte stream is available, the parser will attempt to open a URI
|
||||
* connection to the resource identified by the system
|
||||
* identifier.</p>
|
||||
*
|
||||
* <p>An InputSource object belongs to the application: the SAX parser
|
||||
* shall never modify it in any way (it may modify a copy if
|
||||
* necessary). However, standard processing of both byte and
|
||||
* character streams is to close them on as part of end-of-parse cleanup,
|
||||
* so applications should not attempt to re-use such streams after they
|
||||
* have been handed to a parser. </p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.XMLReader#parse(org.xml.sax.InputSource)
|
||||
* @see org.xml.sax.EntityResolver#resolveEntity
|
||||
* @see java.io.InputStream
|
||||
* @see java.io.Reader
|
||||
*/
|
||||
public class InputSource {
|
||||
|
||||
/**
|
||||
* Zero-argument default constructor.
|
||||
*
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #setCharacterStream
|
||||
* @see #setEncoding
|
||||
*/
|
||||
public InputSource ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new input source with a system identifier.
|
||||
*
|
||||
* <p>Applications may use setPublicId to include a
|
||||
* public identifier as well, or setEncoding to specify
|
||||
* the character encoding, if known.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be fully
|
||||
* resolved (it may not be a relative URL).</p>
|
||||
*
|
||||
* @param systemId The system identifier (URI).
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #setEncoding
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public InputSource (String systemId)
|
||||
{
|
||||
setSystemId(systemId);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new input source with a byte stream.
|
||||
*
|
||||
* <p>Application writers should use setSystemId() to provide a base
|
||||
* for resolving relative URIs, may use setPublicId to include a
|
||||
* public identifier, and may use setEncoding to specify the object's
|
||||
* character encoding.</p>
|
||||
*
|
||||
* @param byteStream The raw byte stream containing the document.
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setEncoding
|
||||
* @see #setByteStream
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public InputSource (InputStream byteStream)
|
||||
{
|
||||
setByteStream(byteStream);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new input source with a character stream.
|
||||
*
|
||||
* <p>Application writers should use setSystemId() to provide a base
|
||||
* for resolving relative URIs, and may use setPublicId to include a
|
||||
* public identifier.</p>
|
||||
*
|
||||
* <p>The character stream shall not include a byte order mark.</p>
|
||||
*
|
||||
* @see #setPublicId
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public InputSource (Reader characterStream)
|
||||
{
|
||||
setCharacterStream(characterStream);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the public identifier for this input source.
|
||||
*
|
||||
* <p>The public identifier is always optional: if the application
|
||||
* writer includes one, it will be provided as part of the
|
||||
* location information.</p>
|
||||
*
|
||||
* @param publicId The public identifier as a string.
|
||||
* @see #getPublicId
|
||||
* @see org.xml.sax.Locator#getPublicId
|
||||
* @see org.xml.sax.SAXParseException#getPublicId
|
||||
*/
|
||||
public void setPublicId (String publicId)
|
||||
{
|
||||
this.publicId = publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the public identifier for this input source.
|
||||
*
|
||||
* @return The public identifier, or null if none was supplied.
|
||||
* @see #setPublicId
|
||||
*/
|
||||
public String getPublicId ()
|
||||
{
|
||||
return publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the system identifier for this input source.
|
||||
*
|
||||
* <p>The system identifier is optional if there is a byte stream
|
||||
* or a character stream, but it is still useful to provide one,
|
||||
* since the application can use it to resolve relative URIs
|
||||
* and can include it in error messages and warnings (the parser
|
||||
* will attempt to open a connection to the URI only if
|
||||
* there is no byte stream or character stream specified).</p>
|
||||
*
|
||||
* <p>If the application knows the character encoding of the
|
||||
* object pointed to by the system identifier, it can register
|
||||
* the encoding using the setEncoding method.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be fully
|
||||
* resolved (it may not be a relative URL).</p>
|
||||
*
|
||||
* @param systemId The system identifier as a string.
|
||||
* @see #setEncoding
|
||||
* @see #getSystemId
|
||||
* @see org.xml.sax.Locator#getSystemId
|
||||
* @see org.xml.sax.SAXParseException#getSystemId
|
||||
*/
|
||||
public void setSystemId (String systemId)
|
||||
{
|
||||
this.systemId = systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the system identifier for this input source.
|
||||
*
|
||||
* <p>The getEncoding method will return the character encoding
|
||||
* of the object pointed to, or null if unknown.</p>
|
||||
*
|
||||
* <p>If the system ID is a URL, it will be fully resolved.</p>
|
||||
*
|
||||
* @return The system identifier, or null if none was supplied.
|
||||
* @see #setSystemId
|
||||
* @see #getEncoding
|
||||
*/
|
||||
public String getSystemId ()
|
||||
{
|
||||
return systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the byte stream for this input source.
|
||||
*
|
||||
* <p>The SAX parser will ignore this if there is also a character
|
||||
* stream specified, but it will use a byte stream in preference
|
||||
* to opening a URI connection itself.</p>
|
||||
*
|
||||
* <p>If the application knows the character encoding of the
|
||||
* byte stream, it should set it with the setEncoding method.</p>
|
||||
*
|
||||
* @param byteStream A byte stream containing an XML document or
|
||||
* other entity.
|
||||
* @see #setEncoding
|
||||
* @see #getByteStream
|
||||
* @see #getEncoding
|
||||
* @see java.io.InputStream
|
||||
*/
|
||||
public void setByteStream (InputStream byteStream)
|
||||
{
|
||||
this.byteStream = byteStream;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the byte stream for this input source.
|
||||
*
|
||||
* <p>The getEncoding method will return the character
|
||||
* encoding for this byte stream, or null if unknown.</p>
|
||||
*
|
||||
* @return The byte stream, or null if none was supplied.
|
||||
* @see #getEncoding
|
||||
* @see #setByteStream
|
||||
*/
|
||||
public InputStream getByteStream ()
|
||||
{
|
||||
return byteStream;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the character encoding, if known.
|
||||
*
|
||||
* <p>The encoding must be a string acceptable for an
|
||||
* XML encoding declaration (see section 4.3.3 of the XML 1.0
|
||||
* recommendation).</p>
|
||||
*
|
||||
* <p>This method has no effect when the application provides a
|
||||
* character stream.</p>
|
||||
*
|
||||
* @param encoding A string describing the character encoding.
|
||||
* @see #setSystemId
|
||||
* @see #setByteStream
|
||||
* @see #getEncoding
|
||||
*/
|
||||
public void setEncoding (String encoding)
|
||||
{
|
||||
this.encoding = encoding;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the character encoding for a byte stream or URI.
|
||||
* This value will be ignored when the application provides a
|
||||
* character stream.
|
||||
*
|
||||
* @return The encoding, or null if none was supplied.
|
||||
* @see #setByteStream
|
||||
* @see #getSystemId
|
||||
* @see #getByteStream
|
||||
*/
|
||||
public String getEncoding ()
|
||||
{
|
||||
return encoding;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the character stream for this input source.
|
||||
*
|
||||
* <p>If there is a character stream specified, the SAX parser
|
||||
* will ignore any byte stream and will not attempt to open
|
||||
* a URI connection to the system identifier.</p>
|
||||
*
|
||||
* @param characterStream The character stream containing the
|
||||
* XML document or other entity.
|
||||
* @see #getCharacterStream
|
||||
* @see java.io.Reader
|
||||
*/
|
||||
public void setCharacterStream (Reader characterStream)
|
||||
{
|
||||
this.characterStream = characterStream;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the character stream for this input source.
|
||||
*
|
||||
* @return The character stream, or null if none was supplied.
|
||||
* @see #setCharacterStream
|
||||
*/
|
||||
public Reader getCharacterStream ()
|
||||
{
|
||||
return characterStream;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
private String publicId;
|
||||
private String systemId;
|
||||
private InputStream byteStream;
|
||||
private String encoding;
|
||||
private Reader characterStream;
|
||||
|
||||
}
|
||||
|
||||
// end of InputSource.java
|
||||
|
@ -1,126 +1,136 @@
|
||||
// SAX locator interface for document events.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: Locator.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for associating a SAX event with a document location.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX parser provides location information to the SAX
|
||||
* application, it does so by implementing this interface and then
|
||||
* passing an instance to the application using the content
|
||||
* handler's {@link org.xml.sax.ContentHandler#setDocumentLocator
|
||||
* setDocumentLocator} method. The application can use the
|
||||
* object to obtain the location of any other content handler event
|
||||
* in the XML source document.</p>
|
||||
*
|
||||
* <p>Note that the results returned by the object will be valid only
|
||||
* during the scope of each content handler method: the application
|
||||
* will receive unpredictable results if it attempts to use the
|
||||
* locator at any other time.</p>
|
||||
*
|
||||
* <p>SAX parsers are not required to supply a locator, but they are
|
||||
* very strongly encouraged to do so. If the parser supplies a
|
||||
* locator, it must do so before reporting any other document events.
|
||||
* If no locator has been set by the time the application receives
|
||||
* the {@link org.xml.sax.ContentHandler#startDocument startDocument}
|
||||
* event, the application should assume that a locator is not
|
||||
* available.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.ContentHandler#setDocumentLocator
|
||||
*/
|
||||
public interface Locator {
|
||||
|
||||
|
||||
/**
|
||||
* Return the public identifier for the current document event.
|
||||
*
|
||||
* <p>The return value is the public identifier of the document
|
||||
* entity or of the external parsed entity in which the markup
|
||||
* triggering the event appears.</p>
|
||||
*
|
||||
* @return A string containing the public identifier, or
|
||||
* null if none is available.
|
||||
* @see #getSystemId
|
||||
*/
|
||||
public abstract String getPublicId ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the system identifier for the current document event.
|
||||
*
|
||||
* <p>The return value is the system identifier of the document
|
||||
* entity or of the external parsed entity in which the markup
|
||||
* triggering the event appears.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the parser must resolve it
|
||||
* fully before passing it to the application.</p>
|
||||
*
|
||||
* @return A string containing the system identifier, or null
|
||||
* if none is available.
|
||||
* @see #getPublicId
|
||||
*/
|
||||
public abstract String getSystemId ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the line number where the current document event ends.
|
||||
*
|
||||
* <p><strong>Warning:</strong> The return value from the method
|
||||
* is intended only as an approximation for the sake of error
|
||||
* reporting; it is not intended to provide sufficient information
|
||||
* to edit the character content of the original XML document.</p>
|
||||
*
|
||||
* <p>The return value is an approximation of the line number
|
||||
* in the document entity or external parsed entity where the
|
||||
* markup triggering the event appears.</p>
|
||||
*
|
||||
* <p>If possible, the SAX driver should provide the line position
|
||||
* of the first character after the text associated with the document
|
||||
* event. The first line in the document is line 1.</p>
|
||||
*
|
||||
* @return The line number, or -1 if none is available.
|
||||
* @see #getColumnNumber
|
||||
*/
|
||||
public abstract int getLineNumber ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the column number where the current document event ends.
|
||||
*
|
||||
* <p><strong>Warning:</strong> The return value from the method
|
||||
* is intended only as an approximation for the sake of error
|
||||
* reporting; it is not intended to provide sufficient information
|
||||
* to edit the character content of the original XML document.</p>
|
||||
*
|
||||
* <p>The return value is an approximation of the column number
|
||||
* in the document entity or external parsed entity where the
|
||||
* markup triggering the event appears.</p>
|
||||
*
|
||||
* <p>If possible, the SAX driver should provide the line position
|
||||
* of the first character after the text associated with the document
|
||||
* event.</p>
|
||||
*
|
||||
* <p>If possible, the SAX driver should provide the line position
|
||||
* of the first character after the text associated with the document
|
||||
* event. The first column in each line is column 1.</p>
|
||||
*
|
||||
* @return The column number, or -1 if none is available.
|
||||
* @see #getLineNumber
|
||||
*/
|
||||
public abstract int getColumnNumber ();
|
||||
|
||||
}
|
||||
|
||||
// end of Locator.java
|
||||
// SAX locator interface for document events.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: Locator.java,v 1.4.2.5 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for associating a SAX event with a document location.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>If a SAX parser provides location information to the SAX
|
||||
* application, it does so by implementing this interface and then
|
||||
* passing an instance to the application using the content
|
||||
* handler's {@link org.xml.sax.ContentHandler#setDocumentLocator
|
||||
* setDocumentLocator} method. The application can use the
|
||||
* object to obtain the location of any other SAX event
|
||||
* in the XML source document.</p>
|
||||
*
|
||||
* <p>Note that the results returned by the object will be valid only
|
||||
* during the scope of each callback method: the application
|
||||
* will receive unpredictable results if it attempts to use the
|
||||
* locator at any other time, or after parsing completes.</p>
|
||||
*
|
||||
* <p>SAX parsers are not required to supply a locator, but they are
|
||||
* very strongly encouraged to do so. If the parser supplies a
|
||||
* locator, it must do so before reporting any other document events.
|
||||
* If no locator has been set by the time the application receives
|
||||
* the {@link org.xml.sax.ContentHandler#startDocument startDocument}
|
||||
* event, the application should assume that a locator is not
|
||||
* available.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.ContentHandler#setDocumentLocator
|
||||
*/
|
||||
public interface Locator {
|
||||
|
||||
|
||||
/**
|
||||
* Return the public identifier for the current document event.
|
||||
*
|
||||
* <p>The return value is the public identifier of the document
|
||||
* entity or of the external parsed entity in which the markup
|
||||
* triggering the event appears.</p>
|
||||
*
|
||||
* @return A string containing the public identifier, or
|
||||
* null if none is available.
|
||||
* @see #getSystemId
|
||||
*/
|
||||
public abstract String getPublicId ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the system identifier for the current document event.
|
||||
*
|
||||
* <p>The return value is the system identifier of the document
|
||||
* entity or of the external parsed entity in which the markup
|
||||
* triggering the event appears.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the parser must resolve it
|
||||
* fully before passing it to the application. For example, a file
|
||||
* name must always be provided as a <em>file:...</em> URL, and other
|
||||
* kinds of relative URI are also resolved against their bases.</p>
|
||||
*
|
||||
* @return A string containing the system identifier, or null
|
||||
* if none is available.
|
||||
* @see #getPublicId
|
||||
*/
|
||||
public abstract String getSystemId ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the line number where the current document event ends.
|
||||
* Lines are delimited by line ends, which are defined in
|
||||
* the XML specification.
|
||||
*
|
||||
* <p><strong>Warning:</strong> The return value from the method
|
||||
* is intended only as an approximation for the sake of diagnostics;
|
||||
* it is not intended to provide sufficient information
|
||||
* to edit the character content of the original XML document.
|
||||
* In some cases, these "line" numbers match what would be displayed
|
||||
* as columns, and in others they may not match the source text
|
||||
* due to internal entity expansion. </p>
|
||||
*
|
||||
* <p>The return value is an approximation of the line number
|
||||
* in the document entity or external parsed entity where the
|
||||
* markup triggering the event appears.</p>
|
||||
*
|
||||
* <p>If possible, the SAX driver should provide the line position
|
||||
* of the first character after the text associated with the document
|
||||
* event. The first line is line 1.</p>
|
||||
*
|
||||
* @return The line number, or -1 if none is available.
|
||||
* @see #getColumnNumber
|
||||
*/
|
||||
public abstract int getLineNumber ();
|
||||
|
||||
|
||||
/**
|
||||
* Return the column number where the current document event ends.
|
||||
* This is one-based number of Java <code>char</code> values since
|
||||
* the last line end.
|
||||
*
|
||||
* <p><strong>Warning:</strong> The return value from the method
|
||||
* is intended only as an approximation for the sake of diagnostics;
|
||||
* it is not intended to provide sufficient information
|
||||
* to edit the character content of the original XML document.
|
||||
* For example, when lines contain combining character sequences, wide
|
||||
* characters, surrogate pairs, or bi-directional text, the value may
|
||||
* not correspond to the column in a text editor's display. </p>
|
||||
*
|
||||
* <p>The return value is an approximation of the column number
|
||||
* in the document entity or external parsed entity where the
|
||||
* markup triggering the event appears.</p>
|
||||
*
|
||||
* <p>If possible, the SAX driver should provide the line position
|
||||
* of the first character after the text associated with the document
|
||||
* event. The first column in each line is column 1.</p>
|
||||
*
|
||||
* @return The column number, or -1 if none is available.
|
||||
* @see #getLineNumber
|
||||
*/
|
||||
public abstract int getColumnNumber ();
|
||||
|
||||
}
|
||||
|
||||
// end of Locator.java
|
||||
|
@ -1,207 +1,209 @@
|
||||
// SAX parser interface.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: Parser.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.Locale;
|
||||
|
||||
|
||||
/**
|
||||
* Basic interface for SAX (Simple API for XML) parsers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This was the main event supplier interface for SAX1; it has
|
||||
* been replaced in SAX2 by {@link org.xml.sax.XMLReader XMLReader},
|
||||
* which includes Namespace support and sophisticated configurability
|
||||
* and extensibility.</p>
|
||||
*
|
||||
* <p>All SAX1 parsers must implement this basic interface: it allows
|
||||
* applications to register handlers for different types of events
|
||||
* and to initiate a parse from a URI, or a character stream.</p>
|
||||
*
|
||||
* <p>All SAX1 parsers must also implement a zero-argument constructor
|
||||
* (though other constructors are also allowed).</p>
|
||||
*
|
||||
* <p>SAX1 parsers are reusable but not re-entrant: the application
|
||||
* may reuse a parser object (possibly with a different input source)
|
||||
* once the first parse has completed successfully, but it may not
|
||||
* invoke the parse() methods recursively within a parse.</p>
|
||||
*
|
||||
* @deprecated This interface has been replaced by the SAX2
|
||||
* {@link org.xml.sax.XMLReader XMLReader}
|
||||
* interface, which includes Namespace support.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.EntityResolver
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.DocumentHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
* @see org.xml.sax.HandlerBase
|
||||
* @see org.xml.sax.InputSource
|
||||
*/
|
||||
public interface Parser
|
||||
{
|
||||
|
||||
/**
|
||||
* Allow an application to request a locale for errors and warnings.
|
||||
*
|
||||
* <p>SAX parsers are not required to provide localisation for errors
|
||||
* and warnings; if they cannot support the requested locale,
|
||||
* however, they must throw a SAX exception. Applications may
|
||||
* not request a locale change in the middle of a parse.</p>
|
||||
*
|
||||
* @param locale A Java Locale object.
|
||||
* @exception org.xml.sax.SAXException Throws an exception
|
||||
* (using the previous or default locale) if the
|
||||
* requested locale is not supported.
|
||||
* @see org.xml.sax.SAXException
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void setLocale (Locale locale)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a custom entity resolver.
|
||||
*
|
||||
* <p>If the application does not register an entity resolver, the
|
||||
* SAX parser will resolve system identifiers and open connections
|
||||
* to entities itself (this is the default behaviour implemented in
|
||||
* HandlerBase).</p>
|
||||
*
|
||||
* <p>Applications may register a new or different entity resolver
|
||||
* in the middle of a parse, and the SAX parser must begin using
|
||||
* the new resolver immediately.</p>
|
||||
*
|
||||
* @param resolver The object for resolving entities.
|
||||
* @see EntityResolver
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setEntityResolver (EntityResolver resolver);
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a DTD event handler.
|
||||
*
|
||||
* <p>If the application does not register a DTD handler, all DTD
|
||||
* events reported by the SAX parser will be silently
|
||||
* ignored (this is the default behaviour implemented by
|
||||
* HandlerBase).</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The DTD handler.
|
||||
* @see DTDHandler
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setDTDHandler (DTDHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a document event handler.
|
||||
*
|
||||
* <p>If the application does not register a document handler, all
|
||||
* document events reported by the SAX parser will be silently
|
||||
* ignored (this is the default behaviour implemented by
|
||||
* HandlerBase).</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The document handler.
|
||||
* @see DocumentHandler
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setDocumentHandler (DocumentHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register an error event handler.
|
||||
*
|
||||
* <p>If the application does not register an error event handler,
|
||||
* all error events reported by the SAX parser will be silently
|
||||
* ignored, except for fatalError, which will throw a SAXException
|
||||
* (this is the default behaviour implemented by HandlerBase).</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The error handler.
|
||||
* @see ErrorHandler
|
||||
* @see SAXException
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setErrorHandler (ErrorHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Parse an XML document.
|
||||
*
|
||||
* <p>The application can use this method to instruct the SAX parser
|
||||
* to begin parsing an XML document from any valid input
|
||||
* source (a character stream, a byte stream, or a URI).</p>
|
||||
*
|
||||
* <p>Applications may not invoke this method while a parse is in
|
||||
* progress (they should create a new Parser instead for each
|
||||
* additional XML document). Once a parse is complete, an
|
||||
* application may reuse the same Parser object, possibly with a
|
||||
* different input source.</p>
|
||||
*
|
||||
* @param source The input source for the top-level of the
|
||||
* XML document.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see org.xml.sax.InputSource
|
||||
* @see #parse(java.lang.String)
|
||||
* @see #setEntityResolver
|
||||
* @see #setDTDHandler
|
||||
* @see #setDocumentHandler
|
||||
* @see #setErrorHandler
|
||||
*/
|
||||
public abstract void parse (InputSource source)
|
||||
throws SAXException, IOException;
|
||||
|
||||
|
||||
/**
|
||||
* Parse an XML document from a system identifier (URI).
|
||||
*
|
||||
* <p>This method is a shortcut for the common case of reading a
|
||||
* document from a system identifier. It is the exact
|
||||
* equivalent of the following:</p>
|
||||
*
|
||||
* <pre>
|
||||
* parse(new InputSource(systemId));
|
||||
* </pre>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be fully resolved
|
||||
* by the application before it is passed to the parser.</p>
|
||||
*
|
||||
* @param systemId The system identifier (URI).
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see #parse(org.xml.sax.InputSource)
|
||||
*/
|
||||
public abstract void parse (String systemId)
|
||||
throws SAXException, IOException;
|
||||
|
||||
}
|
||||
|
||||
// end of Parser.java
|
||||
// SAX parser interface.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: Parser.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.Locale;
|
||||
|
||||
|
||||
/**
|
||||
* Basic interface for SAX (Simple API for XML) parsers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This was the main event supplier interface for SAX1; it has
|
||||
* been replaced in SAX2 by {@link org.xml.sax.XMLReader XMLReader},
|
||||
* which includes Namespace support and sophisticated configurability
|
||||
* and extensibility.</p>
|
||||
*
|
||||
* <p>All SAX1 parsers must implement this basic interface: it allows
|
||||
* applications to register handlers for different types of events
|
||||
* and to initiate a parse from a URI, or a character stream.</p>
|
||||
*
|
||||
* <p>All SAX1 parsers must also implement a zero-argument constructor
|
||||
* (though other constructors are also allowed).</p>
|
||||
*
|
||||
* <p>SAX1 parsers are reusable but not re-entrant: the application
|
||||
* may reuse a parser object (possibly with a different input source)
|
||||
* once the first parse has completed successfully, but it may not
|
||||
* invoke the parse() methods recursively within a parse.</p>
|
||||
*
|
||||
* @deprecated This interface has been replaced by the SAX2
|
||||
* {@link org.xml.sax.XMLReader XMLReader}
|
||||
* interface, which includes Namespace support.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.EntityResolver
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.DocumentHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
* @see org.xml.sax.HandlerBase
|
||||
* @see org.xml.sax.InputSource
|
||||
*/
|
||||
public interface Parser
|
||||
{
|
||||
|
||||
/**
|
||||
* Allow an application to request a locale for errors and warnings.
|
||||
*
|
||||
* <p>SAX parsers are not required to provide localisation for errors
|
||||
* and warnings; if they cannot support the requested locale,
|
||||
* however, they must throw a SAX exception. Applications may
|
||||
* not request a locale change in the middle of a parse.</p>
|
||||
*
|
||||
* @param locale A Java Locale object.
|
||||
* @exception org.xml.sax.SAXException Throws an exception
|
||||
* (using the previous or default locale) if the
|
||||
* requested locale is not supported.
|
||||
* @see org.xml.sax.SAXException
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public abstract void setLocale (Locale locale)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a custom entity resolver.
|
||||
*
|
||||
* <p>If the application does not register an entity resolver, the
|
||||
* SAX parser will resolve system identifiers and open connections
|
||||
* to entities itself (this is the default behaviour implemented in
|
||||
* HandlerBase).</p>
|
||||
*
|
||||
* <p>Applications may register a new or different entity resolver
|
||||
* in the middle of a parse, and the SAX parser must begin using
|
||||
* the new resolver immediately.</p>
|
||||
*
|
||||
* @param resolver The object for resolving entities.
|
||||
* @see EntityResolver
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setEntityResolver (EntityResolver resolver);
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a DTD event handler.
|
||||
*
|
||||
* <p>If the application does not register a DTD handler, all DTD
|
||||
* events reported by the SAX parser will be silently
|
||||
* ignored (this is the default behaviour implemented by
|
||||
* HandlerBase).</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The DTD handler.
|
||||
* @see DTDHandler
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setDTDHandler (DTDHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a document event handler.
|
||||
*
|
||||
* <p>If the application does not register a document handler, all
|
||||
* document events reported by the SAX parser will be silently
|
||||
* ignored (this is the default behaviour implemented by
|
||||
* HandlerBase).</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The document handler.
|
||||
* @see DocumentHandler
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setDocumentHandler (DocumentHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register an error event handler.
|
||||
*
|
||||
* <p>If the application does not register an error event handler,
|
||||
* all error events reported by the SAX parser will be silently
|
||||
* ignored, except for fatalError, which will throw a SAXException
|
||||
* (this is the default behaviour implemented by HandlerBase).</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The error handler.
|
||||
* @see ErrorHandler
|
||||
* @see SAXException
|
||||
* @see HandlerBase
|
||||
*/
|
||||
public abstract void setErrorHandler (ErrorHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Parse an XML document.
|
||||
*
|
||||
* <p>The application can use this method to instruct the SAX parser
|
||||
* to begin parsing an XML document from any valid input
|
||||
* source (a character stream, a byte stream, or a URI).</p>
|
||||
*
|
||||
* <p>Applications may not invoke this method while a parse is in
|
||||
* progress (they should create a new Parser instead for each
|
||||
* additional XML document). Once a parse is complete, an
|
||||
* application may reuse the same Parser object, possibly with a
|
||||
* different input source.</p>
|
||||
*
|
||||
* @param source The input source for the top-level of the
|
||||
* XML document.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see org.xml.sax.InputSource
|
||||
* @see #parse(java.lang.String)
|
||||
* @see #setEntityResolver
|
||||
* @see #setDTDHandler
|
||||
* @see #setDocumentHandler
|
||||
* @see #setErrorHandler
|
||||
*/
|
||||
public abstract void parse (InputSource source)
|
||||
throws SAXException, IOException;
|
||||
|
||||
|
||||
/**
|
||||
* Parse an XML document from a system identifier (URI).
|
||||
*
|
||||
* <p>This method is a shortcut for the common case of reading a
|
||||
* document from a system identifier. It is the exact
|
||||
* equivalent of the following:</p>
|
||||
*
|
||||
* <pre>
|
||||
* parse(new InputSource(systemId));
|
||||
* </pre>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be fully resolved
|
||||
* by the application before it is passed to the parser.</p>
|
||||
*
|
||||
* @param systemId The system identifier (URI).
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see #parse(org.xml.sax.InputSource)
|
||||
*/
|
||||
public abstract void parse (String systemId)
|
||||
throws SAXException, IOException;
|
||||
|
||||
}
|
||||
|
||||
// end of Parser.java
|
||||
|
@ -1,144 +1,153 @@
|
||||
// SAX exception class.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: SAXException.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Encapsulate a general SAX error or warning.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class can contain basic error or warning information from
|
||||
* either the XML parser or the application: a parser writer or
|
||||
* application writer can subclass it to provide additional
|
||||
* functionality. SAX handlers may throw this exception or
|
||||
* any exception subclassed from it.</p>
|
||||
*
|
||||
* <p>If the application needs to pass through other types of
|
||||
* exceptions, it must wrap those exceptions in a SAXException
|
||||
* or an exception derived from a SAXException.</p>
|
||||
*
|
||||
* <p>If the parser or application needs to include information about a
|
||||
* specific location in an XML document, it should use the
|
||||
* {@link org.xml.sax.SAXParseException SAXParseException} subclass.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public class SAXException extends Exception {
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException.
|
||||
*
|
||||
* @param message The error or warning message.
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public SAXException (String message) {
|
||||
super(message);
|
||||
this.exception = null;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException wrapping an existing exception.
|
||||
*
|
||||
* <p>The existing exception will be embedded in the new
|
||||
* one, and its message will become the default message for
|
||||
* the SAXException.</p>
|
||||
*
|
||||
* @param e The exception to be wrapped in a SAXException.
|
||||
*/
|
||||
public SAXException (Exception e)
|
||||
{
|
||||
super();
|
||||
this.exception = e;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException from an existing exception.
|
||||
*
|
||||
* <p>The existing exception will be embedded in the new
|
||||
* one, but the new exception will have its own message.</p>
|
||||
*
|
||||
* @param message The detail message.
|
||||
* @param e The exception to be wrapped in a SAXException.
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public SAXException (String message, Exception e)
|
||||
{
|
||||
super(message);
|
||||
this.exception = e;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return a detail message for this exception.
|
||||
*
|
||||
* <p>If there is an embedded exception, and if the SAXException
|
||||
* has no detail message of its own, this method will return
|
||||
* the detail message from the embedded exception.</p>
|
||||
*
|
||||
* @return The error or warning message.
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public String getMessage ()
|
||||
{
|
||||
String message = super.getMessage();
|
||||
|
||||
if (message == null && exception != null) {
|
||||
return exception.getMessage();
|
||||
} else {
|
||||
return message;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the embedded exception, if any.
|
||||
*
|
||||
* @return The embedded exception, or null if there is none.
|
||||
*/
|
||||
public Exception getException ()
|
||||
{
|
||||
return exception;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Override toString to pick up any embedded exception.
|
||||
*
|
||||
* @return A string representation of this exception.
|
||||
*/
|
||||
public String toString ()
|
||||
{
|
||||
if (exception != null) {
|
||||
return exception.toString();
|
||||
} else {
|
||||
return super.toString();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* @serial The embedded exception if tunnelling, or null.
|
||||
*/
|
||||
private Exception exception;
|
||||
|
||||
}
|
||||
|
||||
// end of SAXException.java
|
||||
// SAX exception class.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: SAXException.java,v 1.4.2.4 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Encapsulate a general SAX error or warning.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class can contain basic error or warning information from
|
||||
* either the XML parser or the application: a parser writer or
|
||||
* application writer can subclass it to provide additional
|
||||
* functionality. SAX handlers may throw this exception or
|
||||
* any exception subclassed from it.</p>
|
||||
*
|
||||
* <p>If the application needs to pass through other types of
|
||||
* exceptions, it must wrap those exceptions in a SAXException
|
||||
* or an exception derived from a SAXException.</p>
|
||||
*
|
||||
* <p>If the parser or application needs to include information about a
|
||||
* specific location in an XML document, it should use the
|
||||
* {@link org.xml.sax.SAXParseException SAXParseException} subclass.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public class SAXException extends Exception {
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException.
|
||||
*/
|
||||
public SAXException ()
|
||||
{
|
||||
super();
|
||||
this.exception = null;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException.
|
||||
*
|
||||
* @param message The error or warning message.
|
||||
*/
|
||||
public SAXException (String message) {
|
||||
super(message);
|
||||
this.exception = null;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException wrapping an existing exception.
|
||||
*
|
||||
* <p>The existing exception will be embedded in the new
|
||||
* one, and its message will become the default message for
|
||||
* the SAXException.</p>
|
||||
*
|
||||
* @param e The exception to be wrapped in a SAXException.
|
||||
*/
|
||||
public SAXException (Exception e)
|
||||
{
|
||||
super();
|
||||
this.exception = e;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXException from an existing exception.
|
||||
*
|
||||
* <p>The existing exception will be embedded in the new
|
||||
* one, but the new exception will have its own message.</p>
|
||||
*
|
||||
* @param message The detail message.
|
||||
* @param e The exception to be wrapped in a SAXException.
|
||||
*/
|
||||
public SAXException (String message, Exception e)
|
||||
{
|
||||
super(message);
|
||||
this.exception = e;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return a detail message for this exception.
|
||||
*
|
||||
* <p>If there is an embedded exception, and if the SAXException
|
||||
* has no detail message of its own, this method will return
|
||||
* the detail message from the embedded exception.</p>
|
||||
*
|
||||
* @return The error or warning message.
|
||||
*/
|
||||
public String getMessage ()
|
||||
{
|
||||
String message = super.getMessage();
|
||||
|
||||
if (message == null && exception != null) {
|
||||
return exception.getMessage();
|
||||
} else {
|
||||
return message;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the embedded exception, if any.
|
||||
*
|
||||
* @return The embedded exception, or null if there is none.
|
||||
*/
|
||||
public Exception getException ()
|
||||
{
|
||||
return exception;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Override toString to pick up any embedded exception.
|
||||
*
|
||||
* @return A string representation of this exception.
|
||||
*/
|
||||
public String toString ()
|
||||
{
|
||||
if (exception != null) {
|
||||
return exception.toString();
|
||||
} else {
|
||||
return super.toString();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* @serial The embedded exception if tunnelling, or null.
|
||||
*/
|
||||
private Exception exception;
|
||||
|
||||
}
|
||||
|
||||
// end of SAXException.java
|
||||
|
@ -1,44 +1,55 @@
|
||||
// SAXNotRecognizedException.java - unrecognized feature or value.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: SAXNotRecognizedException.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Exception class for an unrecognized identifier.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>An XMLReader will throw this exception when it finds an
|
||||
* unrecognized feature or property identifier; SAX applications and
|
||||
* extensions may use this class for other, similar purposes.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.SAXNotSupportedException
|
||||
*/
|
||||
public class SAXNotRecognizedException extends SAXException
|
||||
{
|
||||
|
||||
/**
|
||||
* Construct a new exception with the given message.
|
||||
*
|
||||
* @param message The text message of the exception.
|
||||
*/
|
||||
public SAXNotRecognizedException (String message)
|
||||
{
|
||||
super(message);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of SAXNotRecognizedException.java
|
||||
// SAXNotRecognizedException.java - unrecognized feature or value.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: SAXNotRecognizedException.java,v 1.4.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Exception class for an unrecognized identifier.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>An XMLReader will throw this exception when it finds an
|
||||
* unrecognized feature or property identifier; SAX applications and
|
||||
* extensions may use this class for other, similar purposes.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.SAXNotSupportedException
|
||||
*/
|
||||
public class SAXNotRecognizedException extends SAXException
|
||||
{
|
||||
|
||||
/**
|
||||
* Default constructor.
|
||||
*/
|
||||
public SAXNotRecognizedException ()
|
||||
{
|
||||
super();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Construct a new exception with the given message.
|
||||
*
|
||||
* @param message The text message of the exception.
|
||||
*/
|
||||
public SAXNotRecognizedException (String message)
|
||||
{
|
||||
super(message);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of SAXNotRecognizedException.java
|
||||
|
@ -1,44 +1,55 @@
|
||||
// SAXNotSupportedException.java - unsupported feature or value.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: SAXNotSupportedException.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Exception class for an unsupported operation.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>An XMLReader will throw this exception when it recognizes a
|
||||
* feature or property identifier, but cannot perform the requested
|
||||
* operation (setting a state or value). Other SAX2 applications and
|
||||
* extensions may use this class for similar purposes.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.SAXNotRecognizedException
|
||||
*/
|
||||
public class SAXNotSupportedException extends SAXException
|
||||
{
|
||||
|
||||
/**
|
||||
* Construct a new exception with the given message.
|
||||
*
|
||||
* @param message The text message of the exception.
|
||||
*/
|
||||
public SAXNotSupportedException (String message)
|
||||
{
|
||||
super(message);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of SAXNotSupportedException.java
|
||||
// SAXNotSupportedException.java - unsupported feature or value.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: SAXNotSupportedException.java,v 1.4.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Exception class for an unsupported operation.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>An XMLReader will throw this exception when it recognizes a
|
||||
* feature or property identifier, but cannot perform the requested
|
||||
* operation (setting a state or value). Other SAX2 applications and
|
||||
* extensions may use this class for similar purposes.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.SAXNotRecognizedException
|
||||
*/
|
||||
public class SAXNotSupportedException extends SAXException
|
||||
{
|
||||
|
||||
/**
|
||||
* Construct a new exception with no message.
|
||||
*/
|
||||
public SAXNotSupportedException ()
|
||||
{
|
||||
super();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Construct a new exception with the given message.
|
||||
*
|
||||
* @param message The text message of the exception.
|
||||
*/
|
||||
public SAXNotSupportedException (String message)
|
||||
{
|
||||
super(message);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of SAXNotSupportedException.java
|
||||
|
@ -1,264 +1,270 @@
|
||||
// SAX exception class.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: SAXParseException.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Encapsulate an XML parse error or warning.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This exception will include information for locating the error
|
||||
* in the original XML document. Note that although the application
|
||||
* will receive a SAXParseException as the argument to the handlers
|
||||
* in the {@link org.xml.sax.ErrorHandler ErrorHandler} interface,
|
||||
* the application is not actually required to throw the exception;
|
||||
* instead, it can simply read the information in it and take a
|
||||
* different action.</p>
|
||||
*
|
||||
* <p>Since this exception is a subclass of {@link org.xml.sax.SAXException
|
||||
* SAXException}, it inherits the ability to wrap another exception.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.SAXException
|
||||
* @see org.xml.sax.Locator
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public class SAXParseException extends SAXException {
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Constructors.
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXParseException from a message and a Locator.
|
||||
*
|
||||
* <p>This constructor is especially useful when an application is
|
||||
* creating its own exception from within a {@link org.xml.sax.ContentHandler
|
||||
* ContentHandler} callback.</p>
|
||||
*
|
||||
* @param message The error or warning message.
|
||||
* @param locator The locator object for the error or warning (may be
|
||||
* null).
|
||||
* @see org.xml.sax.Locator
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public SAXParseException (String message, Locator locator) {
|
||||
super(message);
|
||||
if (locator != null) {
|
||||
init(locator.getPublicId(), locator.getSystemId(),
|
||||
locator.getLineNumber(), locator.getColumnNumber());
|
||||
} else {
|
||||
init(null, null, -1, -1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Wrap an existing exception in a SAXParseException.
|
||||
*
|
||||
* <p>This constructor is especially useful when an application is
|
||||
* creating its own exception from within a {@link org.xml.sax.ContentHandler
|
||||
* ContentHandler} callback, and needs to wrap an existing exception that is not a
|
||||
* subclass of {@link org.xml.sax.SAXException SAXException}.</p>
|
||||
*
|
||||
* @param message The error or warning message, or null to
|
||||
* use the message from the embedded exception.
|
||||
* @param locator The locator object for the error or warning (may be
|
||||
* null).
|
||||
* @param e Any exception.
|
||||
* @see org.xml.sax.Locator
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public SAXParseException (String message, Locator locator,
|
||||
Exception e) {
|
||||
super(message, e);
|
||||
if (locator != null) {
|
||||
init(locator.getPublicId(), locator.getSystemId(),
|
||||
locator.getLineNumber(), locator.getColumnNumber());
|
||||
} else {
|
||||
init(null, null, -1, -1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXParseException.
|
||||
*
|
||||
* <p>This constructor is most useful for parser writers.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the parser must resolve it
|
||||
* fully before creating the exception.</p>
|
||||
*
|
||||
* @param message The error or warning message.
|
||||
* @param publicId The public identifier of the entity that generated
|
||||
* the error or warning.
|
||||
* @param systemId The system identifier of the entity that generated
|
||||
* the error or warning.
|
||||
* @param lineNumber The line number of the end of the text that
|
||||
* caused the error or warning.
|
||||
* @param columnNumber The column number of the end of the text that
|
||||
* cause the error or warning.
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public SAXParseException (String message, String publicId, String systemId,
|
||||
int lineNumber, int columnNumber)
|
||||
{
|
||||
super(message);
|
||||
init(publicId, systemId, lineNumber, columnNumber);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXParseException with an embedded exception.
|
||||
*
|
||||
* <p>This constructor is most useful for parser writers who
|
||||
* need to wrap an exception that is not a subclass of
|
||||
* {@link org.xml.sax.SAXException SAXException}.</p>
|
||||
*
|
||||
* <p>If the system identifier is a URL, the parser must resolve it
|
||||
* fully before creating the exception.</p>
|
||||
*
|
||||
* @param message The error or warning message, or null to use
|
||||
* the message from the embedded exception.
|
||||
* @param publicId The public identifier of the entity that generated
|
||||
* the error or warning.
|
||||
* @param systemId The system identifier of the entity that generated
|
||||
* the error or warning.
|
||||
* @param lineNumber The line number of the end of the text that
|
||||
* caused the error or warning.
|
||||
* @param columnNumber The column number of the end of the text that
|
||||
* cause the error or warning.
|
||||
* @param e Another exception to embed in this one.
|
||||
* @see org.xml.sax.Parser#setLocale
|
||||
*/
|
||||
public SAXParseException (String message, String publicId, String systemId,
|
||||
int lineNumber, int columnNumber, Exception e)
|
||||
{
|
||||
super(message, e);
|
||||
init(publicId, systemId, lineNumber, columnNumber);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Internal initialization method.
|
||||
*
|
||||
* @param publicId The public identifier of the entity which generated the exception,
|
||||
* or null.
|
||||
* @param systemId The system identifier of the entity which generated the exception,
|
||||
* or null.
|
||||
* @param lineNumber The line number of the error, or -1.
|
||||
* @param columnNumber The column number of the error, or -1.
|
||||
*/
|
||||
private void init (String publicId, String systemId,
|
||||
int lineNumber, int columnNumber)
|
||||
{
|
||||
this.publicId = publicId;
|
||||
this.systemId = systemId;
|
||||
this.lineNumber = lineNumber;
|
||||
this.columnNumber = columnNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the public identifier of the entity where the exception occurred.
|
||||
*
|
||||
* @return A string containing the public identifier, or null
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getPublicId
|
||||
*/
|
||||
public String getPublicId ()
|
||||
{
|
||||
return this.publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the system identifier of the entity where the exception occurred.
|
||||
*
|
||||
* <p>If the system identifier is a URL, it will be resolved
|
||||
* fully.</p>
|
||||
*
|
||||
* @return A string containing the system identifier, or null
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getSystemId
|
||||
*/
|
||||
public String getSystemId ()
|
||||
{
|
||||
return this.systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* The line number of the end of the text where the exception occurred.
|
||||
*
|
||||
* @return An integer representing the line number, or -1
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getLineNumber
|
||||
*/
|
||||
public int getLineNumber ()
|
||||
{
|
||||
return this.lineNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* The column number of the end of the text where the exception occurred.
|
||||
*
|
||||
* <p>The first column in a line is position 1.</p>
|
||||
*
|
||||
* @return An integer representing the column number, or -1
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getColumnNumber
|
||||
*/
|
||||
public int getColumnNumber ()
|
||||
{
|
||||
return this.columnNumber;
|
||||
}
|
||||
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* @serial The public identifier, or null.
|
||||
* @see #getPublicId
|
||||
*/
|
||||
private String publicId;
|
||||
|
||||
|
||||
/**
|
||||
* @serial The system identifier, or null.
|
||||
* @see #getSystemId
|
||||
*/
|
||||
private String systemId;
|
||||
|
||||
|
||||
/**
|
||||
* @serial The line number, or -1.
|
||||
* @see #getLineNumber
|
||||
*/
|
||||
private int lineNumber;
|
||||
|
||||
|
||||
/**
|
||||
* @serial The column number, or -1.
|
||||
* @see #getColumnNumber
|
||||
*/
|
||||
private int columnNumber;
|
||||
|
||||
}
|
||||
|
||||
// end of SAXParseException.java
|
||||
// SAX exception class.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: SAXParseException.java,v 1.3.2.5 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
/**
|
||||
* Encapsulate an XML parse error or warning.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This exception may include information for locating the error
|
||||
* in the original XML document, as if it came from a {@link Locator}
|
||||
* object. Note that although the application
|
||||
* will receive a SAXParseException as the argument to the handlers
|
||||
* in the {@link org.xml.sax.ErrorHandler ErrorHandler} interface,
|
||||
* the application is not actually required to throw the exception;
|
||||
* instead, it can simply read the information in it and take a
|
||||
* different action.</p>
|
||||
*
|
||||
* <p>Since this exception is a subclass of {@link org.xml.sax.SAXException
|
||||
* SAXException}, it inherits the ability to wrap another exception.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.SAXException
|
||||
* @see org.xml.sax.Locator
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public class SAXParseException extends SAXException {
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Constructors.
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXParseException from a message and a Locator.
|
||||
*
|
||||
* <p>This constructor is especially useful when an application is
|
||||
* creating its own exception from within a {@link org.xml.sax.ContentHandler
|
||||
* ContentHandler} callback.</p>
|
||||
*
|
||||
* @param message The error or warning message.
|
||||
* @param locator The locator object for the error or warning (may be
|
||||
* null).
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public SAXParseException (String message, Locator locator) {
|
||||
super(message);
|
||||
if (locator != null) {
|
||||
init(locator.getPublicId(), locator.getSystemId(),
|
||||
locator.getLineNumber(), locator.getColumnNumber());
|
||||
} else {
|
||||
init(null, null, -1, -1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Wrap an existing exception in a SAXParseException.
|
||||
*
|
||||
* <p>This constructor is especially useful when an application is
|
||||
* creating its own exception from within a {@link org.xml.sax.ContentHandler
|
||||
* ContentHandler} callback, and needs to wrap an existing exception that is not a
|
||||
* subclass of {@link org.xml.sax.SAXException SAXException}.</p>
|
||||
*
|
||||
* @param message The error or warning message, or null to
|
||||
* use the message from the embedded exception.
|
||||
* @param locator The locator object for the error or warning (may be
|
||||
* null).
|
||||
* @param e Any exception.
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public SAXParseException (String message, Locator locator,
|
||||
Exception e) {
|
||||
super(message, e);
|
||||
if (locator != null) {
|
||||
init(locator.getPublicId(), locator.getSystemId(),
|
||||
locator.getLineNumber(), locator.getColumnNumber());
|
||||
} else {
|
||||
init(null, null, -1, -1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXParseException.
|
||||
*
|
||||
* <p>This constructor is most useful for parser writers.</p>
|
||||
*
|
||||
* <p>All parameters except the message are as if
|
||||
* they were provided by a {@link Locator}. For example, if the
|
||||
* system identifier is a URL (including relative filename), the
|
||||
* caller must resolve it fully before creating the exception.</p>
|
||||
*
|
||||
*
|
||||
* @param message The error or warning message.
|
||||
* @param publicId The public identifer of the entity that generated
|
||||
* the error or warning.
|
||||
* @param systemId The system identifer of the entity that generated
|
||||
* the error or warning.
|
||||
* @param lineNumber The line number of the end of the text that
|
||||
* caused the error or warning.
|
||||
* @param columnNumber The column number of the end of the text that
|
||||
* cause the error or warning.
|
||||
*/
|
||||
public SAXParseException (String message, String publicId, String systemId,
|
||||
int lineNumber, int columnNumber)
|
||||
{
|
||||
super(message);
|
||||
init(publicId, systemId, lineNumber, columnNumber);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAXParseException with an embedded exception.
|
||||
*
|
||||
* <p>This constructor is most useful for parser writers who
|
||||
* need to wrap an exception that is not a subclass of
|
||||
* {@link org.xml.sax.SAXException SAXException}.</p>
|
||||
*
|
||||
* <p>All parameters except the message and exception are as if
|
||||
* they were provided by a {@link Locator}. For example, if the
|
||||
* system identifier is a URL (including relative filename), the
|
||||
* caller must resolve it fully before creating the exception.</p>
|
||||
*
|
||||
* @param message The error or warning message, or null to use
|
||||
* the message from the embedded exception.
|
||||
* @param publicId The public identifer of the entity that generated
|
||||
* the error or warning.
|
||||
* @param systemId The system identifer of the entity that generated
|
||||
* the error or warning.
|
||||
* @param lineNumber The line number of the end of the text that
|
||||
* caused the error or warning.
|
||||
* @param columnNumber The column number of the end of the text that
|
||||
* cause the error or warning.
|
||||
* @param e Another exception to embed in this one.
|
||||
*/
|
||||
public SAXParseException (String message, String publicId, String systemId,
|
||||
int lineNumber, int columnNumber, Exception e)
|
||||
{
|
||||
super(message, e);
|
||||
init(publicId, systemId, lineNumber, columnNumber);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Internal initialization method.
|
||||
*
|
||||
* @param publicId The public identifier of the entity which generated the exception,
|
||||
* or null.
|
||||
* @param systemId The system identifier of the entity which generated the exception,
|
||||
* or null.
|
||||
* @param lineNumber The line number of the error, or -1.
|
||||
* @param columnNumber The column number of the error, or -1.
|
||||
*/
|
||||
private void init (String publicId, String systemId,
|
||||
int lineNumber, int columnNumber)
|
||||
{
|
||||
this.publicId = publicId;
|
||||
this.systemId = systemId;
|
||||
this.lineNumber = lineNumber;
|
||||
this.columnNumber = columnNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the public identifier of the entity where the exception occurred.
|
||||
*
|
||||
* @return A string containing the public identifier, or null
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getPublicId
|
||||
*/
|
||||
public String getPublicId ()
|
||||
{
|
||||
return this.publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the system identifier of the entity where the exception occurred.
|
||||
*
|
||||
* <p>If the system identifier is a URL, it will have been resolved
|
||||
* fully.</p>
|
||||
*
|
||||
* @return A string containing the system identifier, or null
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getSystemId
|
||||
*/
|
||||
public String getSystemId ()
|
||||
{
|
||||
return this.systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* The line number of the end of the text where the exception occurred.
|
||||
*
|
||||
* <p>The first line is line 1.</p>
|
||||
*
|
||||
* @return An integer representing the line number, or -1
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getLineNumber
|
||||
*/
|
||||
public int getLineNumber ()
|
||||
{
|
||||
return this.lineNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* The column number of the end of the text where the exception occurred.
|
||||
*
|
||||
* <p>The first column in a line is position 1.</p>
|
||||
*
|
||||
* @return An integer representing the column number, or -1
|
||||
* if none is available.
|
||||
* @see org.xml.sax.Locator#getColumnNumber
|
||||
*/
|
||||
public int getColumnNumber ()
|
||||
{
|
||||
return this.columnNumber;
|
||||
}
|
||||
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* @serial The public identifier, or null.
|
||||
* @see #getPublicId
|
||||
*/
|
||||
private String publicId;
|
||||
|
||||
|
||||
/**
|
||||
* @serial The system identifier, or null.
|
||||
* @see #getSystemId
|
||||
*/
|
||||
private String systemId;
|
||||
|
||||
|
||||
/**
|
||||
* @serial The line number, or -1.
|
||||
* @see #getLineNumber
|
||||
*/
|
||||
private int lineNumber;
|
||||
|
||||
|
||||
/**
|
||||
* @serial The column number, or -1.
|
||||
* @see #getColumnNumber
|
||||
*/
|
||||
private int columnNumber;
|
||||
|
||||
}
|
||||
|
||||
// end of SAXParseException.java
|
||||
|
@ -1,65 +1,67 @@
|
||||
// XMLFilter.java - filter SAX2 events.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: XMLFilter.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for an XML filter.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>An XML filter is like an XML reader, except that it obtains its
|
||||
* events from another XML reader rather than a primary source like
|
||||
* an XML document or database. Filters can modify a stream of
|
||||
* events as they pass on to the final application.</p>
|
||||
*
|
||||
* <p>The XMLFilterImpl helper class provides a convenient base
|
||||
* for creating SAX2 filters, by passing on all {@link org.xml.sax.EntityResolver
|
||||
* EntityResolver}, {@link org.xml.sax.DTDHandler DTDHandler},
|
||||
* {@link org.xml.sax.ContentHandler ContentHandler} and {@link org.xml.sax.ErrorHandler
|
||||
* ErrorHandler} events automatically.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.helpers.XMLFilterImpl
|
||||
*/
|
||||
public interface XMLFilter extends XMLReader
|
||||
{
|
||||
|
||||
/**
|
||||
* Set the parent reader.
|
||||
*
|
||||
* <p>This method allows the application to link the filter to
|
||||
* a parent reader (which may be another filter). The argument
|
||||
* may not be null.</p>
|
||||
*
|
||||
* @param parent The parent reader.
|
||||
*/
|
||||
public abstract void setParent (XMLReader parent);
|
||||
|
||||
|
||||
/**
|
||||
* Get the parent reader.
|
||||
*
|
||||
* <p>This method allows the application to query the parent
|
||||
* reader (which may be another filter). It is generally a
|
||||
* bad idea to perform any operations on the parent reader
|
||||
* directly: they should all pass through this filter.</p>
|
||||
*
|
||||
* @return The parent filter, or null if none has been set.
|
||||
*/
|
||||
public abstract XMLReader getParent ();
|
||||
|
||||
}
|
||||
|
||||
// end of XMLFilter.java
|
||||
// XMLFilter.java - filter SAX2 events.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: XMLFilter.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for an XML filter.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>An XML filter is like an XML reader, except that it obtains its
|
||||
* events from another XML reader rather than a primary source like
|
||||
* an XML document or database. Filters can modify a stream of
|
||||
* events as they pass on to the final application.</p>
|
||||
*
|
||||
* <p>The XMLFilterImpl helper class provides a convenient base
|
||||
* for creating SAX2 filters, by passing on all {@link org.xml.sax.EntityResolver
|
||||
* EntityResolver}, {@link org.xml.sax.DTDHandler DTDHandler},
|
||||
* {@link org.xml.sax.ContentHandler ContentHandler} and {@link org.xml.sax.ErrorHandler
|
||||
* ErrorHandler} events automatically.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.helpers.XMLFilterImpl
|
||||
*/
|
||||
public interface XMLFilter extends XMLReader
|
||||
{
|
||||
|
||||
/**
|
||||
* Set the parent reader.
|
||||
*
|
||||
* <p>This method allows the application to link the filter to
|
||||
* a parent reader (which may be another filter). The argument
|
||||
* may not be null.</p>
|
||||
*
|
||||
* @param parent The parent reader.
|
||||
*/
|
||||
public abstract void setParent (XMLReader parent);
|
||||
|
||||
|
||||
/**
|
||||
* Get the parent reader.
|
||||
*
|
||||
* <p>This method allows the application to query the parent
|
||||
* reader (which may be another filter). It is generally a
|
||||
* bad idea to perform any operations on the parent reader
|
||||
* directly: they should all pass through this filter.</p>
|
||||
*
|
||||
* @return The parent filter, or null if none has been set.
|
||||
*/
|
||||
public abstract XMLReader getParent ();
|
||||
|
||||
}
|
||||
|
||||
// end of XMLFilter.java
|
||||
|
@ -1,415 +1,398 @@
|
||||
// XMLReader.java - read an XML document.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: XMLReader.java,v 1.1 2000/10/02 02:43:17 sboag Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for reading an XML document using callbacks.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p><strong>Note:</strong> despite its name, this interface does
|
||||
* <em>not</em> extend the standard Java {@link java.io.Reader Reader}
|
||||
* interface, because reading XML is a fundamentally different activity
|
||||
* than reading character data.</p>
|
||||
*
|
||||
* <p>XMLReader is the interface that an XML parser's SAX2 driver must
|
||||
* implement. This interface allows an application to set and
|
||||
* query features and properties in the parser, to register
|
||||
* event handlers for document processing, and to initiate
|
||||
* a document parse.</p>
|
||||
*
|
||||
* <p>All SAX interfaces are assumed to be synchronous: the
|
||||
* {@link #parse parse} methods must not return until parsing
|
||||
* is complete, and readers must wait for an event-handler callback
|
||||
* to return before reporting the next event.</p>
|
||||
*
|
||||
* <p>This interface replaces the (now deprecated) SAX 1.0 {@link
|
||||
* org.xml.sax.Parser Parser} interface. The XMLReader interface
|
||||
* contains two important enhancements over the old Parser
|
||||
* interface:</p>
|
||||
*
|
||||
* <ol>
|
||||
* <li>it adds a standard way to query and set features and
|
||||
* properties; and</li>
|
||||
* <li>it adds Namespace support, which is required for many
|
||||
* higher-level XML standards.</li>
|
||||
* </ol>
|
||||
*
|
||||
* <p>There are adapters available to convert a SAX1 Parser to
|
||||
* a SAX2 XMLReader and vice-versa.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.XMLFilter
|
||||
* @see org.xml.sax.helpers.ParserAdapter
|
||||
* @see org.xml.sax.helpers.XMLReaderAdapter
|
||||
*/
|
||||
public interface XMLReader
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Configuration.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Look up the value of a feature.
|
||||
*
|
||||
* <p>The feature name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a feature name but
|
||||
* to be unable to return its value; this is especially true
|
||||
* in the case of an adapter for a SAX1 Parser, which has
|
||||
* no way of knowing whether the underlying parser is
|
||||
* performing validation or expanding external entities.</p>
|
||||
*
|
||||
* <p>All XMLReaders are required to recognize the
|
||||
* http://xml.org/sax/features/namespaces and the
|
||||
* http://xml.org/sax/features/namespace-prefixes feature names.</p>
|
||||
*
|
||||
* <p>Some feature values may be available only in specific
|
||||
* contexts, such as before, during, or after a parse.</p>
|
||||
*
|
||||
* <p>Typical usage is something like this:</p>
|
||||
*
|
||||
* <pre>
|
||||
* XMLReader r = new MySAXDriver();
|
||||
*
|
||||
* // try to activate validation
|
||||
* try {
|
||||
* r.setFeature("http://xml.org/sax/features/validation", true);
|
||||
* } catch (SAXException e) {
|
||||
* System.err.println("Cannot activate validation.");
|
||||
* }
|
||||
*
|
||||
* // register event handlers
|
||||
* r.setContentHandler(new MyContentHandler());
|
||||
* r.setErrorHandler(new MyErrorHandler());
|
||||
*
|
||||
* // parse the first document
|
||||
* try {
|
||||
* r.parse("http://www.foo.com/mydoc.xml");
|
||||
* } catch (IOException e) {
|
||||
* System.err.println("I/O exception reading XML document");
|
||||
* } catch (SAXException e) {
|
||||
* System.err.println("XML exception reading document.");
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>Implementors are free (and encouraged) to invent their own features,
|
||||
* using names built on their own URIs.</p>
|
||||
*
|
||||
* @param name The feature name, which is a fully-qualified URI.
|
||||
* @return The current state of the feature (true or false).
|
||||
* @exception org.xml.sax.SAXNotRecognizedException When the
|
||||
* XMLReader does not recognize the feature name.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the feature name but
|
||||
* cannot determine its value at this time.
|
||||
* @see #setFeature
|
||||
*/
|
||||
public boolean getFeature (String name)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
/**
|
||||
* Set the state of a feature.
|
||||
*
|
||||
* <p>The feature name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a feature name but
|
||||
* to be unable to set its value; this is especially true
|
||||
* in the case of an adapter for a SAX1 {@link org.xml.sax.Parser Parser},
|
||||
* which has no way of affecting whether the underlying parser is
|
||||
* validating, for example.</p>
|
||||
*
|
||||
* <p>All XMLReaders are required to support setting
|
||||
* http://xml.org/sax/features/namespaces to true and
|
||||
* http://xml.org/sax/features/namespace-prefixes to false.</p>
|
||||
*
|
||||
* <p>Some feature values may be immutable or mutable only
|
||||
* in specific contexts, such as before, during, or after
|
||||
* a parse.</p>
|
||||
*
|
||||
* @param name The feature name, which is a fully-qualified URI.
|
||||
* @param state The requested state of the feature (true or false).
|
||||
* @exception org.xml.sax.SAXNotRecognizedException When the
|
||||
* XMLReader does not recognize the feature name.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the feature name but
|
||||
* cannot set the requested value.
|
||||
* @see #getFeature
|
||||
*/
|
||||
public void setFeature (String name, boolean value)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
/**
|
||||
* Look up the value of a property.
|
||||
*
|
||||
* <p>The property name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a property name but
|
||||
* to be unable to return its state; this is especially true
|
||||
* in the case of an adapter for a SAX1 {@link org.xml.sax.Parser
|
||||
* Parser}.</p>
|
||||
*
|
||||
* <p>XMLReaders are not required to recognize any specific
|
||||
* property names, though an initial core set is documented for
|
||||
* SAX2.</p>
|
||||
*
|
||||
* <p>Some property values may be available only in specific
|
||||
* contexts, such as before, during, or after a parse.</p>
|
||||
*
|
||||
* <p>Implementors are free (and encouraged) to invent their own properties,
|
||||
* using names built on their own URIs.</p>
|
||||
*
|
||||
* @param name The property name, which is a fully-qualified URI.
|
||||
* @return The current value of the property.
|
||||
* @exception org.xml.sax.SAXNotRecognizedException When the
|
||||
* XMLReader does not recognize the property name.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the property name but
|
||||
* cannot determine its value at this time.
|
||||
* @see #setProperty
|
||||
*/
|
||||
public Object getProperty (String name)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
/**
|
||||
* Set the value of a property.
|
||||
*
|
||||
* <p>The property name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a property name but
|
||||
* to be unable to set its value; this is especially true
|
||||
* in the case of an adapter for a SAX1 {@link org.xml.sax.Parser
|
||||
* Parser}.</p>
|
||||
*
|
||||
* <p>XMLReaders are not required to recognize setting
|
||||
* any specific property names, though a core set is provided with
|
||||
* SAX2.</p>
|
||||
*
|
||||
* <p>Some property values may be immutable or mutable only
|
||||
* in specific contexts, such as before, during, or after
|
||||
* a parse.</p>
|
||||
*
|
||||
* <p>This method is also the standard mechanism for setting
|
||||
* extended handlers.</p>
|
||||
*
|
||||
* @param name The property name, which is a fully-qualified URI.
|
||||
* @param state The requested value for the property.
|
||||
* @exception org.xml.sax.SAXNotRecognizedException When the
|
||||
* XMLReader does not recognize the property name.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the property name but
|
||||
* cannot set the requested value.
|
||||
*/
|
||||
public void setProperty (String name, Object value)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Event handlers.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register an entity resolver.
|
||||
*
|
||||
* <p>If the application does not register an entity resolver,
|
||||
* the XMLReader will perform its own default resolution.</p>
|
||||
*
|
||||
* <p>Applications may register a new or different resolver in the
|
||||
* middle of a parse, and the SAX parser must begin using the new
|
||||
* resolver immediately.</p>
|
||||
*
|
||||
* @param resolver The entity resolver.
|
||||
* @exception java.lang.NullPointerException If the resolver
|
||||
* argument is null.
|
||||
* @see #getEntityResolver
|
||||
*/
|
||||
public void setEntityResolver (EntityResolver resolver);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current entity resolver.
|
||||
*
|
||||
* @return The current entity resolver, or null if none
|
||||
* has been registered.
|
||||
* @see #setEntityResolver
|
||||
*/
|
||||
public EntityResolver getEntityResolver ();
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a DTD event handler.
|
||||
*
|
||||
* <p>If the application does not register a DTD handler, all DTD
|
||||
* events reported by the SAX parser will be silently ignored.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The DTD handler.
|
||||
* @exception java.lang.NullPointerException If the handler
|
||||
* argument is null.
|
||||
* @see #getDTDHandler
|
||||
*/
|
||||
public void setDTDHandler (DTDHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current DTD handler.
|
||||
*
|
||||
* @return The current DTD handler, or null if none
|
||||
* has been registered.
|
||||
* @see #setDTDHandler
|
||||
*/
|
||||
public DTDHandler getDTDHandler ();
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a content event handler.
|
||||
*
|
||||
* <p>If the application does not register a content handler, all
|
||||
* content events reported by the SAX parser will be silently
|
||||
* ignored.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The content handler.
|
||||
* @exception java.lang.NullPointerException If the handler
|
||||
* argument is null.
|
||||
* @see #getContentHandler
|
||||
*/
|
||||
public void setContentHandler (ContentHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current content handler.
|
||||
*
|
||||
* @return The current content handler, or null if none
|
||||
* has been registered.
|
||||
* @see #setContentHandler
|
||||
*/
|
||||
public ContentHandler getContentHandler ();
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register an error event handler.
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The error handler.
|
||||
* @exception java.lang.NullPointerException If the handler
|
||||
* argument is null.
|
||||
* @see #getErrorHandler
|
||||
*/
|
||||
public void setErrorHandler (ErrorHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current error handler.
|
||||
*
|
||||
* @return The current error handler, or null if none
|
||||
* has been registered.
|
||||
* @see #setErrorHandler
|
||||
*/
|
||||
public ErrorHandler getErrorHandler ();
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Parsing.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
* Parse an XML document.
|
||||
*
|
||||
* <p>The application can use this method to instruct the XML
|
||||
* reader to begin parsing an XML document from any valid input
|
||||
* source (a character stream, a byte stream, or a URI).</p>
|
||||
*
|
||||
* <p>Applications may not invoke this method while a parse is in
|
||||
* progress (they should create a new XMLReader instead for each
|
||||
* nested XML document). Once a parse is complete, an
|
||||
* application may reuse the same XMLReader object, possibly with a
|
||||
* different input source.</p>
|
||||
*
|
||||
* <p>During the parse, the XMLReader will provide information
|
||||
* about the XML document through the registered event
|
||||
* handlers.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param source The input source for the top-level of the
|
||||
* XML document.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see org.xml.sax.InputSource
|
||||
* @see #parse(java.lang.String)
|
||||
* @see #setEntityResolver
|
||||
* @see #setDTDHandler
|
||||
* @see #setContentHandler
|
||||
* @see #setErrorHandler
|
||||
*/
|
||||
public void parse (InputSource input)
|
||||
throws IOException, SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Parse an XML document from a system identifier (URI).
|
||||
*
|
||||
* <p>This method is a shortcut for the common case of reading a
|
||||
* document from a system identifier. It is the exact
|
||||
* equivalent of the following:</p>
|
||||
*
|
||||
* <pre>
|
||||
* parse(new InputSource(systemId));
|
||||
* </pre>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be fully resolved
|
||||
* by the application before it is passed to the parser.</p>
|
||||
*
|
||||
* @param systemId The system identifier (URI).
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see #parse(org.xml.sax.InputSource)
|
||||
*/
|
||||
public void parse (String systemId)
|
||||
throws IOException, SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of XMLReader.java
|
||||
// XMLReader.java - read an XML document.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: XMLReader.java,v 1.3.2.5 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
||||
/**
|
||||
* Interface for reading an XML document using callbacks.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p><strong>Note:</strong> despite its name, this interface does
|
||||
* <em>not</em> extend the standard Java {@link java.io.Reader Reader}
|
||||
* interface, because reading XML is a fundamentally different activity
|
||||
* than reading character data.</p>
|
||||
*
|
||||
* <p>XMLReader is the interface that an XML parser's SAX2 driver must
|
||||
* implement. This interface allows an application to set and
|
||||
* query features and properties in the parser, to register
|
||||
* event handlers for document processing, and to initiate
|
||||
* a document parse.</p>
|
||||
*
|
||||
* <p>All SAX interfaces are assumed to be synchronous: the
|
||||
* {@link #parse parse} methods must not return until parsing
|
||||
* is complete, and readers must wait for an event-handler callback
|
||||
* to return before reporting the next event.</p>
|
||||
*
|
||||
* <p>This interface replaces the (now deprecated) SAX 1.0 {@link
|
||||
* org.xml.sax.Parser Parser} interface. The XMLReader interface
|
||||
* contains two important enhancements over the old Parser
|
||||
* interface (as well as some minor ones):</p>
|
||||
*
|
||||
* <ol>
|
||||
* <li>it adds a standard way to query and set features and
|
||||
* properties; and</li>
|
||||
* <li>it adds Namespace support, which is required for many
|
||||
* higher-level XML standards.</li>
|
||||
* </ol>
|
||||
*
|
||||
* <p>There are adapters available to convert a SAX1 Parser to
|
||||
* a SAX2 XMLReader and vice-versa.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.XMLFilter
|
||||
* @see org.xml.sax.helpers.ParserAdapter
|
||||
* @see org.xml.sax.helpers.XMLReaderAdapter
|
||||
*/
|
||||
public interface XMLReader
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Configuration.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Look up the value of a feature flag.
|
||||
*
|
||||
* <p>The feature name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a feature name but
|
||||
* temporarily be unable to return its value.
|
||||
* Some feature values may be available only in specific
|
||||
* contexts, such as before, during, or after a parse.
|
||||
* Also, some feature values may not be programmatically accessible.
|
||||
* (In the case of an adapter for SAX1 {@link Parser}, there is no
|
||||
* implementation-independent way to expose whether the underlying
|
||||
* parser is performing validation, expanding external entities,
|
||||
* and so forth.) </p>
|
||||
*
|
||||
* <p>All XMLReaders are required to recognize the
|
||||
* http://xml.org/sax/features/namespaces and the
|
||||
* http://xml.org/sax/features/namespace-prefixes feature names.</p>
|
||||
*
|
||||
* <p>Typical usage is something like this:</p>
|
||||
*
|
||||
* <pre>
|
||||
* XMLReader r = new MySAXDriver();
|
||||
*
|
||||
* // try to activate validation
|
||||
* try {
|
||||
* r.setFeature("http://xml.org/sax/features/validation", true);
|
||||
* } catch (SAXException e) {
|
||||
* System.err.println("Cannot activate validation.");
|
||||
* }
|
||||
*
|
||||
* // register event handlers
|
||||
* r.setContentHandler(new MyContentHandler());
|
||||
* r.setErrorHandler(new MyErrorHandler());
|
||||
*
|
||||
* // parse the first document
|
||||
* try {
|
||||
* r.parse("http://www.foo.com/mydoc.xml");
|
||||
* } catch (IOException e) {
|
||||
* System.err.println("I/O exception reading XML document");
|
||||
* } catch (SAXException e) {
|
||||
* System.err.println("XML exception reading document.");
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>Implementors are free (and encouraged) to invent their own features,
|
||||
* using names built on their own URIs.</p>
|
||||
*
|
||||
* @param name The feature name, which is a fully-qualified URI.
|
||||
* @return The current value of the feature (true or false).
|
||||
* @exception org.xml.sax.SAXNotRecognizedException If the feature
|
||||
* value can't be assigned or retrieved.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the feature name but
|
||||
* cannot determine its value at this time.
|
||||
* @see #setFeature
|
||||
*/
|
||||
public boolean getFeature (String name)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
/**
|
||||
* Set the value of a feature flag.
|
||||
*
|
||||
* <p>The feature name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to expose a feature value but
|
||||
* to be unable to change the current value.
|
||||
* Some feature values may be immutable or mutable only
|
||||
* in specific contexts, such as before, during, or after
|
||||
* a parse.</p>
|
||||
*
|
||||
* <p>All XMLReaders are required to support setting
|
||||
* http://xml.org/sax/features/namespaces to true and
|
||||
* http://xml.org/sax/features/namespace-prefixes to false.</p>
|
||||
*
|
||||
* @param name The feature name, which is a fully-qualified URI.
|
||||
* @param value The requested value of the feature (true or false).
|
||||
* @exception org.xml.sax.SAXNotRecognizedException If the feature
|
||||
* value can't be assigned or retrieved.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the feature name but
|
||||
* cannot set the requested value.
|
||||
* @see #getFeature
|
||||
*/
|
||||
public void setFeature (String name, boolean value)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
/**
|
||||
* Look up the value of a property.
|
||||
*
|
||||
* <p>The property name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a property name but
|
||||
* temporarily be unable to return its value.
|
||||
* Some property values may be available only in specific
|
||||
* contexts, such as before, during, or after a parse.</p>
|
||||
*
|
||||
* <p>XMLReaders are not required to recognize any specific
|
||||
* property names, though an initial core set is documented for
|
||||
* SAX2.</p>
|
||||
*
|
||||
* <p>Implementors are free (and encouraged) to invent their own properties,
|
||||
* using names built on their own URIs.</p>
|
||||
*
|
||||
* @param name The property name, which is a fully-qualified URI.
|
||||
* @return The current value of the property.
|
||||
* @exception org.xml.sax.SAXNotRecognizedException If the property
|
||||
* value can't be assigned or retrieved.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the property name but
|
||||
* cannot determine its value at this time.
|
||||
* @see #setProperty
|
||||
*/
|
||||
public Object getProperty (String name)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
/**
|
||||
* Set the value of a property.
|
||||
*
|
||||
* <p>The property name is any fully-qualified URI. It is
|
||||
* possible for an XMLReader to recognize a property name but
|
||||
* to be unable to change the current value.
|
||||
* Some property values may be immutable or mutable only
|
||||
* in specific contexts, such as before, during, or after
|
||||
* a parse.</p>
|
||||
*
|
||||
* <p>XMLReaders are not required to recognize setting
|
||||
* any specific property names, though a core set is defined by
|
||||
* SAX2.</p>
|
||||
*
|
||||
* <p>This method is also the standard mechanism for setting
|
||||
* extended handlers.</p>
|
||||
*
|
||||
* @param name The property name, which is a fully-qualified URI.
|
||||
* @param value The requested value for the property.
|
||||
* @exception org.xml.sax.SAXNotRecognizedException If the property
|
||||
* value can't be assigned or retrieved.
|
||||
* @exception org.xml.sax.SAXNotSupportedException When the
|
||||
* XMLReader recognizes the property name but
|
||||
* cannot set the requested value.
|
||||
*/
|
||||
public void setProperty (String name, Object value)
|
||||
throws SAXNotRecognizedException, SAXNotSupportedException;
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Event handlers.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register an entity resolver.
|
||||
*
|
||||
* <p>If the application does not register an entity resolver,
|
||||
* the XMLReader will perform its own default resolution.</p>
|
||||
*
|
||||
* <p>Applications may register a new or different resolver in the
|
||||
* middle of a parse, and the SAX parser must begin using the new
|
||||
* resolver immediately.</p>
|
||||
*
|
||||
* @param resolver The entity resolver.
|
||||
* @see #getEntityResolver
|
||||
*/
|
||||
public void setEntityResolver (EntityResolver resolver);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current entity resolver.
|
||||
*
|
||||
* @return The current entity resolver, or null if none
|
||||
* has been registered.
|
||||
* @see #setEntityResolver
|
||||
*/
|
||||
public EntityResolver getEntityResolver ();
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a DTD event handler.
|
||||
*
|
||||
* <p>If the application does not register a DTD handler, all DTD
|
||||
* events reported by the SAX parser will be silently ignored.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The DTD handler.
|
||||
* @see #getDTDHandler
|
||||
*/
|
||||
public void setDTDHandler (DTDHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current DTD handler.
|
||||
*
|
||||
* @return The current DTD handler, or null if none
|
||||
* has been registered.
|
||||
* @see #setDTDHandler
|
||||
*/
|
||||
public DTDHandler getDTDHandler ();
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register a content event handler.
|
||||
*
|
||||
* <p>If the application does not register a content handler, all
|
||||
* content events reported by the SAX parser will be silently
|
||||
* ignored.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The content handler.
|
||||
* @see #getContentHandler
|
||||
*/
|
||||
public void setContentHandler (ContentHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current content handler.
|
||||
*
|
||||
* @return The current content handler, or null if none
|
||||
* has been registered.
|
||||
* @see #setContentHandler
|
||||
*/
|
||||
public ContentHandler getContentHandler ();
|
||||
|
||||
|
||||
/**
|
||||
* Allow an application to register an error event handler.
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param handler The error handler.
|
||||
* @see #getErrorHandler
|
||||
*/
|
||||
public void setErrorHandler (ErrorHandler handler);
|
||||
|
||||
|
||||
/**
|
||||
* Return the current error handler.
|
||||
*
|
||||
* @return The current error handler, or null if none
|
||||
* has been registered.
|
||||
* @see #setErrorHandler
|
||||
*/
|
||||
public ErrorHandler getErrorHandler ();
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Parsing.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
* Parse an XML document.
|
||||
*
|
||||
* <p>The application can use this method to instruct the XML
|
||||
* reader to begin parsing an XML document from any valid input
|
||||
* source (a character stream, a byte stream, or a URI).</p>
|
||||
*
|
||||
* <p>Applications may not invoke this method while a parse is in
|
||||
* progress (they should create a new XMLReader instead for each
|
||||
* nested XML document). Once a parse is complete, an
|
||||
* application may reuse the same XMLReader object, possibly with a
|
||||
* different input source.</p>
|
||||
*
|
||||
* <p>During the parse, the XMLReader will provide information
|
||||
* about the XML document through the registered event
|
||||
* handlers.</p>
|
||||
*
|
||||
* <p>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.</p>
|
||||
*
|
||||
* @param source The input source for the top-level of the
|
||||
* XML document.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see org.xml.sax.InputSource
|
||||
* @see #parse(java.lang.String)
|
||||
* @see #setEntityResolver
|
||||
* @see #setDTDHandler
|
||||
* @see #setContentHandler
|
||||
* @see #setErrorHandler
|
||||
*/
|
||||
public void parse (InputSource input)
|
||||
throws IOException, SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Parse an XML document from a system identifier (URI).
|
||||
*
|
||||
* <p>This method is a shortcut for the common case of reading a
|
||||
* document from a system identifier. It is the exact
|
||||
* equivalent of the following:</p>
|
||||
*
|
||||
* <pre>
|
||||
* parse(new InputSource(systemId));
|
||||
* </pre>
|
||||
*
|
||||
* <p>If the system identifier is a URL, it must be fully resolved
|
||||
* by the application before it is passed to the parser.</p>
|
||||
*
|
||||
* @param systemId The system identifier (URI).
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @exception java.io.IOException An IO exception from the parser,
|
||||
* possibly from a byte stream or character stream
|
||||
* supplied by the application.
|
||||
* @see #parse(org.xml.sax.InputSource)
|
||||
*/
|
||||
public void parse (String systemId)
|
||||
throws IOException, SAXException;
|
||||
|
||||
}
|
||||
|
@ -1,131 +1,143 @@
|
||||
// DeclHandler.java - Optional handler for DTD declaration events.
|
||||
// Public Domain: no warranty.
|
||||
// $Id: DeclHandler.java,v 1.1 2000/10/02 02:43:19 sboag Exp $
|
||||
|
||||
package org.xml.sax.ext;
|
||||
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* SAX2 extension handler for DTD declaration events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is an optional extension handler for SAX2 to provide
|
||||
* information about DTD declarations in an XML document. XML
|
||||
* readers are not required to support this handler.</p>
|
||||
*
|
||||
* <p>Note that data-related DTD declarations (unparsed entities and
|
||||
* notations) are already reported through the {@link
|
||||
* org.xml.sax.DTDHandler DTDHandler} interface.</p>
|
||||
*
|
||||
* <p>If you are using the declaration handler together with a lexical
|
||||
* handler, all of the events will occur between the
|
||||
* {@link org.xml.sax.ext.LexicalHandler#startDTD startDTD} and the
|
||||
* {@link org.xml.sax.ext.LexicalHandler#endDTD endDTD} events.</p>
|
||||
*
|
||||
* <p>To set the DeclHandler for an XML reader, use the
|
||||
* {@link org.xml.sax.XMLReader#setProperty setProperty} method
|
||||
* with the propertyId "http://xml.org/sax/handlers/DeclHandler".
|
||||
* If the reader does not support declaration events, it will throw a
|
||||
* {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}
|
||||
* or a
|
||||
* {@link org.xml.sax.SAXNotSupportedException SAXNotSupportedException}
|
||||
* when you attempt to register the handler.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0beta
|
||||
* @see org.xml.sax.XMLReader
|
||||
*/
|
||||
public interface DeclHandler
|
||||
{
|
||||
|
||||
/**
|
||||
* Report an element type declaration.
|
||||
*
|
||||
* <p>The content model will consist of the string "EMPTY", the
|
||||
* string "ANY", or a parenthesised group, optionally followed
|
||||
* by an occurrence indicator. The model will be normalized so
|
||||
* that all whitespace is removed,and will include the enclosing
|
||||
* parentheses.</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param model The content model as a normalized string.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
*/
|
||||
public abstract void elementDecl (String name, String model)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report an attribute type declaration.
|
||||
*
|
||||
* <p>Only the effective (first) declaration for an attribute will
|
||||
* be reported. The type will be one of the strings "CDATA",
|
||||
* "ID", "IDREF", "IDREFS", "NMTOKEN", "NMTOKENS", "ENTITY",
|
||||
* "ENTITIES", or "NOTATION", or a parenthesized token group with
|
||||
* the separator "|" and all whitespace removed.</p>
|
||||
*
|
||||
* @param eName The name of the associated element.
|
||||
* @param aName The name of the attribute.
|
||||
* @param type A string representing the attribute type.
|
||||
* @param valueDefault A string representing the attribute default
|
||||
* ("#IMPLIED", "#REQUIRED", or "#FIXED") or null if
|
||||
* none of these applies.
|
||||
* @param value A string representing the attribute's default value,
|
||||
* or null if there is none.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
*/
|
||||
public abstract void attributeDecl (String eName,
|
||||
String aName,
|
||||
String type,
|
||||
String valueDefault,
|
||||
String value)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report an internal entity declaration.
|
||||
*
|
||||
* <p>Only the effective (first) declaration for each entity
|
||||
* will be reported.</p>
|
||||
*
|
||||
* @param name The name of the entity. If it is a parameter
|
||||
* entity, the name will begin with '%'.
|
||||
* @param value The replacement text of the entity.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #externalEntityDecl
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public abstract void internalEntityDecl (String name, String value)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report a parsed external entity declaration.
|
||||
*
|
||||
* <p>Only the effective (first) declaration for each entity
|
||||
* will be reported.</p>
|
||||
*
|
||||
* @param name The name of the entity. If it is a parameter
|
||||
* entity, the name will begin with '%'.
|
||||
* @param publicId The declared public identifier of the entity, or
|
||||
* null if none was declared.
|
||||
* @param systemId The declared system identifier of the entity.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #internalEntityDecl
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public abstract void externalEntityDecl (String name, String publicId,
|
||||
String systemId)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of DeclHandler.java
|
||||
// DeclHandler.java - Optional handler for DTD declaration events.
|
||||
// http://www.saxproject.org
|
||||
// Public Domain: no warranty.
|
||||
// $Id: DeclHandler.java,v 1.2.2.5 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.ext;
|
||||
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* SAX2 extension handler for DTD declaration events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is an optional extension handler for SAX2 to provide more
|
||||
* complete information about DTD declarations in an XML document.
|
||||
* XML readers are not required to recognize this handler, and it
|
||||
* is not part of core-only SAX2 distributions.</p>
|
||||
*
|
||||
* <p>Note that data-related DTD declarations (unparsed entities and
|
||||
* notations) are already reported through the {@link
|
||||
* org.xml.sax.DTDHandler DTDHandler} interface.</p>
|
||||
*
|
||||
* <p>If you are using the declaration handler together with a lexical
|
||||
* handler, all of the events will occur between the
|
||||
* {@link org.xml.sax.ext.LexicalHandler#startDTD startDTD} and the
|
||||
* {@link org.xml.sax.ext.LexicalHandler#endDTD endDTD} events.</p>
|
||||
*
|
||||
* <p>To set the DeclHandler for an XML reader, use the
|
||||
* {@link org.xml.sax.XMLReader#setProperty setProperty} method
|
||||
* with the property name
|
||||
* <code>http://xml.org/sax/properties/declaration-handler</code>
|
||||
* and an object implementing this interface (or null) as the value.
|
||||
* If the reader does not report declaration events, it will throw a
|
||||
* {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}
|
||||
* when you attempt to register the handler.</p>
|
||||
*
|
||||
* @since SAX 2.0 (extensions 1.0)
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
*/
|
||||
public interface DeclHandler
|
||||
{
|
||||
|
||||
/**
|
||||
* Report an element type declaration.
|
||||
*
|
||||
* <p>The content model will consist of the string "EMPTY", the
|
||||
* string "ANY", or a parenthesised group, optionally followed
|
||||
* by an occurrence indicator. The model will be normalized so
|
||||
* that all parameter entities are fully resolved and all whitespace
|
||||
* is removed,and will include the enclosing parentheses. Other
|
||||
* normalization (such as removing redundant parentheses or
|
||||
* simplifying occurrence indicators) is at the discretion of the
|
||||
* parser.</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param model The content model as a normalized string.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
*/
|
||||
public abstract void elementDecl (String name, String model)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report an attribute type declaration.
|
||||
*
|
||||
* <p>Only the effective (first) declaration for an attribute will
|
||||
* be reported. The type will be one of the strings "CDATA",
|
||||
* "ID", "IDREF", "IDREFS", "NMTOKEN", "NMTOKENS", "ENTITY",
|
||||
* "ENTITIES", a parenthesized token group with
|
||||
* the separator "|" and all whitespace removed, or the word
|
||||
* "NOTATION" followed by a space followed by a parenthesized
|
||||
* token group with all whitespace removed.</p>
|
||||
*
|
||||
* <p>The value will be the value as reported to applications,
|
||||
* appropriately normalized and with entity and character
|
||||
* references expanded. </p>
|
||||
*
|
||||
* @param eName The name of the associated element.
|
||||
* @param aName The name of the attribute.
|
||||
* @param type A string representing the attribute type.
|
||||
* @param mode A string representing the attribute defaulting mode
|
||||
* ("#IMPLIED", "#REQUIRED", or "#FIXED") or null if
|
||||
* none of these applies.
|
||||
* @param value A string representing the attribute's default value,
|
||||
* or null if there is none.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
*/
|
||||
public abstract void attributeDecl (String eName,
|
||||
String aName,
|
||||
String type,
|
||||
String mode,
|
||||
String value)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report an internal entity declaration.
|
||||
*
|
||||
* <p>Only the effective (first) declaration for each entity
|
||||
* will be reported. All parameter entities in the value
|
||||
* will be expanded, but general entities will not.</p>
|
||||
*
|
||||
* @param name The name of the entity. If it is a parameter
|
||||
* entity, the name will begin with '%'.
|
||||
* @param value The replacement text of the entity.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #externalEntityDecl
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public abstract void internalEntityDecl (String name, String value)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report a parsed external entity declaration.
|
||||
*
|
||||
* <p>Only the effective (first) declaration for each entity
|
||||
* will be reported.</p>
|
||||
*
|
||||
* @param name The name of the entity. If it is a parameter
|
||||
* entity, the name will begin with '%'.
|
||||
* @param publicId The declared public identifier of the entity, or
|
||||
* null if none was declared.
|
||||
* @param systemId The declared system identifier of the entity.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #internalEntityDecl
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public abstract void externalEntityDecl (String name, String publicId,
|
||||
String systemId)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of DeclHandler.java
|
||||
|
@ -1,161 +1,212 @@
|
||||
// LexicalHandler.java - optional handler for lexical parse events.
|
||||
// Public Domain: no warranty.
|
||||
// $Id: LexicalHandler.java,v 1.1 2000/10/02 02:43:20 sboag Exp $
|
||||
|
||||
package org.xml.sax.ext;
|
||||
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
/**
|
||||
* SAX2 extension handler for lexical events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is an optional extension handler for SAX2 to provide
|
||||
* lexical information about an XML document, such as comments
|
||||
* and CDATA section boundaries; XML readers are not required to
|
||||
* support this handler.</p>
|
||||
*
|
||||
* <p>The events in the lexical handler apply to the entire document,
|
||||
* not just to the document element, and all lexical handler events
|
||||
* must appear between the content handler's startDocument and
|
||||
* endDocument events.</p>
|
||||
*
|
||||
* <p>To set the LexicalHandler for an XML reader, use the
|
||||
* {@link org.xml.sax.XMLReader#setProperty setProperty} method
|
||||
* with the propertyId "http://xml.org/sax/handlers/LexicalHandler".
|
||||
* If the reader does not support lexical events, it will throw a
|
||||
* {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}
|
||||
* or a
|
||||
* {@link org.xml.sax.SAXNotSupportedException SAXNotSupportedException}
|
||||
* when you attempt to register the handler.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0beta
|
||||
* @see org.xml.sax.XMLReader#setProperty
|
||||
* @see org.xml.sax.SAXNotRecognizedException
|
||||
* @see org.xml.sax.SAXNotSupportedException
|
||||
*/
|
||||
public interface LexicalHandler
|
||||
{
|
||||
|
||||
/**
|
||||
* Report the start of DTD declarations, if any.
|
||||
*
|
||||
* <p>Any declarations are assumed to be in the internal subset
|
||||
* unless otherwise indicated by a {@link #startEntity startEntity}
|
||||
* event.</p>
|
||||
*
|
||||
* <p>Note that the start/endDTD events will appear within
|
||||
* the start/endDocument events from ContentHandler and
|
||||
* before the first startElement event.</p>
|
||||
*
|
||||
* @param name The document type name.
|
||||
* @param publicId The declared public identifier for the
|
||||
* external DTD subset, or null if none was declared.
|
||||
* @param systemId The declared system identifier for the
|
||||
* external DTD subset, or null if none was declared.
|
||||
* @exception SAXException The application may raise an
|
||||
* exception.
|
||||
* @see #endDTD
|
||||
* @see #startEntity
|
||||
*/
|
||||
public abstract void startDTD (String name, String publicId,
|
||||
String systemId)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the end of DTD declarations.
|
||||
*
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #startDTD
|
||||
*/
|
||||
public abstract void endDTD ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the beginning of an entity in content.
|
||||
*
|
||||
* <p><strong>NOTE:</entity> entity references in attribute
|
||||
* values -- and the start and end of the document entity --
|
||||
* are never reported.</p>
|
||||
*
|
||||
* <p>The start and end of the external DTD subset are reported
|
||||
* using the pseudo-name "[dtd]". All other events must be
|
||||
* properly nested within start/end entity events.</p>
|
||||
*
|
||||
* <p>Note that skipped entities will be reported through the
|
||||
* {@link org.xml.sax.ContentHandler#skippedEntity skippedEntity}
|
||||
* event, which is part of the ContentHandler interface.</p>
|
||||
*
|
||||
* @param name The name of the entity. If it is a parameter
|
||||
* entity, the name will begin with '%'.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #endEntity
|
||||
* @see org.xml.sax.ext.DeclHandler#internalEntityDecl
|
||||
* @see org.xml.sax.ext.DeclHandler#externalEntityDecl
|
||||
*/
|
||||
public abstract void startEntity (String name)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the end of an entity.
|
||||
*
|
||||
* @param name The name of the entity that is ending.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #startEntity
|
||||
*/
|
||||
public abstract void endEntity (String name)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the start of a CDATA section.
|
||||
*
|
||||
* <p>The contents of the CDATA section will be reported through
|
||||
* the regular {@link org.xml.sax.ContentHandler#characters
|
||||
* characters} event.</p>
|
||||
*
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #endCDATA
|
||||
*/
|
||||
public abstract void startCDATA ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the end of a CDATA section.
|
||||
*
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #startCDATA
|
||||
*/
|
||||
public abstract void endCDATA ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report an XML comment anywhere in the document.
|
||||
*
|
||||
* <p>This callback will be used for comments inside or outside the
|
||||
* document element, including comments in the external DTD
|
||||
* subset (if read).</p>
|
||||
*
|
||||
* @param ch An array holding the characters in the comment.
|
||||
* @param start The starting position in the array.
|
||||
* @param length The number of characters to use from the array.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
*/
|
||||
public abstract void comment (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of LexicalHandler.java
|
||||
// LexicalHandler.java - optional handler for lexical parse events.
|
||||
// http://www.saxproject.org
|
||||
// Public Domain: no warranty.
|
||||
// $Id: LexicalHandler.java,v 1.2.2.4 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.ext;
|
||||
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
/**
|
||||
* SAX2 extension handler for lexical events.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This is an optional extension handler for SAX2 to provide
|
||||
* lexical information about an XML document, such as comments
|
||||
* and CDATA section boundaries.
|
||||
* XML readers are not required to recognize this handler, and it
|
||||
* is not part of core-only SAX2 distributions.</p>
|
||||
*
|
||||
* <p>The events in the lexical handler apply to the entire document,
|
||||
* not just to the document element, and all lexical handler events
|
||||
* must appear between the content handler's startDocument and
|
||||
* endDocument events.</p>
|
||||
*
|
||||
* <p>To set the LexicalHandler for an XML reader, use the
|
||||
* {@link org.xml.sax.XMLReader#setProperty setProperty} method
|
||||
* with the property name
|
||||
* <code>http://xml.org/sax/properties/lexical-handler</code>
|
||||
* and an object implementing this interface (or null) as the value.
|
||||
* If the reader does not report lexical events, it will throw a
|
||||
* {@link org.xml.sax.SAXNotRecognizedException SAXNotRecognizedException}
|
||||
* when you attempt to register the handler.</p>
|
||||
*
|
||||
* @since SAX 2.0 (extensions 1.0)
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
*/
|
||||
public interface LexicalHandler
|
||||
{
|
||||
|
||||
/**
|
||||
* Report the start of DTD declarations, if any.
|
||||
*
|
||||
* <p>This method is intended to report the beginning of the
|
||||
* DOCTYPE declaration; if the document has no DOCTYPE declaration,
|
||||
* this method will not be invoked.</p>
|
||||
*
|
||||
* <p>All declarations reported through
|
||||
* {@link org.xml.sax.DTDHandler DTDHandler} or
|
||||
* {@link org.xml.sax.ext.DeclHandler DeclHandler} events must appear
|
||||
* between the startDTD and {@link #endDTD endDTD} events.
|
||||
* Declarations are assumed to belong to the internal DTD subset
|
||||
* unless they appear between {@link #startEntity startEntity}
|
||||
* and {@link #endEntity endEntity} events. Comments and
|
||||
* processing instructions from the DTD should also be reported
|
||||
* between the startDTD and endDTD events, in their original
|
||||
* order of (logical) occurrence; they are not required to
|
||||
* appear in their correct locations relative to DTDHandler
|
||||
* or DeclHandler events, however.</p>
|
||||
*
|
||||
* <p>Note that the start/endDTD events will appear within
|
||||
* the start/endDocument events from ContentHandler and
|
||||
* before the first
|
||||
* {@link org.xml.sax.ContentHandler#startElement startElement}
|
||||
* event.</p>
|
||||
*
|
||||
* @param name The document type name.
|
||||
* @param publicId The declared public identifier for the
|
||||
* external DTD subset, or null if none was declared.
|
||||
* @param systemId The declared system identifier for the
|
||||
* external DTD subset, or null if none was declared.
|
||||
* (Note that this is not resolved against the document
|
||||
* base URI.)
|
||||
* @exception SAXException The application may raise an
|
||||
* exception.
|
||||
* @see #endDTD
|
||||
* @see #startEntity
|
||||
*/
|
||||
public abstract void startDTD (String name, String publicId,
|
||||
String systemId)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the end of DTD declarations.
|
||||
*
|
||||
* <p>This method is intended to report the end of the
|
||||
* DOCTYPE declaration; if the document has no DOCTYPE declaration,
|
||||
* this method will not be invoked.</p>
|
||||
*
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #startDTD
|
||||
*/
|
||||
public abstract void endDTD ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the beginning of some internal and external XML entities.
|
||||
*
|
||||
* <p>The reporting of parameter entities (including
|
||||
* the external DTD subset) is optional, and SAX2 drivers that
|
||||
* report LexicalHandler events may not implement it; you can use the
|
||||
* <code
|
||||
* >http://xml.org/sax/features/lexical-handler/parameter-entities</code>
|
||||
* feature to query or control the reporting of parameter entities.</p>
|
||||
*
|
||||
* <p>General entities are reported with their regular names,
|
||||
* parameter entities have '%' prepended to their names, and
|
||||
* the external DTD subset has the pseudo-entity name "[dtd]".</p>
|
||||
*
|
||||
* <p>When a SAX2 driver is providing these events, all other
|
||||
* events must be properly nested within start/end entity
|
||||
* events. There is no additional requirement that events from
|
||||
* {@link org.xml.sax.ext.DeclHandler DeclHandler} or
|
||||
* {@link org.xml.sax.DTDHandler DTDHandler} be properly ordered.</p>
|
||||
*
|
||||
* <p>Note that skipped entities will be reported through the
|
||||
* {@link org.xml.sax.ContentHandler#skippedEntity skippedEntity}
|
||||
* event, which is part of the ContentHandler interface.</p>
|
||||
*
|
||||
* <p>Because of the streaming event model that SAX uses, some
|
||||
* entity boundaries cannot be reported under any
|
||||
* circumstances:</p>
|
||||
*
|
||||
* <ul>
|
||||
* <li>general entities within attribute values</li>
|
||||
* <li>parameter entities within declarations</li>
|
||||
* </ul>
|
||||
*
|
||||
* <p>These will be silently expanded, with no indication of where
|
||||
* the original entity boundaries were.</p>
|
||||
*
|
||||
* <p>Note also that the boundaries of character references (which
|
||||
* are not really entities anyway) are not reported.</p>
|
||||
*
|
||||
* <p>All start/endEntity events must be properly nested.
|
||||
*
|
||||
* @param name The name of the entity. If it is a parameter
|
||||
* entity, the name will begin with '%', and if it is the
|
||||
* external DTD subset, it will be "[dtd]".
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #endEntity
|
||||
* @see org.xml.sax.ext.DeclHandler#internalEntityDecl
|
||||
* @see org.xml.sax.ext.DeclHandler#externalEntityDecl
|
||||
*/
|
||||
public abstract void startEntity (String name)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the end of an entity.
|
||||
*
|
||||
* @param name The name of the entity that is ending.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #startEntity
|
||||
*/
|
||||
public abstract void endEntity (String name)
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the start of a CDATA section.
|
||||
*
|
||||
* <p>The contents of the CDATA section will be reported through
|
||||
* the regular {@link org.xml.sax.ContentHandler#characters
|
||||
* characters} event; this event is intended only to report
|
||||
* the boundary.</p>
|
||||
*
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #endCDATA
|
||||
*/
|
||||
public abstract void startCDATA ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report the end of a CDATA section.
|
||||
*
|
||||
* @exception SAXException The application may raise an exception.
|
||||
* @see #startCDATA
|
||||
*/
|
||||
public abstract void endCDATA ()
|
||||
throws SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Report an XML comment anywhere in the document.
|
||||
*
|
||||
* <p>This callback will be used for comments inside or outside the
|
||||
* document element, including comments in the external DTD
|
||||
* subset (if read). Comments in the DTD must be properly
|
||||
* nested inside start/endDTD and start/endEntity events (if
|
||||
* used).</p>
|
||||
*
|
||||
* @param ch An array holding the characters in the comment.
|
||||
* @param start The starting position in the array.
|
||||
* @param length The number of characters to use from the array.
|
||||
* @exception SAXException The application may raise an exception.
|
||||
*/
|
||||
public abstract void comment (char ch[], int start, int length)
|
||||
throws SAXException;
|
||||
|
||||
}
|
||||
|
||||
// end of LexicalHandler.java
|
||||
|
49
libjava/org/xml/sax/ext/package.html
Normal file
49
libjava/org/xml/sax/ext/package.html
Normal file
@ -0,0 +1,49 @@
|
||||
<HTML><HEAD>
|
||||
|
||||
</HEAD><BODY>
|
||||
|
||||
<p>
|
||||
This package contains interfaces to optional SAX2 handlers.
|
||||
|
||||
<p>See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
for more information about SAX.</p>
|
||||
|
||||
<p>
|
||||
The package is independent of the SAX2 core, though the functionality
|
||||
exposed generally needs to be implemented within a parser.
|
||||
That independence has several consequences:</p>
|
||||
|
||||
<ul>
|
||||
|
||||
<li>SAX2 drivers are <em>not</em> required to recognize these handlers,
|
||||
and you cannot assume that the class files will be present in every SAX2
|
||||
installation.</li>
|
||||
|
||||
<li>This package may be updated independently of SAX2 (i.e. new
|
||||
handlers may be added without updating SAX2 itself).</li>
|
||||
|
||||
<li>The handlers are not implemented by the SAX2
|
||||
<code>org.xml.sax.helpers.DefaultHandler</code> or
|
||||
<code>org.xml.sax.helpers.XMLFilterImpl</code> classes.
|
||||
You can subclass these if you need such behaviour.</li>
|
||||
|
||||
<li>The handlers need to be registered differently than regular SAX2
|
||||
handlers.</li>
|
||||
|
||||
</ul>
|
||||
|
||||
<p>This package, SAX2-ext, is a standardized extension to SAX2. It is
|
||||
designed both to allow SAX parsers to pass certain types of information
|
||||
to applications, and to serve as a simple model for other SAX2 parser
|
||||
extension packages. Not all such extension packages should need to
|
||||
be recognized directly by parsers, however.
|
||||
As an example, most schema systems can be cleanly layered on top
|
||||
of parsers supporting the standardized SAX2 interfaces. </p>
|
||||
|
||||
<p><strong>NOTE:</strong> this package alone does add any
|
||||
functionality; it simply provides optional interfaces for SAX2 drivers
|
||||
to use. You must use a SAX2 driver that recognizes these interfaces if
|
||||
you actually want to have access to lexical and declaration
|
||||
information.</p>
|
||||
|
||||
</BODY></HTML>
|
@ -1,310 +1,312 @@
|
||||
// SAX default implementation for AttributeList.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: AttributeListImpl.java,v 1.1 2000/10/02 02:43:20 sboag Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import org.xml.sax.AttributeList;
|
||||
|
||||
import java.util.Vector;
|
||||
|
||||
|
||||
/**
|
||||
* Default implementation for AttributeList.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>AttributeList implements the deprecated SAX1 {@link
|
||||
* org.xml.sax.AttributeList AttributeList} interface, and has been
|
||||
* replaced by the new SAX2 {@link org.xml.sax.helpers.AttributesImpl
|
||||
* AttributesImpl} interface.</p>
|
||||
*
|
||||
* <p>This class provides a convenience implementation of the SAX
|
||||
* {@link org.xml.sax.AttributeList AttributeList} interface. This
|
||||
* implementation is useful both for SAX parser writers, who can use
|
||||
* it to provide attributes to the application, and for SAX application
|
||||
* writers, who can use it to create a persistent copy of an element's
|
||||
* attribute specifications:</p>
|
||||
*
|
||||
* <pre>
|
||||
* private AttributeList myatts;
|
||||
*
|
||||
* public void startElement (String name, AttributeList atts)
|
||||
* {
|
||||
* // create a persistent copy of the attribute list
|
||||
* // for use outside this method
|
||||
* myatts = new AttributeListImpl(atts);
|
||||
* [...]
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>Please note that SAX parsers are not required to use this
|
||||
* class to provide an implementation of AttributeList; it is
|
||||
* supplied only as an optional convenience. In particular,
|
||||
* parser writers are encouraged to invent more efficient
|
||||
* implementations.</p>
|
||||
*
|
||||
* @deprecated This class implements a deprecated interface,
|
||||
* {@link org.xml.sax.AttributeList AttributeList};
|
||||
* that interface has been replaced by
|
||||
* {@link org.xml.sax.Attributes Attributes},
|
||||
* which is implemented in the
|
||||
* {@link org.xml.sax.helpers.AttributesImpl
|
||||
* AttributesImpl} helper class.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.AttributeList
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public class AttributeListImpl implements AttributeList
|
||||
{
|
||||
|
||||
/**
|
||||
* Create an empty attribute list.
|
||||
*
|
||||
* <p>This constructor is most useful for parser writers, who
|
||||
* will use it to create a single, reusable attribute list that
|
||||
* can be reset with the clear method between elements.</p>
|
||||
*
|
||||
* @see #addAttribute
|
||||
* @see #clear
|
||||
*/
|
||||
public AttributeListImpl ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Construct a persistent copy of an existing attribute list.
|
||||
*
|
||||
* <p>This constructor is most useful for application writers,
|
||||
* who will use it to create a persistent copy of an existing
|
||||
* attribute list.</p>
|
||||
*
|
||||
* @param atts The attribute list to copy
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public AttributeListImpl (AttributeList atts)
|
||||
{
|
||||
setAttributeList(atts);
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Methods specific to this class.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Set the attribute list, discarding previous contents.
|
||||
*
|
||||
* <p>This method allows an application writer to reuse an
|
||||
* attribute list easily.</p>
|
||||
*
|
||||
* @param atts The attribute list to copy.
|
||||
*/
|
||||
public void setAttributeList (AttributeList atts)
|
||||
{
|
||||
int count = atts.getLength();
|
||||
|
||||
clear();
|
||||
|
||||
for (int i = 0; i < count; i++) {
|
||||
addAttribute(atts.getName(i), atts.getType(i), atts.getValue(i));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Add an attribute to an attribute list.
|
||||
*
|
||||
* <p>This method is provided for SAX parser writers, to allow them
|
||||
* to build up an attribute list incrementally before delivering
|
||||
* it to the application.</p>
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @param type The attribute type ("NMTOKEN" for an enumeration).
|
||||
* @param value The attribute value (must not be null).
|
||||
* @see #removeAttribute
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public void addAttribute (String name, String type, String value)
|
||||
{
|
||||
names.addElement(name);
|
||||
types.addElement(type);
|
||||
values.addElement(value);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Remove an attribute from the list.
|
||||
*
|
||||
* <p>SAX application writers can use this method to filter an
|
||||
* attribute out of an AttributeList. Note that invoking this
|
||||
* method will change the length of the attribute list and
|
||||
* some of the attribute's indices.</p>
|
||||
*
|
||||
* <p>If the requested attribute is not in the list, this is
|
||||
* a no-op.</p>
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @see #addAttribute
|
||||
*/
|
||||
public void removeAttribute (String name)
|
||||
{
|
||||
int i = names.indexOf(name);
|
||||
|
||||
if (i >= 0) {
|
||||
names.removeElementAt(i);
|
||||
types.removeElementAt(i);
|
||||
values.removeElementAt(i);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Clear the attribute list.
|
||||
*
|
||||
* <p>SAX parser writers can use this method to reset the attribute
|
||||
* list between DocumentHandler.startElement events. Normally,
|
||||
* it will make sense to reuse the same AttributeListImpl object
|
||||
* rather than allocating a new one each time.</p>
|
||||
*
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public void clear ()
|
||||
{
|
||||
names.removeAllElements();
|
||||
types.removeAllElements();
|
||||
values.removeAllElements();
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Implementation of org.xml.sax.AttributeList
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the number of attributes in the list.
|
||||
*
|
||||
* @return The number of attributes in the list.
|
||||
* @see org.xml.sax.AttributeList#getLength
|
||||
*/
|
||||
public int getLength ()
|
||||
{
|
||||
return names.size();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the name of an attribute (by position).
|
||||
*
|
||||
* @param i The position of the attribute in the list.
|
||||
* @return The attribute name as a string, or null if there
|
||||
* is no attribute at that position.
|
||||
* @see org.xml.sax.AttributeList#getName(int)
|
||||
*/
|
||||
public String getName (int i)
|
||||
{
|
||||
if (i < 0) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return (String)names.elementAt(i);
|
||||
} catch (ArrayIndexOutOfBoundsException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the type of an attribute (by position).
|
||||
*
|
||||
* @param i The position of the attribute in the list.
|
||||
* @return The attribute type as a string ("NMTOKEN" for an
|
||||
* enumeration, and "CDATA" if no declaration was
|
||||
* read), or null if there is no attribute at
|
||||
* that position.
|
||||
* @see org.xml.sax.AttributeList#getType(int)
|
||||
*/
|
||||
public String getType (int i)
|
||||
{
|
||||
if (i < 0) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return (String)types.elementAt(i);
|
||||
} catch (ArrayIndexOutOfBoundsException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the value of an attribute (by position).
|
||||
*
|
||||
* @param i The position of the attribute in the list.
|
||||
* @return The attribute value as a string, or null if
|
||||
* there is no attribute at that position.
|
||||
* @see org.xml.sax.AttributeList#getValue(int)
|
||||
*/
|
||||
public String getValue (int i)
|
||||
{
|
||||
if (i < 0) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return (String)values.elementAt(i);
|
||||
} catch (ArrayIndexOutOfBoundsException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the type of an attribute (by name).
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @return The attribute type as a string ("NMTOKEN" for an
|
||||
* enumeration, and "CDATA" if no declaration was
|
||||
* read).
|
||||
* @see org.xml.sax.AttributeList#getType(java.lang.String)
|
||||
*/
|
||||
public String getType (String name)
|
||||
{
|
||||
return getType(names.indexOf(name));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the value of an attribute (by name).
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @see org.xml.sax.AttributeList#getValue(java.lang.String)
|
||||
*/
|
||||
public String getValue (String name)
|
||||
{
|
||||
return getValue(names.indexOf(name));
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
Vector names = new Vector();
|
||||
Vector types = new Vector();
|
||||
Vector values = new Vector();
|
||||
|
||||
}
|
||||
|
||||
// end of AttributeListImpl.java
|
||||
// SAX default implementation for AttributeList.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: AttributeListImpl.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import org.xml.sax.AttributeList;
|
||||
|
||||
import java.util.Vector;
|
||||
|
||||
|
||||
/**
|
||||
* Default implementation for AttributeList.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>AttributeList implements the deprecated SAX1 {@link
|
||||
* org.xml.sax.AttributeList AttributeList} interface, and has been
|
||||
* replaced by the new SAX2 {@link org.xml.sax.helpers.AttributesImpl
|
||||
* AttributesImpl} interface.</p>
|
||||
*
|
||||
* <p>This class provides a convenience implementation of the SAX
|
||||
* {@link org.xml.sax.AttributeList AttributeList} interface. This
|
||||
* implementation is useful both for SAX parser writers, who can use
|
||||
* it to provide attributes to the application, and for SAX application
|
||||
* writers, who can use it to create a persistent copy of an element's
|
||||
* attribute specifications:</p>
|
||||
*
|
||||
* <pre>
|
||||
* private AttributeList myatts;
|
||||
*
|
||||
* public void startElement (String name, AttributeList atts)
|
||||
* {
|
||||
* // create a persistent copy of the attribute list
|
||||
* // for use outside this method
|
||||
* myatts = new AttributeListImpl(atts);
|
||||
* [...]
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>Please note that SAX parsers are not required to use this
|
||||
* class to provide an implementation of AttributeList; it is
|
||||
* supplied only as an optional convenience. In particular,
|
||||
* parser writers are encouraged to invent more efficient
|
||||
* implementations.</p>
|
||||
*
|
||||
* @deprecated This class implements a deprecated interface,
|
||||
* {@link org.xml.sax.AttributeList AttributeList};
|
||||
* that interface has been replaced by
|
||||
* {@link org.xml.sax.Attributes Attributes},
|
||||
* which is implemented in the
|
||||
* {@link org.xml.sax.helpers.AttributesImpl
|
||||
* AttributesImpl} helper class.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.AttributeList
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public class AttributeListImpl implements AttributeList
|
||||
{
|
||||
|
||||
/**
|
||||
* Create an empty attribute list.
|
||||
*
|
||||
* <p>This constructor is most useful for parser writers, who
|
||||
* will use it to create a single, reusable attribute list that
|
||||
* can be reset with the clear method between elements.</p>
|
||||
*
|
||||
* @see #addAttribute
|
||||
* @see #clear
|
||||
*/
|
||||
public AttributeListImpl ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Construct a persistent copy of an existing attribute list.
|
||||
*
|
||||
* <p>This constructor is most useful for application writers,
|
||||
* who will use it to create a persistent copy of an existing
|
||||
* attribute list.</p>
|
||||
*
|
||||
* @param atts The attribute list to copy
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public AttributeListImpl (AttributeList atts)
|
||||
{
|
||||
setAttributeList(atts);
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Methods specific to this class.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Set the attribute list, discarding previous contents.
|
||||
*
|
||||
* <p>This method allows an application writer to reuse an
|
||||
* attribute list easily.</p>
|
||||
*
|
||||
* @param atts The attribute list to copy.
|
||||
*/
|
||||
public void setAttributeList (AttributeList atts)
|
||||
{
|
||||
int count = atts.getLength();
|
||||
|
||||
clear();
|
||||
|
||||
for (int i = 0; i < count; i++) {
|
||||
addAttribute(atts.getName(i), atts.getType(i), atts.getValue(i));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Add an attribute to an attribute list.
|
||||
*
|
||||
* <p>This method is provided for SAX parser writers, to allow them
|
||||
* to build up an attribute list incrementally before delivering
|
||||
* it to the application.</p>
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @param type The attribute type ("NMTOKEN" for an enumeration).
|
||||
* @param value The attribute value (must not be null).
|
||||
* @see #removeAttribute
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public void addAttribute (String name, String type, String value)
|
||||
{
|
||||
names.addElement(name);
|
||||
types.addElement(type);
|
||||
values.addElement(value);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Remove an attribute from the list.
|
||||
*
|
||||
* <p>SAX application writers can use this method to filter an
|
||||
* attribute out of an AttributeList. Note that invoking this
|
||||
* method will change the length of the attribute list and
|
||||
* some of the attribute's indices.</p>
|
||||
*
|
||||
* <p>If the requested attribute is not in the list, this is
|
||||
* a no-op.</p>
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @see #addAttribute
|
||||
*/
|
||||
public void removeAttribute (String name)
|
||||
{
|
||||
int i = names.indexOf(name);
|
||||
|
||||
if (i >= 0) {
|
||||
names.removeElementAt(i);
|
||||
types.removeElementAt(i);
|
||||
values.removeElementAt(i);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Clear the attribute list.
|
||||
*
|
||||
* <p>SAX parser writers can use this method to reset the attribute
|
||||
* list between DocumentHandler.startElement events. Normally,
|
||||
* it will make sense to reuse the same AttributeListImpl object
|
||||
* rather than allocating a new one each time.</p>
|
||||
*
|
||||
* @see org.xml.sax.DocumentHandler#startElement
|
||||
*/
|
||||
public void clear ()
|
||||
{
|
||||
names.removeAllElements();
|
||||
types.removeAllElements();
|
||||
values.removeAllElements();
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Implementation of org.xml.sax.AttributeList
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the number of attributes in the list.
|
||||
*
|
||||
* @return The number of attributes in the list.
|
||||
* @see org.xml.sax.AttributeList#getLength
|
||||
*/
|
||||
public int getLength ()
|
||||
{
|
||||
return names.size();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the name of an attribute (by position).
|
||||
*
|
||||
* @param i The position of the attribute in the list.
|
||||
* @return The attribute name as a string, or null if there
|
||||
* is no attribute at that position.
|
||||
* @see org.xml.sax.AttributeList#getName(int)
|
||||
*/
|
||||
public String getName (int i)
|
||||
{
|
||||
if (i < 0) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return (String)names.elementAt(i);
|
||||
} catch (ArrayIndexOutOfBoundsException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the type of an attribute (by position).
|
||||
*
|
||||
* @param i The position of the attribute in the list.
|
||||
* @return The attribute type as a string ("NMTOKEN" for an
|
||||
* enumeration, and "CDATA" if no declaration was
|
||||
* read), or null if there is no attribute at
|
||||
* that position.
|
||||
* @see org.xml.sax.AttributeList#getType(int)
|
||||
*/
|
||||
public String getType (int i)
|
||||
{
|
||||
if (i < 0) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return (String)types.elementAt(i);
|
||||
} catch (ArrayIndexOutOfBoundsException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the value of an attribute (by position).
|
||||
*
|
||||
* @param i The position of the attribute in the list.
|
||||
* @return The attribute value as a string, or null if
|
||||
* there is no attribute at that position.
|
||||
* @see org.xml.sax.AttributeList#getValue(int)
|
||||
*/
|
||||
public String getValue (int i)
|
||||
{
|
||||
if (i < 0) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
return (String)values.elementAt(i);
|
||||
} catch (ArrayIndexOutOfBoundsException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the type of an attribute (by name).
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @return The attribute type as a string ("NMTOKEN" for an
|
||||
* enumeration, and "CDATA" if no declaration was
|
||||
* read).
|
||||
* @see org.xml.sax.AttributeList#getType(java.lang.String)
|
||||
*/
|
||||
public String getType (String name)
|
||||
{
|
||||
return getType(names.indexOf(name));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the value of an attribute (by name).
|
||||
*
|
||||
* @param name The attribute name.
|
||||
* @see org.xml.sax.AttributeList#getValue(java.lang.String)
|
||||
*/
|
||||
public String getValue (String name)
|
||||
{
|
||||
return getValue(names.indexOf(name));
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
Vector names = new Vector();
|
||||
Vector types = new Vector();
|
||||
Vector values = new Vector();
|
||||
|
||||
}
|
||||
|
||||
// end of AttributeListImpl.java
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,447 +1,468 @@
|
||||
// DefaultHandler.java - default implementation of the core handlers.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the public domain.
|
||||
|
||||
// $Id: DefaultHandler.java,v 1.1 2000/10/02 02:43:20 sboag Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import org.xml.sax.InputSource;
|
||||
import org.xml.sax.Locator;
|
||||
import org.xml.sax.Attributes;
|
||||
import org.xml.sax.EntityResolver;
|
||||
import org.xml.sax.DTDHandler;
|
||||
import org.xml.sax.ContentHandler;
|
||||
import org.xml.sax.ErrorHandler;
|
||||
import org.xml.sax.SAXException;
|
||||
import org.xml.sax.SAXParseException;
|
||||
|
||||
|
||||
/**
|
||||
* Default base class for SAX2 event handlers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class is available as a convenience base class for SAX2
|
||||
* applications: it provides default implementations for all of the
|
||||
* callbacks in the four core SAX2 handler classes:</p>
|
||||
*
|
||||
* <ul>
|
||||
* <li>{@link org.xml.sax.EntityResolver EntityResolver}</li>
|
||||
* <li>{@link org.xml.sax.DTDHandler DTDHandler}</li>
|
||||
* <li>{@link org.xml.sax.ContentHandler ContentHandler}</li>
|
||||
* <li>{@link org.xml.sax.ErrorHandler ErrorHandler}</li>
|
||||
* </ul>
|
||||
*
|
||||
* <p>Application writers can extend this class when they need to
|
||||
* implement only part of an interface; parser writers can
|
||||
* instantiate this class to provide default handlers when the
|
||||
* application has not supplied its own.</p>
|
||||
*
|
||||
* <p>This class replaces the deprecated SAX1
|
||||
* {@link org.xml.sax.HandlerBase HandlerBase} class.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.EntityResolver
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.ContentHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public class DefaultHandler
|
||||
implements EntityResolver, DTDHandler, ContentHandler, ErrorHandler
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the EntityResolver interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
* Resolve an external entity.
|
||||
*
|
||||
* <p>Always return null, so that the parser will use the system
|
||||
* identifier provided in the XML document. This method implements
|
||||
* the SAX default behaviour: application writers can override it
|
||||
* in a subclass to do special translations such as catalog lookups
|
||||
* or URI redirection.</p>
|
||||
*
|
||||
* @param publicId The public identifier, or null if none is
|
||||
* available.
|
||||
* @param systemId The system identifier provided in the XML
|
||||
* document.
|
||||
* @return The new input source, or null to require the
|
||||
* default behaviour.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.EntityResolver#resolveEntity
|
||||
*/
|
||||
public InputSource resolveEntity (String publicId, String systemId)
|
||||
throws SAXException
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of DTDHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a notation declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to keep track of the notations
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The notation name.
|
||||
* @param publicId The notation public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The notation system identifier.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DTDHandler#notationDecl
|
||||
*/
|
||||
public void notationDecl (String name, String publicId, String systemId)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of an unparsed entity declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to keep track of the unparsed entities
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The entity name.
|
||||
* @param publicId The entity public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The entity system identifier.
|
||||
* @param notationName The name of the associated notation.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public void unparsedEntityDecl (String name, String publicId,
|
||||
String systemId, String notationName)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of ContentHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive a Locator object for document events.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to store the locator for use
|
||||
* with other document events.</p>
|
||||
*
|
||||
* @param locator A locator for all SAX document events.
|
||||
* @see org.xml.sax.ContentHandler#setDocumentLocator
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void setDocumentLocator (Locator locator)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the beginning
|
||||
* of a document (such as allocating the root node of a tree or
|
||||
* creating an output file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#startDocument
|
||||
*/
|
||||
public void startDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end
|
||||
* of a document (such as finalising a tree or closing an output
|
||||
* file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#endDocument
|
||||
*/
|
||||
public void endDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the start of a Namespace mapping.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the start of
|
||||
* each Namespace prefix scope (such as storing the prefix mapping).</p>
|
||||
*
|
||||
* @param prefix The Namespace prefix being declared.
|
||||
* @param uri The Namespace URI mapped to the prefix.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#startPrefixMapping
|
||||
*/
|
||||
public void startPrefixMapping (String prefix, String uri)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of a Namespace mapping.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end of
|
||||
* each prefix mapping.</p>
|
||||
*
|
||||
* @param prefix The Namespace prefix being declared.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#endPrefixMapping
|
||||
*/
|
||||
public void endPrefixMapping (String prefix)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the start of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the start of
|
||||
* each element (such as allocating a new tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param attributes The specified or defaulted attributes.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#startElement
|
||||
*/
|
||||
public void startElement (String uri, String localName,
|
||||
String qName, Attributes attributes)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end of
|
||||
* each element (such as finalising a tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param name The element type name.
|
||||
* @param attributes The specified or defaulted attributes.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#endElement
|
||||
*/
|
||||
public void endElement (String uri, String localName, String qName)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data inside an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of character data
|
||||
* (such as adding the data to a node or buffer, or printing it to
|
||||
* a file).</p>
|
||||
*
|
||||
* @param ch The characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#characters
|
||||
*/
|
||||
public void characters (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of ignorable
|
||||
* whitespace (such as adding data to a node or buffer, or printing
|
||||
* it to a file).</p>
|
||||
*
|
||||
* @param ch The whitespace characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#ignorableWhitespace
|
||||
*/
|
||||
public void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions for each
|
||||
* processing instruction, such as setting status variables or
|
||||
* invoking other methods.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none is supplied.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#processingInstruction
|
||||
*/
|
||||
public void processingInstruction (String target, String data)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a skipped entity.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions for each
|
||||
* processing instruction, such as setting status variables or
|
||||
* invoking other methods.</p>
|
||||
*
|
||||
* @param name The name of the skipped entity.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#processingInstruction
|
||||
*/
|
||||
public void skippedEntity (String name)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the ErrorHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a parser warning.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each warning, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void warning (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a recoverable parser error.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each error, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void error (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Report a fatal XML parsing error.
|
||||
*
|
||||
* <p>The default implementation throws a SAXParseException.
|
||||
* Application writers may override this method in a subclass if
|
||||
* they need to take specific actions for each fatal error (such as
|
||||
* collecting all of the errors into a single report): in any case,
|
||||
* the application must stop all regular processing when this
|
||||
* method is invoked, since the document is no longer reliable, and
|
||||
* the parser may no longer report parsing events.</p>
|
||||
*
|
||||
* @param e The error information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#fatalError
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void fatalError (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
throw e;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of DefaultHandler.java
|
||||
// DefaultHandler.java - default implementation of the core handlers.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// NO WARRANTY! This class is in the public domain.
|
||||
|
||||
// $Id: DefaultHandler.java,v 1.5.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import org.xml.sax.InputSource;
|
||||
import org.xml.sax.Locator;
|
||||
import org.xml.sax.Attributes;
|
||||
import org.xml.sax.EntityResolver;
|
||||
import org.xml.sax.DTDHandler;
|
||||
import org.xml.sax.ContentHandler;
|
||||
import org.xml.sax.ErrorHandler;
|
||||
import org.xml.sax.SAXException;
|
||||
import org.xml.sax.SAXParseException;
|
||||
|
||||
|
||||
/**
|
||||
* Default base class for SAX2 event handlers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class is available as a convenience base class for SAX2
|
||||
* applications: it provides default implementations for all of the
|
||||
* callbacks in the four core SAX2 handler classes:</p>
|
||||
*
|
||||
* <ul>
|
||||
* <li>{@link org.xml.sax.EntityResolver EntityResolver}</li>
|
||||
* <li>{@link org.xml.sax.DTDHandler DTDHandler}</li>
|
||||
* <li>{@link org.xml.sax.ContentHandler ContentHandler}</li>
|
||||
* <li>{@link org.xml.sax.ErrorHandler ErrorHandler}</li>
|
||||
* </ul>
|
||||
*
|
||||
* <p>Application writers can extend this class when they need to
|
||||
* implement only part of an interface; parser writers can
|
||||
* instantiate this class to provide default handlers when the
|
||||
* application has not supplied its own.</p>
|
||||
*
|
||||
* <p>This class replaces the deprecated SAX1
|
||||
* {@link org.xml.sax.HandlerBase HandlerBase} class.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.EntityResolver
|
||||
* @see org.xml.sax.DTDHandler
|
||||
* @see org.xml.sax.ContentHandler
|
||||
* @see org.xml.sax.ErrorHandler
|
||||
*/
|
||||
public class DefaultHandler
|
||||
implements EntityResolver, DTDHandler, ContentHandler, ErrorHandler
|
||||
{
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the EntityResolver interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
* Resolve an external entity.
|
||||
*
|
||||
* <p>Always return null, so that the parser will use the system
|
||||
* identifier provided in the XML document. This method implements
|
||||
* the SAX default behaviour: application writers can override it
|
||||
* in a subclass to do special translations such as catalog lookups
|
||||
* or URI redirection.</p>
|
||||
*
|
||||
* @param publicId The public identifer, or null if none is
|
||||
* available.
|
||||
* @param systemId The system identifier provided in the XML
|
||||
* document.
|
||||
* @return The new input source, or null to require the
|
||||
* default behaviour.
|
||||
* @exception java.io.IOException If there is an error setting
|
||||
* up the new input source.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.EntityResolver#resolveEntity
|
||||
*/
|
||||
public InputSource resolveEntity (String publicId, String systemId)
|
||||
throws IOException, SAXException
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of DTDHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a notation declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to keep track of the notations
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The notation name.
|
||||
* @param publicId The notation public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The notation system identifier.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DTDHandler#notationDecl
|
||||
*/
|
||||
public void notationDecl (String name, String publicId, String systemId)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of an unparsed entity declaration.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to keep track of the unparsed entities
|
||||
* declared in a document.</p>
|
||||
*
|
||||
* @param name The entity name.
|
||||
* @param publicId The entity public identifier, or null if not
|
||||
* available.
|
||||
* @param systemId The entity system identifier.
|
||||
* @param notationName The name of the associated notation.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.DTDHandler#unparsedEntityDecl
|
||||
*/
|
||||
public void unparsedEntityDecl (String name, String publicId,
|
||||
String systemId, String notationName)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of ContentHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive a Locator object for document events.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass if they wish to store the locator for use
|
||||
* with other document events.</p>
|
||||
*
|
||||
* @param locator A locator for all SAX document events.
|
||||
* @see org.xml.sax.ContentHandler#setDocumentLocator
|
||||
* @see org.xml.sax.Locator
|
||||
*/
|
||||
public void setDocumentLocator (Locator locator)
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the beginning of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the beginning
|
||||
* of a document (such as allocating the root node of a tree or
|
||||
* creating an output file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#startDocument
|
||||
*/
|
||||
public void startDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of the document.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end
|
||||
* of a document (such as finalising a tree or closing an output
|
||||
* file).</p>
|
||||
*
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#endDocument
|
||||
*/
|
||||
public void endDocument ()
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the start of a Namespace mapping.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the start of
|
||||
* each Namespace prefix scope (such as storing the prefix mapping).</p>
|
||||
*
|
||||
* @param prefix The Namespace prefix being declared.
|
||||
* @param uri The Namespace URI mapped to the prefix.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#startPrefixMapping
|
||||
*/
|
||||
public void startPrefixMapping (String prefix, String uri)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of a Namespace mapping.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end of
|
||||
* each prefix mapping.</p>
|
||||
*
|
||||
* @param prefix The Namespace prefix being declared.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#endPrefixMapping
|
||||
*/
|
||||
public void endPrefixMapping (String prefix)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the start of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the start of
|
||||
* each element (such as allocating a new tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if the
|
||||
* element has no Namespace URI or if Namespace
|
||||
* processing is not being performed.
|
||||
* @param localName The local name (without prefix), or the
|
||||
* empty string if Namespace processing is not being
|
||||
* performed.
|
||||
* @param qName The qualified name (with prefix), or the
|
||||
* empty string if qualified names are not available.
|
||||
* @param atts The attributes attached to the element. If
|
||||
* there are no attributes, it shall be an empty
|
||||
* Attributes object.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#startElement
|
||||
*/
|
||||
public void startElement (String uri, String localName,
|
||||
String qName, Attributes attributes)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of the end of an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions at the end of
|
||||
* each element (such as finalising a tree node or writing
|
||||
* output to a file).</p>
|
||||
*
|
||||
* @param uri The Namespace URI, or the empty string if the
|
||||
* element has no Namespace URI or if Namespace
|
||||
* processing is not being performed.
|
||||
* @param localName The local name (without prefix), or the
|
||||
* empty string if Namespace processing is not being
|
||||
* performed.
|
||||
* @param qName The qualified name (with prefix), or the
|
||||
* empty string if qualified names are not available.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#endElement
|
||||
*/
|
||||
public void endElement (String uri, String localName, String qName)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of character data inside an element.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of character data
|
||||
* (such as adding the data to a node or buffer, or printing it to
|
||||
* a file).</p>
|
||||
*
|
||||
* @param ch The characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#characters
|
||||
*/
|
||||
public void characters (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of ignorable whitespace in element content.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method to take specific actions for each chunk of ignorable
|
||||
* whitespace (such as adding data to a node or buffer, or printing
|
||||
* it to a file).</p>
|
||||
*
|
||||
* @param ch The whitespace characters.
|
||||
* @param start The start position in the character array.
|
||||
* @param length The number of characters to use from the
|
||||
* character array.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#ignorableWhitespace
|
||||
*/
|
||||
public void ignorableWhitespace (char ch[], int start, int length)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a processing instruction.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions for each
|
||||
* processing instruction, such as setting status variables or
|
||||
* invoking other methods.</p>
|
||||
*
|
||||
* @param target The processing instruction target.
|
||||
* @param data The processing instruction data, or null if
|
||||
* none is supplied.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#processingInstruction
|
||||
*/
|
||||
public void processingInstruction (String target, String data)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a skipped entity.
|
||||
*
|
||||
* <p>By default, do nothing. Application writers may override this
|
||||
* method in a subclass to take specific actions for each
|
||||
* processing instruction, such as setting status variables or
|
||||
* invoking other methods.</p>
|
||||
*
|
||||
* @param name The name of the skipped entity.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ContentHandler#processingInstruction
|
||||
*/
|
||||
public void skippedEntity (String name)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Default implementation of the ErrorHandler interface.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a parser warning.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each warning, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void warning (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Receive notification of a recoverable parser error.
|
||||
*
|
||||
* <p>The default implementation does nothing. Application writers
|
||||
* may override this method in a subclass to take specific actions
|
||||
* for each error, such as inserting the message in a log file or
|
||||
* printing it to the console.</p>
|
||||
*
|
||||
* @param e The warning information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#warning
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void error (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
// no op
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Report a fatal XML parsing error.
|
||||
*
|
||||
* <p>The default implementation throws a SAXParseException.
|
||||
* Application writers may override this method in a subclass if
|
||||
* they need to take specific actions for each fatal error (such as
|
||||
* collecting all of the errors into a single report): in any case,
|
||||
* the application must stop all regular processing when this
|
||||
* method is invoked, since the document is no longer reliable, and
|
||||
* the parser may no longer report parsing events.</p>
|
||||
*
|
||||
* @param e The error information encoded as an exception.
|
||||
* @exception org.xml.sax.SAXException Any SAX exception, possibly
|
||||
* wrapping another exception.
|
||||
* @see org.xml.sax.ErrorHandler#fatalError
|
||||
* @see org.xml.sax.SAXParseException
|
||||
*/
|
||||
public void fatalError (SAXParseException e)
|
||||
throws SAXException
|
||||
{
|
||||
throw e;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of DefaultHandler.java
|
||||
|
@ -1,212 +1,214 @@
|
||||
// SAX default implementation for Locator.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: LocatorImpl.java,v 1.1 2000/10/02 02:43:20 sboag Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import org.xml.sax.Locator;
|
||||
|
||||
|
||||
/**
|
||||
* Provide an optional convenience implementation of Locator.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class is available mainly for application writers, who
|
||||
* can use it to make a persistent snapshot of a locator at any
|
||||
* point during a document parse:</p>
|
||||
*
|
||||
* <pre>
|
||||
* Locator locator;
|
||||
* Locator startloc;
|
||||
*
|
||||
* public void setLocator (Locator locator)
|
||||
* {
|
||||
* // note the locator
|
||||
* this.locator = locator;
|
||||
* }
|
||||
*
|
||||
* public void startDocument ()
|
||||
* {
|
||||
* // save the location of the start of the document
|
||||
* // for future use.
|
||||
* Locator startloc = new LocatorImpl(locator);
|
||||
* }
|
||||
*</pre>
|
||||
*
|
||||
* <p>Normally, parser writers will not use this class, since it
|
||||
* is more efficient to provide location information only when
|
||||
* requested, rather than constantly updating a Locator object.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Locator Locator
|
||||
*/
|
||||
public class LocatorImpl implements Locator
|
||||
{
|
||||
|
||||
|
||||
/**
|
||||
* Zero-argument constructor.
|
||||
*
|
||||
* <p>This will not normally be useful, since the main purpose
|
||||
* of this class is to make a snapshot of an existing Locator.</p>
|
||||
*/
|
||||
public LocatorImpl ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Copy constructor.
|
||||
*
|
||||
* <p>Create a persistent copy of the current state of a locator.
|
||||
* When the original locator changes, this copy will still keep
|
||||
* the original values (and it can be used outside the scope of
|
||||
* DocumentHandler methods).</p>
|
||||
*
|
||||
* @param locator The locator to copy.
|
||||
*/
|
||||
public LocatorImpl (Locator locator)
|
||||
{
|
||||
setPublicId(locator.getPublicId());
|
||||
setSystemId(locator.getSystemId());
|
||||
setLineNumber(locator.getLineNumber());
|
||||
setColumnNumber(locator.getColumnNumber());
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Implementation of org.xml.sax.Locator
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved public identifier.
|
||||
*
|
||||
* @return The public identifier as a string, or null if none
|
||||
* is available.
|
||||
* @see org.xml.sax.Locator#getPublicId
|
||||
* @see #setPublicId
|
||||
*/
|
||||
public String getPublicId ()
|
||||
{
|
||||
return publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved system identifier.
|
||||
*
|
||||
* @return The system identifier as a string, or null if none
|
||||
* is available.
|
||||
* @see org.xml.sax.Locator#getSystemId
|
||||
* @see #setSystemId
|
||||
*/
|
||||
public String getSystemId ()
|
||||
{
|
||||
return systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved line number (1-based).
|
||||
*
|
||||
* @return The line number as an integer, or -1 if none is available.
|
||||
* @see org.xml.sax.Locator#getLineNumber
|
||||
* @see #setLineNumber
|
||||
*/
|
||||
public int getLineNumber ()
|
||||
{
|
||||
return lineNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved column number (1-based).
|
||||
*
|
||||
* @return The column number as an integer, or -1 if none is available.
|
||||
* @see org.xml.sax.Locator#getColumnNumber
|
||||
* @see #setColumnNumber
|
||||
*/
|
||||
public int getColumnNumber ()
|
||||
{
|
||||
return columnNumber;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Setters for the properties (not in org.xml.sax.Locator)
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Set the public identifier for this locator.
|
||||
*
|
||||
* @param publicId The new public identifier, or null
|
||||
* if none is available.
|
||||
* @see #getPublicId
|
||||
*/
|
||||
public void setPublicId (String publicId)
|
||||
{
|
||||
this.publicId = publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the system identifier for this locator.
|
||||
*
|
||||
* @param systemId The new system identifier, or null
|
||||
* if none is available.
|
||||
* @see #getSystemId
|
||||
*/
|
||||
public void setSystemId (String systemId)
|
||||
{
|
||||
this.systemId = systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the line number for this locator (1-based).
|
||||
*
|
||||
* @param lineNumber The line number, or -1 if none is available.
|
||||
* @see #getLineNumber
|
||||
*/
|
||||
public void setLineNumber (int lineNumber)
|
||||
{
|
||||
this.lineNumber = lineNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the column number for this locator (1-based).
|
||||
*
|
||||
* @param columnNumber The column number, or -1 if none is available.
|
||||
* @see #getColumnNumber
|
||||
*/
|
||||
public void setColumnNumber (int columnNumber)
|
||||
{
|
||||
this.columnNumber = columnNumber;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
private String publicId;
|
||||
private String systemId;
|
||||
private int lineNumber;
|
||||
private int columnNumber;
|
||||
|
||||
}
|
||||
|
||||
// end of LocatorImpl.java
|
||||
// SAX default implementation for Locator.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: LocatorImpl.java,v 1.3.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import org.xml.sax.Locator;
|
||||
|
||||
|
||||
/**
|
||||
* Provide an optional convenience implementation of Locator.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class is available mainly for application writers, who
|
||||
* can use it to make a persistent snapshot of a locator at any
|
||||
* point during a document parse:</p>
|
||||
*
|
||||
* <pre>
|
||||
* Locator locator;
|
||||
* Locator startloc;
|
||||
*
|
||||
* public void setLocator (Locator locator)
|
||||
* {
|
||||
* // note the locator
|
||||
* this.locator = locator;
|
||||
* }
|
||||
*
|
||||
* public void startDocument ()
|
||||
* {
|
||||
* // save the location of the start of the document
|
||||
* // for future use.
|
||||
* Locator startloc = new LocatorImpl(locator);
|
||||
* }
|
||||
*</pre>
|
||||
*
|
||||
* <p>Normally, parser writers will not use this class, since it
|
||||
* is more efficient to provide location information only when
|
||||
* requested, rather than constantly updating a Locator object.</p>
|
||||
*
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
* @see org.xml.sax.Locator Locator
|
||||
*/
|
||||
public class LocatorImpl implements Locator
|
||||
{
|
||||
|
||||
|
||||
/**
|
||||
* Zero-argument constructor.
|
||||
*
|
||||
* <p>This will not normally be useful, since the main purpose
|
||||
* of this class is to make a snapshot of an existing Locator.</p>
|
||||
*/
|
||||
public LocatorImpl ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Copy constructor.
|
||||
*
|
||||
* <p>Create a persistent copy of the current state of a locator.
|
||||
* When the original locator changes, this copy will still keep
|
||||
* the original values (and it can be used outside the scope of
|
||||
* DocumentHandler methods).</p>
|
||||
*
|
||||
* @param locator The locator to copy.
|
||||
*/
|
||||
public LocatorImpl (Locator locator)
|
||||
{
|
||||
setPublicId(locator.getPublicId());
|
||||
setSystemId(locator.getSystemId());
|
||||
setLineNumber(locator.getLineNumber());
|
||||
setColumnNumber(locator.getColumnNumber());
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Implementation of org.xml.sax.Locator
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved public identifier.
|
||||
*
|
||||
* @return The public identifier as a string, or null if none
|
||||
* is available.
|
||||
* @see org.xml.sax.Locator#getPublicId
|
||||
* @see #setPublicId
|
||||
*/
|
||||
public String getPublicId ()
|
||||
{
|
||||
return publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved system identifier.
|
||||
*
|
||||
* @return The system identifier as a string, or null if none
|
||||
* is available.
|
||||
* @see org.xml.sax.Locator#getSystemId
|
||||
* @see #setSystemId
|
||||
*/
|
||||
public String getSystemId ()
|
||||
{
|
||||
return systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved line number (1-based).
|
||||
*
|
||||
* @return The line number as an integer, or -1 if none is available.
|
||||
* @see org.xml.sax.Locator#getLineNumber
|
||||
* @see #setLineNumber
|
||||
*/
|
||||
public int getLineNumber ()
|
||||
{
|
||||
return lineNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return the saved column number (1-based).
|
||||
*
|
||||
* @return The column number as an integer, or -1 if none is available.
|
||||
* @see org.xml.sax.Locator#getColumnNumber
|
||||
* @see #setColumnNumber
|
||||
*/
|
||||
public int getColumnNumber ()
|
||||
{
|
||||
return columnNumber;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Setters for the properties (not in org.xml.sax.Locator)
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
/**
|
||||
* Set the public identifier for this locator.
|
||||
*
|
||||
* @param publicId The new public identifier, or null
|
||||
* if none is available.
|
||||
* @see #getPublicId
|
||||
*/
|
||||
public void setPublicId (String publicId)
|
||||
{
|
||||
this.publicId = publicId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the system identifier for this locator.
|
||||
*
|
||||
* @param systemId The new system identifier, or null
|
||||
* if none is available.
|
||||
* @see #getSystemId
|
||||
*/
|
||||
public void setSystemId (String systemId)
|
||||
{
|
||||
this.systemId = systemId;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the line number for this locator (1-based).
|
||||
*
|
||||
* @param lineNumber The line number, or -1 if none is available.
|
||||
* @see #getLineNumber
|
||||
*/
|
||||
public void setLineNumber (int lineNumber)
|
||||
{
|
||||
this.lineNumber = lineNumber;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the column number for this locator (1-based).
|
||||
*
|
||||
* @param columnNumber The column number, or -1 if none is available.
|
||||
* @see #getColumnNumber
|
||||
*/
|
||||
public void setColumnNumber (int columnNumber)
|
||||
{
|
||||
this.columnNumber = columnNumber;
|
||||
}
|
||||
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////
|
||||
// Internal state.
|
||||
////////////////////////////////////////////////////////////////////
|
||||
|
||||
private String publicId;
|
||||
private String systemId;
|
||||
private int lineNumber;
|
||||
private int columnNumber;
|
||||
|
||||
}
|
||||
|
||||
// end of LocatorImpl.java
|
||||
|
File diff suppressed because it is too large
Load Diff
80
libjava/org/xml/sax/helpers/NewInstance.java
Normal file
80
libjava/org/xml/sax/helpers/NewInstance.java
Normal file
@ -0,0 +1,80 @@
|
||||
// NewInstance.java - create a new instance of a class by name.
|
||||
// http://www.saxproject.org
|
||||
// Written by Edwin Goei, edwingo@apache.org
|
||||
// and by David Brownell, dbrownell@users.sourceforge.net
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: NewInstance.java,v 1.1.2.4 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import java.lang.reflect.Method;
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
|
||||
/**
|
||||
* Create a new instance of a class by name.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class contains a static method for creating an instance of a
|
||||
* class from an explicit class name. It tries to use the thread's context
|
||||
* ClassLoader if possible and falls back to using
|
||||
* Class.forName(String).</p>
|
||||
*
|
||||
* <p>This code is designed to compile and run on JDK version 1.1 and later
|
||||
* including versions of Java 2.</p>
|
||||
*
|
||||
* @author Edwin Goei, David Brownell
|
||||
* @version 2.0.1 (sax2r2)
|
||||
*/
|
||||
class NewInstance {
|
||||
|
||||
/**
|
||||
* Creates a new instance of the specified class name
|
||||
*
|
||||
* Package private so this code is not exposed at the API level.
|
||||
*/
|
||||
static Object newInstance (ClassLoader classLoader, String className)
|
||||
throws ClassNotFoundException, IllegalAccessException,
|
||||
InstantiationException
|
||||
{
|
||||
Class driverClass;
|
||||
if (classLoader == null) {
|
||||
driverClass = Class.forName(className);
|
||||
} else {
|
||||
driverClass = classLoader.loadClass(className);
|
||||
}
|
||||
return driverClass.newInstance();
|
||||
}
|
||||
|
||||
/**
|
||||
* Figure out which ClassLoader to use. For JDK 1.2 and later use
|
||||
* the context ClassLoader.
|
||||
*/
|
||||
static ClassLoader getClassLoader ()
|
||||
{
|
||||
Method m = null;
|
||||
|
||||
try {
|
||||
m = Thread.class.getMethod("getContextClassLoader", null);
|
||||
} catch (NoSuchMethodException e) {
|
||||
// Assume that we are running JDK 1.1, use the current ClassLoader
|
||||
return NewInstance.class.getClassLoader();
|
||||
}
|
||||
|
||||
try {
|
||||
return (ClassLoader) m.invoke(Thread.currentThread(), null);
|
||||
} catch (IllegalAccessException e) {
|
||||
// assert(false)
|
||||
throw new UnknownError(e.getMessage());
|
||||
} catch (InvocationTargetException e) {
|
||||
// assert(e.getTargetException() instanceof SecurityException)
|
||||
throw new UnknownError(e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -1,129 +1,129 @@
|
||||
// SAX parser factory.
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: ParserFactory.java,v 1.1 2000/10/02 02:43:20 sboag Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import java.lang.ClassNotFoundException;
|
||||
import java.lang.IllegalAccessException;
|
||||
import java.lang.InstantiationException;
|
||||
import java.lang.SecurityException;
|
||||
import java.lang.ClassCastException;
|
||||
|
||||
import org.xml.sax.Parser;
|
||||
|
||||
|
||||
/**
|
||||
* Java-specific class for dynamically loading SAX parsers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p><strong>Note:</strong> This class is designed to work with the now-deprecated
|
||||
* SAX1 {@link org.xml.sax.Parser Parser} class. SAX2 applications should use
|
||||
* {@link org.xml.sax.helpers.XMLReaderFactory XMLReaderFactory} instead.</p>
|
||||
*
|
||||
* <p>ParserFactory is not part of the platform-independent definition
|
||||
* of SAX; it is an additional convenience class designed
|
||||
* specifically for Java XML application writers. SAX applications
|
||||
* can use the static methods in this class to allocate a SAX parser
|
||||
* dynamically at run-time based either on the value of the
|
||||
* `org.xml.sax.parser' system property or on a string containing the class
|
||||
* name.</p>
|
||||
*
|
||||
* <p>Note that the application still requires an XML parser that
|
||||
* implements SAX1.</p>
|
||||
*
|
||||
* @deprecated This class works with the deprecated
|
||||
* {@link org.xml.sax.Parser Parser}
|
||||
* interface.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.Parser
|
||||
* @see java.lang.Class
|
||||
*/
|
||||
public class ParserFactory {
|
||||
|
||||
|
||||
/**
|
||||
* Private null constructor.
|
||||
*/
|
||||
private ParserFactory ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAX parser using the `org.xml.sax.parser' system property.
|
||||
*
|
||||
* <p>The named class must exist and must implement the
|
||||
* {@link org.xml.sax.Parser Parser} interface.</p>
|
||||
*
|
||||
* @exception java.lang.NullPointerException There is no value
|
||||
* for the `org.xml.sax.parser' system property.
|
||||
* @exception java.lang.ClassNotFoundException The SAX parser
|
||||
* class was not found (check your CLASSPATH).
|
||||
* @exception IllegalAccessException The SAX parser class was
|
||||
* found, but you do not have permission to load
|
||||
* it.
|
||||
* @exception InstantiationException The SAX parser class was
|
||||
* found but could not be instantiated.
|
||||
* @exception java.lang.ClassCastException The SAX parser class
|
||||
* was found and instantiated, but does not implement
|
||||
* org.xml.sax.Parser.
|
||||
* @see #makeParser(java.lang.String)
|
||||
* @see org.xml.sax.Parser
|
||||
*/
|
||||
public static Parser makeParser ()
|
||||
throws ClassNotFoundException,
|
||||
IllegalAccessException,
|
||||
InstantiationException,
|
||||
NullPointerException,
|
||||
ClassCastException
|
||||
{
|
||||
String className = System.getProperty("org.xml.sax.parser");
|
||||
if (className == null) {
|
||||
throw new NullPointerException("No value for sax.parser property");
|
||||
} else {
|
||||
return makeParser(className);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAX parser object using the class name provided.
|
||||
*
|
||||
* <p>The named class must exist and must implement the
|
||||
* {@link org.xml.sax.Parser Parser} interface.</p>
|
||||
*
|
||||
* @param className A string containing the name of the
|
||||
* SAX parser class.
|
||||
* @exception java.lang.ClassNotFoundException The SAX parser
|
||||
* class was not found (check your CLASSPATH).
|
||||
* @exception IllegalAccessException The SAX parser class was
|
||||
* found, but you do not have permission to load
|
||||
* it.
|
||||
* @exception InstantiationException The SAX parser class was
|
||||
* found but could not be instantiated.
|
||||
* @exception java.lang.ClassCastException The SAX parser class
|
||||
* was found and instantiated, but does not implement
|
||||
* org.xml.sax.Parser.
|
||||
* @see #makeParser()
|
||||
* @see org.xml.sax.Parser
|
||||
*/
|
||||
public static Parser makeParser (String className)
|
||||
throws ClassNotFoundException,
|
||||
IllegalAccessException,
|
||||
InstantiationException,
|
||||
ClassCastException
|
||||
{
|
||||
return (Parser)(Class.forName(className).newInstance());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of ParserFactory.java
|
||||
// SAX parser factory.
|
||||
// http://www.saxproject.org
|
||||
// No warranty; no copyright -- use this as you will.
|
||||
// $Id: ParserFactory.java,v 1.4.2.3 2002/01/29 21:34:14 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
|
||||
import java.lang.ClassNotFoundException;
|
||||
import java.lang.IllegalAccessException;
|
||||
import java.lang.InstantiationException;
|
||||
import java.lang.SecurityException;
|
||||
import java.lang.ClassCastException;
|
||||
|
||||
import org.xml.sax.Parser;
|
||||
|
||||
|
||||
/**
|
||||
* Java-specific class for dynamically loading SAX parsers.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p><strong>Note:</strong> This class is designed to work with the now-deprecated
|
||||
* SAX1 {@link org.xml.sax.Parser Parser} class. SAX2 applications should use
|
||||
* {@link org.xml.sax.helpers.XMLReaderFactory XMLReaderFactory} instead.</p>
|
||||
*
|
||||
* <p>ParserFactory is not part of the platform-independent definition
|
||||
* of SAX; it is an additional convenience class designed
|
||||
* specifically for Java XML application writers. SAX applications
|
||||
* can use the static methods in this class to allocate a SAX parser
|
||||
* dynamically at run-time based either on the value of the
|
||||
* `org.xml.sax.parser' system property or on a string containing the class
|
||||
* name.</p>
|
||||
*
|
||||
* <p>Note that the application still requires an XML parser that
|
||||
* implements SAX1.</p>
|
||||
*
|
||||
* @deprecated This class works with the deprecated
|
||||
* {@link org.xml.sax.Parser Parser}
|
||||
* interface.
|
||||
* @since SAX 1.0
|
||||
* @author David Megginson
|
||||
* @version 2.0.1 (sax2r2)
|
||||
*/
|
||||
public class ParserFactory {
|
||||
|
||||
|
||||
/**
|
||||
* Private null constructor.
|
||||
*/
|
||||
private ParserFactory ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAX parser using the `org.xml.sax.parser' system property.
|
||||
*
|
||||
* <p>The named class must exist and must implement the
|
||||
* {@link org.xml.sax.Parser Parser} interface.</p>
|
||||
*
|
||||
* @exception java.lang.NullPointerException There is no value
|
||||
* for the `org.xml.sax.parser' system property.
|
||||
* @exception java.lang.ClassNotFoundException The SAX parser
|
||||
* class was not found (check your CLASSPATH).
|
||||
* @exception IllegalAccessException The SAX parser class was
|
||||
* found, but you do not have permission to load
|
||||
* it.
|
||||
* @exception InstantiationException The SAX parser class was
|
||||
* found but could not be instantiated.
|
||||
* @exception java.lang.ClassCastException The SAX parser class
|
||||
* was found and instantiated, but does not implement
|
||||
* org.xml.sax.Parser.
|
||||
* @see #makeParser(java.lang.String)
|
||||
* @see org.xml.sax.Parser
|
||||
*/
|
||||
public static Parser makeParser ()
|
||||
throws ClassNotFoundException,
|
||||
IllegalAccessException,
|
||||
InstantiationException,
|
||||
NullPointerException,
|
||||
ClassCastException
|
||||
{
|
||||
String className = System.getProperty("org.xml.sax.parser");
|
||||
if (className == null) {
|
||||
throw new NullPointerException("No value for sax.parser property");
|
||||
} else {
|
||||
return makeParser(className);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new SAX parser object using the class name provided.
|
||||
*
|
||||
* <p>The named class must exist and must implement the
|
||||
* {@link org.xml.sax.Parser Parser} interface.</p>
|
||||
*
|
||||
* @param className A string containing the name of the
|
||||
* SAX parser class.
|
||||
* @exception java.lang.ClassNotFoundException The SAX parser
|
||||
* class was not found (check your CLASSPATH).
|
||||
* @exception IllegalAccessException The SAX parser class was
|
||||
* found, but you do not have permission to load
|
||||
* it.
|
||||
* @exception InstantiationException The SAX parser class was
|
||||
* found but could not be instantiated.
|
||||
* @exception java.lang.ClassCastException The SAX parser class
|
||||
* was found and instantiated, but does not implement
|
||||
* org.xml.sax.Parser.
|
||||
* @see #makeParser()
|
||||
* @see org.xml.sax.Parser
|
||||
*/
|
||||
public static Parser makeParser (String className)
|
||||
throws ClassNotFoundException,
|
||||
IllegalAccessException,
|
||||
InstantiationException,
|
||||
ClassCastException
|
||||
{
|
||||
return (Parser) NewInstance.newInstance (
|
||||
NewInstance.getClassLoader (), className);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,136 +1,203 @@
|
||||
// XMLReaderFactory.java - factory for creating a new reader.
|
||||
// Written by David Megginson, sax@megginson.com
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: XMLReaderFactory.java,v 1.1 2000/10/02 02:43:20 sboag Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
import org.xml.sax.Parser;
|
||||
import org.xml.sax.XMLReader;
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Factory for creating an XML reader.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class contains static methods for creating an XML reader
|
||||
* from an explicit class name, or for creating an XML reader based
|
||||
* on the value of the <code>org.xml.sax.driver</code> system
|
||||
* property:</p>
|
||||
*
|
||||
* <pre>
|
||||
* try {
|
||||
* XMLReader myReader = XMLReaderFactory.createXMLReader();
|
||||
* } catch (SAXException e) {
|
||||
* System.err.println(e.getMessage());
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p>Note that these methods will not be usable in environments where
|
||||
* system properties are not accessible or where the application or
|
||||
* applet is not permitted to load classes dynamically.</p>
|
||||
*
|
||||
* <p><strong>Note to implementors:</strong> SAX implementations in specialized
|
||||
* environments may replace this class with a different one optimized for the
|
||||
* environment, as long as its method signatures remain the same.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson,
|
||||
* <a href="mailto:sax@megginson.com">sax@megginson.com</a>
|
||||
* @version 2.0
|
||||
* @see org.xml.sax.XMLReader
|
||||
*/
|
||||
final public class XMLReaderFactory
|
||||
{
|
||||
|
||||
/**
|
||||
* Private constructor.
|
||||
*
|
||||
* <p>This constructor prevents the class from being instantiated.</p>
|
||||
*/
|
||||
private XMLReaderFactory ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Attempt to create an XML reader from a system property.
|
||||
*
|
||||
* <p>This method uses the value of the system property
|
||||
* "org.xml.sax.driver" as the full name of a Java class
|
||||
* and tries to instantiate that class as a SAX2
|
||||
* XMLReader.</p>
|
||||
*
|
||||
* <p>Note that many Java interpreters allow system properties
|
||||
* to be specified on the command line.</p>
|
||||
*
|
||||
* @return A new XMLReader.
|
||||
* @exception org.xml.sax.SAXException If the value of the
|
||||
* "org.xml.sax.driver" system property is null,
|
||||
* or if the class cannot be loaded and instantiated.
|
||||
* @see #createXMLReader(java.lang.String)
|
||||
*/
|
||||
public static XMLReader createXMLReader ()
|
||||
throws SAXException
|
||||
{
|
||||
String className = System.getProperty("org.xml.sax.driver");
|
||||
if (className == null) {
|
||||
Parser parser;
|
||||
try {
|
||||
parser = ParserFactory.makeParser();
|
||||
} catch (Exception e) {
|
||||
parser = null;
|
||||
}
|
||||
if (parser == null) {
|
||||
throw new
|
||||
SAXException("System property org.xml.sax.driver not specified");
|
||||
} else {
|
||||
return new ParserAdapter(parser);
|
||||
}
|
||||
} else {
|
||||
return createXMLReader(className);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Attempt to create an XML reader from a class name.
|
||||
*
|
||||
* <p>Given a class name, this method attempts to load
|
||||
* and instantiate the class as an XML reader.</p>
|
||||
*
|
||||
* @return A new XML reader.
|
||||
* @exception org.xml.sax.SAXException If the class cannot be
|
||||
* loaded, instantiated, and cast to XMLReader.
|
||||
* @see #createXMLReader()
|
||||
*/
|
||||
public static XMLReader createXMLReader (String className)
|
||||
throws SAXException
|
||||
{
|
||||
try {
|
||||
return (XMLReader)(Class.forName(className).newInstance());
|
||||
} catch (ClassNotFoundException e1) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" not found", e1);
|
||||
} catch (IllegalAccessException e2) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" found but cannot be loaded", e2);
|
||||
} catch (InstantiationException e3) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" loaded but cannot be instantiated (no empty public constructor?)",
|
||||
e3);
|
||||
} catch (ClassCastException e4) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" does not implement XMLReader", e4);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// end of XMLReaderFactory.java
|
||||
// XMLReaderFactory.java - factory for creating a new reader.
|
||||
// http://www.saxproject.org
|
||||
// Written by David Megginson
|
||||
// and by David Brownell
|
||||
// NO WARRANTY! This class is in the Public Domain.
|
||||
|
||||
// $Id: XMLReaderFactory.java,v 1.5.2.4 2002/01/29 21:34:15 dbrownell Exp $
|
||||
|
||||
package org.xml.sax.helpers;
|
||||
import java.io.BufferedReader;
|
||||
import java.io.InputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import org.xml.sax.XMLReader;
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
|
||||
/**
|
||||
* Factory for creating an XML reader.
|
||||
*
|
||||
* <blockquote>
|
||||
* <em>This module, both source code and documentation, is in the
|
||||
* Public Domain, and comes with <strong>NO WARRANTY</strong>.</em>
|
||||
* See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
* for further information.
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>This class contains static methods for creating an XML reader
|
||||
* from an explicit class name, or based on runtime defaults:</p>
|
||||
*
|
||||
* <pre>
|
||||
* try {
|
||||
* XMLReader myReader = XMLReaderFactory.createXMLReader();
|
||||
* } catch (SAXException e) {
|
||||
* System.err.println(e.getMessage());
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
* <p><strong>Note to Distributions bundled with parsers:</strong>
|
||||
* You should modify the implementation of the no-arguments
|
||||
* <em>createXMLReader</em> to handle cases where the external
|
||||
* configuration mechanisms aren't set up. That method should do its
|
||||
* best to return a parser when one is in the class path, even when
|
||||
* nothing bound its class name to <code>org.xml.sax.driver</code> so
|
||||
* those configuration mechanisms would see it.</p>
|
||||
*
|
||||
* @since SAX 2.0
|
||||
* @author David Megginson, David Brownell
|
||||
* @version 2.0.1 (sax2r2)
|
||||
*/
|
||||
final public class XMLReaderFactory
|
||||
{
|
||||
/**
|
||||
* Private constructor.
|
||||
*
|
||||
* <p>This constructor prevents the class from being instantiated.</p>
|
||||
*/
|
||||
private XMLReaderFactory ()
|
||||
{
|
||||
}
|
||||
|
||||
private static final String property = "org.xml.sax.driver";
|
||||
|
||||
/**
|
||||
* Attempt to create an XMLReader from system defaults.
|
||||
* In environments which can support it, the name of the XMLReader
|
||||
* class is determined by trying each these options in order, and
|
||||
* using the first one which succeeds:</p> <ul>
|
||||
*
|
||||
* <li>If the system property <code>org.xml.sax.driver</code>
|
||||
* has a value, that is used as an XMLReader class name. </li>
|
||||
*
|
||||
* <li>The JAR "Services API" is used to look for a class name
|
||||
* in the <em>META-INF/services/org.xml.sax.driver</em> file in
|
||||
* jarfiles available to the runtime.</li>
|
||||
*
|
||||
* <li> SAX parser distributions are strongly encouraged to provide
|
||||
* a default XMLReader class name that will take effect only when
|
||||
* previous options (on this list) are not successful.</li>
|
||||
*
|
||||
* <li>Finally, if {@link ParserFactory#makeParser()} can
|
||||
* return a system default SAX1 parser, that parser is wrapped in
|
||||
* a {@link ParserAdapter}. (This is a migration aid for SAX1
|
||||
* environments, where the <code>org.xml.sax.parser</code> system
|
||||
* property will often be usable.) </li>
|
||||
*
|
||||
* </ul>
|
||||
*
|
||||
* <p> In environments such as small embedded systems, which can not
|
||||
* support that flexibility, other mechanisms to determine the default
|
||||
* may be used. </p>
|
||||
*
|
||||
* <p>Note that many Java environments allow system properties to be
|
||||
* initialized on a command line. This means that <em>in most cases</em>
|
||||
* setting a good value for that property ensures that calls to this
|
||||
* method will succeed, except when security policies intervene.
|
||||
* This will also maximize application portability to older SAX
|
||||
* environments, with less robust implementations of this method.
|
||||
* </p>
|
||||
*
|
||||
* @return A new XMLReader.
|
||||
* @exception org.xml.sax.SAXException If no default XMLReader class
|
||||
* can be identified and instantiated.
|
||||
* @see #createXMLReader(java.lang.String)
|
||||
*/
|
||||
public static XMLReader createXMLReader ()
|
||||
throws SAXException
|
||||
{
|
||||
String className = null;
|
||||
ClassLoader loader = NewInstance.getClassLoader ();
|
||||
|
||||
// 1. try the JVM-instance-wide system property
|
||||
try { className = System.getProperty (property); }
|
||||
catch (Exception e) { /* normally fails for applets */ }
|
||||
|
||||
// 2. if that fails, try META-INF/services/
|
||||
if (className == null) {
|
||||
try {
|
||||
String service = "META-INF/services/" + property;
|
||||
InputStream in;
|
||||
BufferedReader reader;
|
||||
|
||||
if (loader == null)
|
||||
in = ClassLoader.getSystemResourceAsStream (service);
|
||||
else
|
||||
in = loader.getResourceAsStream (service);
|
||||
|
||||
if (in != null) {
|
||||
reader = new BufferedReader (
|
||||
new InputStreamReader (in, "UTF8"));
|
||||
className = reader.readLine ();
|
||||
in.close ();
|
||||
}
|
||||
} catch (Exception e) {
|
||||
}
|
||||
}
|
||||
|
||||
// 3. Distro-specific fallback
|
||||
if (className == null) {
|
||||
// BEGIN DISTRIBUTION-SPECIFIC
|
||||
|
||||
// EXAMPLE:
|
||||
// className = "com.example.sax.XmlReader";
|
||||
// or a $JAVA_HOME/jre/lib/*properties setting...
|
||||
|
||||
// END DISTRIBUTION-SPECIFIC
|
||||
}
|
||||
|
||||
// do we know the XMLReader implementation class yet?
|
||||
if (className != null)
|
||||
return loadClass (loader, className);
|
||||
|
||||
// 4. panic -- adapt any SAX1 parser
|
||||
try {
|
||||
return new ParserAdapter (ParserFactory.makeParser ());
|
||||
} catch (Exception e) {
|
||||
throw new SAXException ("Can't create default XMLReader; "
|
||||
+ "is system property org.xml.sax.driver set?");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Attempt to create an XML reader from a class name.
|
||||
*
|
||||
* <p>Given a class name, this method attempts to load
|
||||
* and instantiate the class as an XML reader.</p>
|
||||
*
|
||||
* <p>Note that this method will not be usable in environments where
|
||||
* the caller (perhaps an applet) is not permitted to load classes
|
||||
* dynamically.</p>
|
||||
*
|
||||
* @return A new XML reader.
|
||||
* @exception org.xml.sax.SAXException If the class cannot be
|
||||
* loaded, instantiated, and cast to XMLReader.
|
||||
* @see #createXMLReader()
|
||||
*/
|
||||
public static XMLReader createXMLReader (String className)
|
||||
throws SAXException
|
||||
{
|
||||
return loadClass (NewInstance.getClassLoader (), className);
|
||||
}
|
||||
|
||||
private static XMLReader loadClass (ClassLoader loader, String className)
|
||||
throws SAXException
|
||||
{
|
||||
try {
|
||||
return (XMLReader) NewInstance.newInstance (loader, className);
|
||||
} catch (ClassNotFoundException e1) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" not found", e1);
|
||||
} catch (IllegalAccessException e2) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" found but cannot be loaded", e2);
|
||||
} catch (InstantiationException e3) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" loaded but cannot be instantiated (no empty public constructor?)",
|
||||
e3);
|
||||
} catch (ClassCastException e4) {
|
||||
throw new SAXException("SAX2 driver class " + className +
|
||||
" does not implement XMLReader", e4);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
13
libjava/org/xml/sax/helpers/package.html
Normal file
13
libjava/org/xml/sax/helpers/package.html
Normal file
@ -0,0 +1,13 @@
|
||||
<HTML><HEAD>
|
||||
|
||||
<!-- $Id: package.html,v 1.3.2.1 2001/11/09 20:32:58 dbrownell Exp $ -->
|
||||
|
||||
</HEAD><BODY>
|
||||
|
||||
<p>This package contains "helper" classes, including
|
||||
support for bootstrapping SAX-based applications.
|
||||
|
||||
<p>See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
for more information about SAX.</p>
|
||||
|
||||
</BODY></HTML>
|
164
libjava/org/xml/sax/package.html
Normal file
164
libjava/org/xml/sax/package.html
Normal file
@ -0,0 +1,164 @@
|
||||
<html><head>
|
||||
|
||||
<!-- $Id: package.html,v 1.2.2.2 2002/01/12 21:42:21 dbrownell Exp $ -->
|
||||
|
||||
</head><body>
|
||||
|
||||
<p> This package provides the core SAX APIs.
|
||||
Some SAX1 APIs are deprecated to encourage integration of
|
||||
namespace-awareness into designs of new applications
|
||||
and into maintainance of existing infrastructure. </p>
|
||||
|
||||
<p>See <a href='http://www.saxproject.org'>http://www.saxproject.org</a>
|
||||
for more information about SAX.</p>
|
||||
|
||||
|
||||
<h2> SAX2 Standard Feature Flags </h2>
|
||||
|
||||
<p> One of the essential characteristics of SAX2 is that it added
|
||||
feature flags which can be used to examine and perhaps modify
|
||||
parser modes, in particular modes such as validation.
|
||||
Since features are identified by (absolute) URIs, anyone
|
||||
can define such features.
|
||||
Currently defined standard feature URIs have the prefix
|
||||
<code>http://xml.org/sax/features/</code> before an identifier such as
|
||||
<code>validation</code>. Turn features on or off using
|
||||
<em>setFeature</em>. Those standard identifiers are: </p>
|
||||
|
||||
|
||||
<table border="1" cellpadding="3" cellspacing="0" width="100%">
|
||||
<tr align="center" bgcolor="#ccccff">
|
||||
<th>Feature ID</th>
|
||||
<th>Default</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>external-general-entities</td>
|
||||
<td><em>unspecified</em></td>
|
||||
<td> Reports whether this parser processes external
|
||||
general entities; always true if validating</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>external-parameter-entities</td>
|
||||
<td><em>unspecified</em></td>
|
||||
<td> Reports whether this parser processes external
|
||||
parameter entities; always true if validating</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>lexical-handler/parameter-entities</td>
|
||||
<td><em>unspecified</em></td>
|
||||
<td> true indicates that the LexicalHandler will report the
|
||||
beginning and end of parameter entities
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>namespaces</td>
|
||||
<td>true</td>
|
||||
<td> true indicates namespace URIs and unprefixed local names
|
||||
for element and attribute names will be available </td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>namespace-prefixes</td>
|
||||
<td>false</td>
|
||||
<td> true indicates XML 1.0 names (with prefixes) and attributes
|
||||
(including <em>xmlns*</em> attributes) will be available </td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>string-interning</td>
|
||||
<td><em>unspecified</em></td>
|
||||
<td> true if all XML names (for elements, prefixes, attributes,
|
||||
entities, notations, and local names),
|
||||
as well as Namespace URIs, will have been interned
|
||||
using <em>java.lang.String.intern</em>. This supports fast
|
||||
testing of equality/inequality against string constants.</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>validation</td>
|
||||
<td><em>unspecified</em></td>
|
||||
<td> controls whether the parser is reporting all validity
|
||||
errors; if true, all external entities will be read. </td>
|
||||
</tr>
|
||||
|
||||
</table>
|
||||
|
||||
<p> Support for the default values of the
|
||||
<em>namespaces</em> and <em>namespace-prefixes</em>
|
||||
properties is required.
|
||||
</p>
|
||||
|
||||
<p> For default values not specified by SAX2,
|
||||
each XMLReader implementation specifies its default,
|
||||
or may choose not to expose the feature flag.
|
||||
Unless otherwise specified here,
|
||||
implementations may support changing current values
|
||||
of these standard feature flags, but not while parsing.
|
||||
</p>
|
||||
|
||||
<h2> SAX2 Standard Handler and Property IDs </h2>
|
||||
|
||||
<p> For parser interface characteristics that are described
|
||||
as objects, a separate namespace is defined. The
|
||||
objects in this namespace are again identified by URI, and
|
||||
the standard property URIs have the prefix
|
||||
<code>http://xml.org/sax/properties/</code> before an identifier such as
|
||||
<code>lexical-handler</code> or
|
||||
<code>dom-node</code>. Manage those properties using
|
||||
<em>setProperty()</em>. Those identifiers are: </p>
|
||||
|
||||
<table border="1" cellpadding="3" cellspacing="0" width="100%">
|
||||
<tr align="center" bgcolor="#ccccff">
|
||||
<th>Property ID</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>declaration-handler</td>
|
||||
<td> Used to see most DTD declarations except those treated
|
||||
as lexical ("document element name is ...") or which are
|
||||
mandatory for all SAX parsers (<em>DTDHandler</em>).
|
||||
The Object must implement <a href="ext/DeclHandler.html"
|
||||
><em>org.xml.sax.ext.DeclHandler</em></a>.
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>dom-node</td>
|
||||
<td> For "DOM Walker" style parsers, which ignore their
|
||||
<em>parser.parse()</em> parameters, this is used to
|
||||
specify the DOM (sub)tree being walked by the parser.
|
||||
The Object must implement the
|
||||
<em>org.w3c.dom.Node</em> interface.
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>lexical-handler</td>
|
||||
<td> Used to see some syntax events that are essential in some
|
||||
applications: comments, CDATA delimeters, selected general
|
||||
entity inclusions, and the start and end of the DTD
|
||||
(and declaration of document element name).
|
||||
The Object must implement <a href="ext/LexicalHandler.html"
|
||||
><em>org.xml.sax.ext.LexicalHandler</em></a>.
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td>xml-string</td>
|
||||
<td> Readable only during a parser callback, this exposes a <b>TBS</b>
|
||||
chunk of characters responsible for the current event. </td>
|
||||
</tr>
|
||||
|
||||
</table>
|
||||
|
||||
<p> All of these standard properties are optional;
|
||||
XMLReader implementations need not support them.
|
||||
</p>
|
||||
|
||||
</body></html>
|
Loading…
x
Reference in New Issue
Block a user