gnu.xml.dom

Class DomElement

Implemented Interfaces:
DocumentEvent, Element, EventTarget, Node, NodeList, Cloneable, Comparable
Known Direct Subclasses:
DomHTMLElement

public class DomElement
extends DomNsNode
implements Element

"Element" implementation.

Constructor Summary

DomElement(DomDocument owner, String namespaceURI, String name)
Constructs an Element node associated with the specified document.

Method Summary

Object
clone()
Shallow clone of the element, except that associated attributes are (deep) cloned.
String
getAttribute(String name)
DOM L1 Returns the value of the specified attribute, or an empty string.
String
getAttributeNS(String namespaceURI, String local)
DOM L2 Returns the value of the specified attribute, or an empty string.
Attr
getAttributeNode(String name)
DOM L1 Returns the appropriate attribute node; the name is the nodeName property of the attribute.
Attr
getAttributeNodeNS(String namespace, String localPart)
DOM L2 Returns the appropriate attribute node; the name combines the namespace name and the local part.
NamedNodeMap
getAttributes()
DOM L1 Returns the element's attributes
String
getBaseURI()
TypeInfo
getSchemaTypeInfo()
String
getTagName()
DOM L1 Returns the element name (same as getNodeName).
boolean
hasAttribute(String name)
DOM L2 Returns true if the element has an attribute with the specified name (specified or DTD defaulted).
boolean
hasAttributeNS(String namespaceURI, String local)
DOM L2 Returns true if the element has an attribute with the specified name (specified or DTD defaulted).
boolean
hasAttributes()
DOM L2> Returns true iff this is an element node with attributes.
boolean
isDefaultNamespace(String namespaceURI)
String
lookupNamespaceURI(String prefix)
String
lookupPrefix(String namespaceURI)
void
makeReadonly()
Marks this element, its children, and its associated attributes as readonly.
void
removeAttribute(String name)
DOM L1 Removes the appropriate attribute node.
void
removeAttributeNS(String namespace, String localPart)
DOM L2 Removes the appropriate attribute node; the name combines the namespace name and the local part.
Attr
removeAttributeNode(Attr node)
DOM L1 Removes the appropriate attribute node; the name is the nodeName property of the attribute.
void
setAttribute(String name, String value)
DOM L1 Modifies an existing attribute to have the specified value, or creates a new one with that value.
void
setAttributeNS(String uri, String aname, String value)
DOM L2 Modifies an existing attribute to have the specified value, or creates a new one with that value.
Attr
setAttributeNode(Attr attr)
DOM L1 Stores the specified attribute, optionally overwriting any existing one with that name.
Attr
setAttributeNodeNS(Attr attr)
DOM L2 Stores the specified attribute, optionally overwriting any existing one with that name.
void
setIdAttribute(String name, boolean isId)
void
setIdAttributeNS(String namespaceURI, String localName, boolean isId)
void
setIdAttributeNode(Attr attr, boolean isId)

Methods inherited from class gnu.xml.dom.DomNsNode

getLocalName, getNamespaceURI, getNodeName, getPrefix, setPrefix

Methods inherited from class gnu.xml.dom.DomNode

addEventListener, appendChild, clone, cloneNode, compact, compareDocumentPosition, compareTo, createEvent, dispatchEvent, getAttributes, getBaseURI, getChildNodes, getElementsByTagName, getElementsByTagNameNS, getFeature, getFirstChild, getLastChild, getLength, getLocalName, getNamespaceURI, getNextSibling, getNodeName, getNodeType, getNodeValue, getOwnerDocument, getParentNode, getPrefix, getPreviousSibling, getTextContent, getUserData, hasAttributes, hasChildNodes, insertBefore, isDefaultNamespace, isEqualNode, isReadonly, isSameNode, isSupported, item, lookupNamespaceURI, lookupPrefix, makeReadonly, nameAndTypeEquals, normalize, removeChild, removeEventListener, replaceChild, setNodeValue, setPrefix, setTextContent, setUserData, toString, trimToSize

Methods inherited from class java.lang.Object

clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

Constructor Details

DomElement

protected DomElement(DomDocument owner,
                     String namespaceURI,
                     String name)
Constructs an Element node associated with the specified document.

This constructor should only be invoked by a Document as part of its createElement functionality, or through a subclass which is similarly used in a "Sub-DOM" style layer.

Parameters:
owner - The document with which this node is associated
namespaceURI - Combined with the local part of the name, this is used to uniquely identify a type of element
name - Name of this element, which may include a prefix

Method Details

clone

public Object clone()
Shallow clone of the element, except that associated attributes are (deep) cloned.
Overrides:
clone in interface DomNode

getAttribute

public String getAttribute(String name)
DOM L1 Returns the value of the specified attribute, or an empty string.

getAttributeNS

public String getAttributeNS(String namespaceURI,
                             String local)
DOM L2 Returns the value of the specified attribute, or an empty string.

getAttributeNode

public Attr getAttributeNode(String name)
DOM L1 Returns the appropriate attribute node; the name is the nodeName property of the attribute.

getAttributeNodeNS

public Attr getAttributeNodeNS(String namespace,
                               String localPart)
DOM L2 Returns the appropriate attribute node; the name combines the namespace name and the local part.

getAttributes

public NamedNodeMap getAttributes()
DOM L1 Returns the element's attributes
Overrides:
getAttributes in interface DomNode

getBaseURI

public String getBaseURI()
Overrides:
getBaseURI in interface DomNode

getSchemaTypeInfo

public TypeInfo getSchemaTypeInfo()

getTagName

public final String getTagName()
DOM L1 Returns the element name (same as getNodeName).

hasAttribute

public boolean hasAttribute(String name)
DOM L2 Returns true if the element has an attribute with the specified name (specified or DTD defaulted).

hasAttributeNS

public boolean hasAttributeNS(String namespaceURI,
                              String local)
DOM L2 Returns true if the element has an attribute with the specified name (specified or DTD defaulted).

hasAttributes

public boolean hasAttributes()
DOM L2> Returns true iff this is an element node with attributes.
Overrides:
hasAttributes in interface DomNode

isDefaultNamespace

public boolean isDefaultNamespace(String namespaceURI)
Overrides:
isDefaultNamespace in interface DomNode

lookupNamespaceURI

public String lookupNamespaceURI(String prefix)
Overrides:
lookupNamespaceURI in interface DomNode

lookupPrefix

public String lookupPrefix(String namespaceURI)
Overrides:
lookupPrefix in interface DomNode

makeReadonly

public void makeReadonly()
Marks this element, its children, and its associated attributes as readonly.
Overrides:
makeReadonly in interface DomNode

removeAttribute

public void removeAttribute(String name)
DOM L1 Removes the appropriate attribute node. If there is no such node, this is (bizarrely enough) a NOP so you won't see exceptions if your code deletes non-existent attributes.

Note that since there is no portable way for DOM to record DTD information, default values for attributes will never be provided automatically.


removeAttributeNS

public void removeAttributeNS(String namespace,
                              String localPart)
DOM L2 Removes the appropriate attribute node; the name combines the namespace name and the local part.

Note that since there is no portable way for DOM to record DTD information, default values for attributes will never be provided automatically.


removeAttributeNode

public Attr removeAttributeNode(Attr node)
DOM L1 Removes the appropriate attribute node; the name is the nodeName property of the attribute.

Note that since there is no portable way for DOM to record DTD information, default values for attributes will never be provided automatically.


setAttribute

public void setAttribute(String name,
                         String value)
DOM L1 Modifies an existing attribute to have the specified value, or creates a new one with that value. The name used is the nodeName value.

setAttributeNS

public void setAttributeNS(String uri,
                           String aname,
                           String value)
DOM L2 Modifies an existing attribute to have the specified value, or creates a new one with that value.

setAttributeNode

public Attr setAttributeNode(Attr attr)
DOM L1 Stores the specified attribute, optionally overwriting any existing one with that name.

setAttributeNodeNS

public Attr setAttributeNodeNS(Attr attr)
DOM L2 Stores the specified attribute, optionally overwriting any existing one with that name.

setIdAttribute

public void setIdAttribute(String name,
                           boolean isId)

setIdAttributeNS

public void setIdAttributeNS(String namespaceURI,
                             String localName,
                             boolean isId)

setIdAttributeNode

public void setIdAttributeNode(Attr attr,
                               boolean isId)

DomElement.java -- Copyright (C) 1999,2000,2001,2004 Free Software Foundation, Inc. This file is part of GNU Classpath. GNU Classpath is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. GNU Classpath is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GNU Classpath; see the file COPYING. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. Linking this library statically or dynamically with other modules is making a combined work based on this library. Thus, the terms and conditions of the GNU General Public License cover the whole combination. As a special exception, the copyright holders of this library give you permission to link this library with independent modules to produce an executable, regardless of the license terms of these independent modules, and to copy and distribute the resulting executable under terms of your choice, provided that you also meet, for each linked independent module, the terms and conditions of the license of that module. An independent module is a module which is not derived from or based on this library. If you modify this library, you may extend this exception to your version of the library, but you are not obligated to do so. If you do not wish to do so, delete this exception statement from your version.