Class Document
- java.lang.Object
-
- nu.xom.Node
-
- nu.xom.ParentNode
-
- nu.xom.Document
-
public class Document extends ParentNode
The
Documentclass represents a complete XML document including its root element, prolog, and epilog.- Version:
- 1.3.0
- Author:
- Elliotte Rusty Harold
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Documentcopy()Returns a complete copy of this document.java.lang.StringgetBaseURI()Returns the absolute URI from which this document was loaded.DocTypegetDocType()Returns this document's document type declaration, or null if it doesn't have one.ElementgetRootElement()Returns this document's root element.java.lang.StringgetValue()Returns the value of the document as defined by XPath 1.0.NoderemoveChild(int position)Removes the child of this document at the specified position.NoderemoveChild(Node child)Removes the specified child from this document.voidreplaceChild(Node oldChild, Node newChild)Replaces an existing child with a new child node.voidsetBaseURI(java.lang.String URI)Sets the URI from which this document was loaded, and against which relative URLs in this document will be resolved.voidsetDocType(DocType doctype)Sets this document's document type declaration.voidsetRootElement(Element root)Replaces the current root element with a different root element.java.lang.StringtoString()Returns a string representation of this document suitable for debugging and diagnosis.java.lang.StringtoXML()Returns the actual complete, well-formed XML document as aString.-
Methods inherited from class nu.xom.ParentNode
appendChild, getChild, getChildCount, indexOf, insertChild
-
-
-
-
Constructor Detail
-
Document
public Document(Element root)
Creates a new
Documentobject with the specified root element.- Parameters:
root- the root element of this document- Throws:
java.lang.NullPointerException- ifrootis nullMultipleParentException- ifrootalready has a parent
-
Document
public Document(Document doc)
Creates a copy of this document.
- Parameters:
doc- the document to copy- Throws:
java.lang.NullPointerException- ifdocis null
-
-
Method Detail
-
getDocType
public final DocType getDocType()
Returns this document's document type declaration, or null if it doesn't have one.
- Returns:
- the document type declaration
- See Also:
setDocType(nu.xom.DocType)
-
setDocType
public void setDocType(DocType doctype)
Sets this document's document type declaration. If this document already has a document type declaration, then it's inserted at that position. Otherwise, it's inserted at the beginning of the document.
- Parameters:
doctype- the document type declaration- Throws:
MultipleParentException- ifdoctypebelongs to another documentjava.lang.NullPointerException- ifdoctypeis null
-
getRootElement
public final Element getRootElement()
Returns this document's root element. This is guaranteed to be non-null.
- Returns:
- the root element
-
setRootElement
public void setRootElement(Element root)
Replaces the current root element with a different root element.
- Parameters:
root- the new root element- Throws:
MultipleParentException- if root has a parentjava.lang.NullPointerException- if root is null
-
setBaseURI
public void setBaseURI(java.lang.String URI)
Sets the URI from which this document was loaded, and against which relative URLs in this document will be resolved. Setting the base URI to null or the empty string removes any existing base URI.
- Specified by:
setBaseURIin classParentNode- Parameters:
URI- the base URI of this document- Throws:
MalformedURIException- ifURIis not a legal absolute URI
-
getBaseURI
public final java.lang.String getBaseURI()
Returns the absolute URI from which this document was loaded. This method returns the empty string if the base URI is not known; for instance if the document was created in memory with a constructor rather than by parsing an existing document.
- Overrides:
getBaseURIin classNode- Returns:
- the base URI of this document
-
removeChild
public Node removeChild(int position)
Removes the child of this document at the specified position. Indexes begin at 0 and count up to one less than the number of children of this document. The root element cannot be removed. Instead, use
setRootElementto replace the existing root element with a different element.- Overrides:
removeChildin classParentNode- Parameters:
position- index of the node to remove- Returns:
- the node which was removed
- Throws:
java.lang.IndexOutOfBoundsException- if the index is negative or greater than the number of children of this document - 1WellformednessException- if the index points to the root element
-
removeChild
public Node removeChild(Node child)
Removes the specified child from this document. The root element cannot be removed. Instead, use
setRootElementto replace the existing root element with a different element.- Overrides:
removeChildin classParentNode- Parameters:
child- node to remove- Returns:
- the node which was removed
- Throws:
NoSuchChildException- if the node is not a child of this nodeWellformednessException- if child is the root element
-
replaceChild
public void replaceChild(Node oldChild, Node newChild)
Replaces an existing child with a new child node. If
oldChildis not a child of this node, then aNoSuchChildExceptionis thrown. The root element can only be replaced by another element.- Overrides:
replaceChildin classParentNode- Parameters:
oldChild- the node removed from the treenewChild- the node inserted into the tree- Throws:
MultipleParentException- ifnewChildalready has a parentNoSuchChildException- ifoldChildis not a child of this nodejava.lang.NullPointerException- if either argument is nullIllegalAddException- ifnewChildis an attribute or a text nodeWellformednessException- ifnewChildoldChildis an element andnewChildis not
-
getValue
public final java.lang.String getValue()
Returns the value of the document as defined by XPath 1.0. This is the same as the value of the root element, which is the complete PCDATA content of the root element, without any tags, comments, or processing instructions after all entity and character references have been resolved.
-
toXML
public final java.lang.String toXML()
Returns the actual complete, well-formed XML document as a
String. Significant white space is preserved. Insignificant white space in tags, the prolog, the epilog, and the internal DTD subset is not preserved. Entity and character references are not preserved. The entire document is contained in this one string.
-
copy
public Document copy()
Returns a complete copy of this document.
-
toString
public final java.lang.String toString()
Returns a string representation of this document suitable for debugging and diagnosis. This is not the XML representation of this document.
- Overrides:
toStringin classjava.lang.Object- Returns:
- a non-XML string representation of this document
-
-