⇒ Index (Frames) |  ⇒ Index (No Frames) |  ⇒ Package |  ⇒ Package Tree |  ⇒ Full Tree 
org.xml.sax.helpers

Class AttributeListImpl

java.lang.Object
|
+--org.xml.sax.helpers.AttributeListImpl

All Implemented Interfaces:
AttributeList


public class AttributeListImpl
extends java.lang.Object
implements AttributeList

Default implementation for AttributeList.
This module, both source code and documentation, is in the Public Domain, and comes with NO WARRANTY. See http://www.saxproject.org for further information.

AttributeList implements the deprecated SAX1 org.xml.sax.AttributeList AttributeList interface, and has been replaced by the new SAX2 org.xml.sax.helpers.AttributesImpl AttributesImpl interface.

This class provides a convenience implementation of the SAX 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:

 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);
   [...]
 }

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. org.xml.sax.AttributeList AttributeList; that interface has been replaced by org.xml.sax.Attributes Attributes, which is implemented in the org.xml.sax.helpers.AttributesImpl AttributesImpl helper class.

Since:
SAX 1.0
Author:
David Megginson
See Also:
org.xml.sax.AttributeList
org.xml.sax.DocumentHandler.startElement

Constructor Summary

AttributeListImpl()

Create an empty attribute list.

AttributeListImpl(AttributeList atts)

Construct a persistent copy of an existing attribute list.

Method Summary

void

addAttribute(java.lang.String name, java.lang.String type, java.lang.String value)

Add an attribute to an attribute list.

void

clear()

Clear the attribute list.

int

getLength()

Return the number of attributes in the list.

java.lang.String

getName(int i)

Get the name of an attribute (by position).

java.lang.String

getType(int i)

Get the type of an attribute (by position).

java.lang.String

getType(java.lang.String name)

Get the type of an attribute (by name).

java.lang.String

getValue(int i)

Get the value of an attribute (by position).

java.lang.String

getValue(java.lang.String name)

Get the value of an attribute (by name).

void

removeAttribute(java.lang.String name)

Remove an attribute from the list.

void

setAttributeList(AttributeList atts)

Set the attribute list, discarding previous contents.

Constructor Details

AttributeListImpl

public AttributeListImpl()

Create an empty attribute list.

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.

See Also:
addAttribute
clear

AttributeListImpl

public AttributeListImpl(AttributeList atts)

Construct a persistent copy of an existing attribute list.

This constructor is most useful for application writers, who will use it to create a persistent copy of an existing attribute list.

Parameters:
atts - The attribute list to copy
See Also:
org.xml.sax.DocumentHandler.startElement

Method Details

addAttribute

public void addAttribute(java.lang.String name, java.lang.String type, java.lang.String value)

Add an attribute to an attribute list.

This method is provided for SAX parser writers, to allow them to build up an attribute list incrementally before delivering it to the application.

Parameters:
name - The attribute name.
type - The attribute type ("NMTOKEN" for an enumeration).
value - The attribute value (must not be null).
See Also:
removeAttribute
org.xml.sax.DocumentHandler.startElement

clear

public void clear()

Clear the attribute list.

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.

See Also:
org.xml.sax.DocumentHandler.startElement

getLength

public int getLength()

Return the number of attributes in the list.

Returns:
The number of attributes in the list.
See Also:
org.xml.sax.AttributeList.getLength

getName

public String getName(int i)

Get the name of an attribute (by position).

Parameters:
i - The position of the attribute in the list.
Returns:
The attribute name as a string, or null if there is no attribute at that position.
See Also:
org.xml.sax.AttributeList.getName(int)

getType

public String getType(int i)

Get the type of an attribute (by position).

Parameters:
i - The position of the attribute in the list.
Returns:
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 Also:
org.xml.sax.AttributeList.getType(int)

getType

public String getType(java.lang.String name)

Get the type of an attribute (by name).

Parameters:
name - The attribute name.
Returns:
The attribute type as a string ("NMTOKEN" for an enumeration, and "CDATA" if no declaration was read).
See Also:
org.xml.sax.AttributeList.getType(java.lang.String)

getValue

public String getValue(int i)

Get the value of an attribute (by position).

Parameters:
i - The position of the attribute in the list.
Returns:
The attribute value as a string, or null if there is no attribute at that position.
See Also:
org.xml.sax.AttributeList.getValue(int)

getValue

public String getValue(java.lang.String name)

Get the value of an attribute (by name).

Parameters:
name - The attribute name.
See Also:
org.xml.sax.AttributeList.getValue(java.lang.String)

removeAttribute

public void removeAttribute(java.lang.String name)

Remove an attribute from the list.

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.

If the requested attribute is not in the list, this is a no-op.

Parameters:
name - The attribute name.
See Also:
addAttribute

setAttributeList

public void setAttributeList(AttributeList atts)

Set the attribute list, discarding previous contents.

This method allows an application writer to reuse an attribute list easily.

Parameters:
atts - The attribute list to copy.