public class DOMElementWriter
extends java.lang.Object
Utility class used by XmlLogger
and
org.apache.tools.ant.taskdefs.optional.junit.XMLJUnitResultFormatter
XMLJUnitResultFormatter}.
Modifier and Type | Class and Description |
---|---|
static class |
DOMElementWriter.XmlNamespacePolicy
Whether namespaces should be ignored for elements and attributes.
|
Modifier and Type | Field and Description |
---|---|
protected java.lang.String[] |
knownEntities
Don't try to be too smart but at least recognize the predefined entities.
|
Constructor and Description |
---|
DOMElementWriter()
Create an element writer.
|
DOMElementWriter(boolean xmlDeclaration)
Create an element writer XML namespaces will be ignored.
|
DOMElementWriter(boolean xmlDeclaration,
DOMElementWriter.XmlNamespacePolicy namespacePolicy)
Create an element writer XML namespaces will be ignored.
|
Modifier and Type | Method and Description |
---|---|
void |
closeElement(org.w3c.dom.Element element,
java.io.Writer out,
int indent,
java.lang.String indentWith,
boolean hasChildren)
Writes a DOM tree to a stream.
|
java.lang.String |
encode(java.lang.String value)
Escape <, > & ', " as their entities and drop
characters that are illegal in XML documents.
|
java.lang.String |
encodeAttributeValue(java.lang.String value)
Escape <, > & ', " as their entities, \n, \r and \t
as numeric entities and drop characters that are illegal in XML
documents.
|
java.lang.String |
encodedata(java.lang.String value)
Drop characters that are illegal in XML documents.
|
boolean |
isLegalCharacter(char c)
Is the given character allowed inside an XML document?
|
boolean |
isReference(java.lang.String ent)
Is the given argument a character or entity reference?
|
void |
openElement(org.w3c.dom.Element element,
java.io.Writer out,
int indent,
java.lang.String indentWith)
Writes the opening tag - including all attributes - corresponding to a
DOM element.
|
void |
openElement(org.w3c.dom.Element element,
java.io.Writer out,
int indent,
java.lang.String indentWith,
boolean hasChildren)
Writes the opening tag - including all attributes - corresponding to a
DOM element.
|
void |
write(org.w3c.dom.Element root,
java.io.OutputStream out)
Writes a DOM tree to a stream in UTF8 encoding.
|
void |
write(org.w3c.dom.Element element,
java.io.Writer out,
int indent,
java.lang.String indentWith)
Writes a DOM tree to a stream.
|
void |
writeXMLDeclaration(java.io.Writer wri)
Writes the XML declaration if xmlDeclaration is true.
|
protected java.lang.String[] knownEntities
public DOMElementWriter()
public DOMElementWriter(boolean xmlDeclaration)
xmlDeclaration
- flag to indicate whether the ?xml? declaration should be
included.public DOMElementWriter(boolean xmlDeclaration, DOMElementWriter.XmlNamespacePolicy namespacePolicy)
xmlDeclaration
- flag to indicate whether the ?xml? declaration should be
included.namespacePolicy
- the policy to use.public void write(org.w3c.dom.Element root, java.io.OutputStream out) throws java.io.IOException
root
- the root element of the DOM tree.out
- the outputstream to write to.java.io.IOException
- if an error happens while writing to the stream.public void writeXMLDeclaration(java.io.Writer wri) throws java.io.IOException
wri
- the writer to write to.java.io.IOException
- if there is an error.public void write(org.w3c.dom.Element element, java.io.Writer out, int indent, java.lang.String indentWith) throws java.io.IOException
element
- the Root DOM element of the treeout
- where to send the outputindent
- number ofindentWith
- string that should be used to indent the corresponding tag.java.io.IOException
- if an error happens while writing to the stream.public void openElement(org.w3c.dom.Element element, java.io.Writer out, int indent, java.lang.String indentWith) throws java.io.IOException
element
- the DOM element to writeout
- where to send the outputindent
- number ofindentWith
- string that should be used to indent the corresponding tag.java.io.IOException
- if an error happens while writing to the stream.public void openElement(org.w3c.dom.Element element, java.io.Writer out, int indent, java.lang.String indentWith, boolean hasChildren) throws java.io.IOException
element
- the DOM element to writeout
- where to send the outputindent
- number ofindentWith
- string that should be used to indent the corresponding tag.hasChildren
- whether this element has children.java.io.IOException
- if an error happens while writing to the stream.public void closeElement(org.w3c.dom.Element element, java.io.Writer out, int indent, java.lang.String indentWith, boolean hasChildren) throws java.io.IOException
element
- the Root DOM element of the treeout
- where to send the outputindent
- number ofindentWith
- string that should be used to indent the corresponding tag.hasChildren
- if true indent.java.io.IOException
- if an error happens while writing to the stream.public java.lang.String encode(java.lang.String value)
value
- the string to encode.public java.lang.String encodeAttributeValue(java.lang.String value)
value
- the string to encode.public java.lang.String encodedata(java.lang.String value)
Also ensure that we are not including an ]]>
marker by
replacing that sequence with ]]>
.
See XML 1.0 2.2 http://www.w3.org/TR/1998/REC-xml-19980210#charsets and 2.7 http://www.w3.org/TR/1998/REC-xml-19980210#sec-cdata-sect.
value
- the value to be encoded.public boolean isReference(java.lang.String ent)
ent
- the value to be checked.public boolean isLegalCharacter(char c)
See XML 1.0 2.2 http://www.w3.org/TR/1998/REC-xml-19980210#charsets.
c
- the character to test.