org.xml.sax.ext

Class Attributes2Impl

Implemented Interfaces:
Attributes, Attributes2

public class Attributes2Impl
extends AttributesImpl
implements Attributes2

SAX2 extension helper for additional Attributes information, implementing the Attributes2 interface.
This module, both source code and documentation, is in the Public Domain, and comes with NO WARRANTY.

This is not part of core-only SAX2 distributions.

The specified flag for each attribute will always be true, unless it has been set to false in the copy constructor or using setSpecified(int,boolean). Similarly, the declared flag for each attribute will always be false, except for defaulted attributes (specified is false), non-CDATA attributes, or when it is set to true using setDeclared(int,boolean). If you change an attribute's type by hand, you may need to modify its declared flag to match.

Since:
SAX 2.0 (extensions 1.1 alpha)

Constructor Summary

Attributes2Impl()
Construct a new, empty Attributes2Impl object.
Attributes2Impl(Attributes atts)
Copy an existing Attributes or Attributes2 object.

Method Summary

void
addAttribute(String uri, String localName, String qName, String type, String value)
Add an attribute to the end of the list, setting its "specified" flag to true.
boolean
isDeclared(int index)
Returns the current value of the attribute's "declared" flag.
boolean
isDeclared(String qName)
Returns the current value of the attribute's "declared" flag.
boolean
isDeclared(String uri, String localName)
Returns the current value of the attribute's "declared" flag.
boolean
isSpecified(int index)
Returns the current value of an attribute's "specified" flag.
boolean
isSpecified(String qName)
Returns the current value of an attribute's "specified" flag.
boolean
isSpecified(String uri, String localName)
Returns the current value of an attribute's "specified" flag.
void
removeAttribute(int index)
Remove an attribute from the list.
void
setAttributes(Attributes atts)
Copy an entire Attributes object.
void
setDeclared(int index, boolean value)
Assign a value to the "declared" flag of a specific attribute.
void
setSpecified(int index, boolean value)
Assign a value to the "specified" flag of a specific attribute.

Methods inherited from class org.xml.sax.helpers.AttributesImpl

addAttribute, clear, getIndex, getIndex, getLength, getLocalName, getQName, getType, getType, getType, getURI, getValue, getValue, getValue, removeAttribute, setAttribute, setAttributes, setLocalName, setQName, setType, setURI, setValue

Methods inherited from class java.lang.Object

clone, equals, extends Object> getClass, finalize, hashCode, notify, notifyAll, toString, wait, wait, wait

Constructor Details

Attributes2Impl

public Attributes2Impl()
Construct a new, empty Attributes2Impl object.

Attributes2Impl

public Attributes2Impl(Attributes atts)
Copy an existing Attributes or Attributes2 object. If the object implements Attributes2, values of the specified and declared flags for each attribute are copied. Otherwise the flag values are defaulted to assume no DTD was used, unless there is evidence to the contrary (such as attributes with type other than CDATA, which must have been declared).

This constructor is especially useful inside a startElement event.

Parameters:
atts - The existing Attributes object.

Method Details

addAttribute

public void addAttribute(String uri,
                         String localName,
                         String qName,
                         String type,
                         String value)
Add an attribute to the end of the list, setting its "specified" flag to true. To set that flag's value to false, use setSpecified(int,boolean).

Unless the attribute type is CDATA, this attribute is marked as being declared in the DTD. To set that flag's value to true for CDATA attributes, use setDeclared(int,boolean).

Overrides:
addAttribute in interface AttributesImpl

isDeclared

public boolean isDeclared(int index)
Returns the current value of the attribute's "declared" flag.
Specified by:
isDeclared in interface Attributes2

isDeclared

public boolean isDeclared(String qName)
Returns the current value of the attribute's "declared" flag.
Specified by:
isDeclared in interface Attributes2

isDeclared

public boolean isDeclared(String uri,
                          String localName)
Returns the current value of the attribute's "declared" flag.
Specified by:
isDeclared in interface Attributes2

isSpecified

public boolean isSpecified(int index)
Returns the current value of an attribute's "specified" flag.
Specified by:
isSpecified in interface Attributes2
Parameters:
index - The attribute index (zero-based).
Returns:
current flag value
Throws:
ArrayIndexOutOfBoundsException - When the supplied index does not identify an attribute.

isSpecified

public boolean isSpecified(String qName)
Returns the current value of an attribute's "specified" flag.
Specified by:
isSpecified in interface Attributes2
Parameters:
qName - The XML qualified (prefixed) name.
Returns:
current flag value
Throws:
IllegalArgumentException - When the supplied name does not identify an attribute.

isSpecified

public boolean isSpecified(String uri,
                           String localName)
Returns the current value of an attribute's "specified" flag.
Specified by:
isSpecified in interface Attributes2
Parameters:
uri - The Namespace URI, or the empty string if the name has no Namespace URI.
localName - The attribute's local name.
Returns:
current flag value
Throws:
IllegalArgumentException - When the supplied names do not identify an attribute.

removeAttribute

public void removeAttribute(int index)
Remove an attribute from the list.
Overrides:
removeAttribute in interface AttributesImpl
Parameters:
index - The index of the attribute (zero-based).
Throws:
ArrayIndexOutOfBoundsException - When the supplied index does not point to an attribute in the list.

setAttributes

public void setAttributes(Attributes atts)
Copy an entire Attributes object. The "specified" flags are assigned as true, and "declared" flags as false (except when an attribute's type is not CDATA), unless the object is an Attributes2 object. In that case those flag values are all copied.
Overrides:
setAttributes in interface AttributesImpl

setDeclared

public void setDeclared(int index,
                        boolean value)
Assign a value to the "declared" flag of a specific attribute. This is normally needed only for attributes of type CDATA, including attributes whose type is changed to or from CDATA.
Parameters:
index - The index of the attribute (zero-based).
value - The desired flag value.
Throws:
ArrayIndexOutOfBoundsException - When the supplied index does not identify an attribute.
See Also:
Attributes2Impl

setSpecified

public void setSpecified(int index,
                         boolean value)
Assign a value to the "specified" flag of a specific attribute. This is the only way this flag can be cleared, except clearing by initialization with the copy constructor.
Parameters:
index - The index of the attribute (zero-based).
value - The desired flag value.
Throws:
ArrayIndexOutOfBoundsException - When the supplied index does not identify an attribute.