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 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,
Writer out,
int indent,
String indentWith,
boolean hasChildren)
Writes a DOM tree to a stream.
|
String |
encode(String value)
Escape <, > & ', " as their entities and
drop characters that are illegal in XML documents.
|
String |
encodeAttributeValue(String value)
Escape <, > & ', " as their entities, \n,
\r and \t as numeric entities and drop characters that are
illegal in XML documents.
|
String |
encodedata(String value)
Drop characters that are illegal in XML documents.
|
void |
encodedata(Writer out,
String value)
Drop characters that are illegal in XML documents and write the
rest to the given writer.
|
boolean |
isLegalCharacter(char c)
Is the given character allowed inside an XML document?
|
boolean |
isReference(String ent)
Is the given argument a character or entity reference?
|
void |
openElement(org.w3c.dom.Element element,
Writer out,
int indent,
String indentWith)
Writes the opening tag - including all attributes -
corresponding to a DOM element.
|
void |
openElement(org.w3c.dom.Element element,
Writer out,
int indent,
String indentWith,
boolean hasChildren)
Writes the opening tag - including all attributes -
corresponding to a DOM element.
|
void |
write(org.w3c.dom.Element root,
OutputStream out)
Writes a DOM tree to a stream in UTF8 encoding.
|
void |
write(org.w3c.dom.Element element,
Writer out,
int indent,
String indentWith)
Writes a DOM tree to a stream.
|
void |
writeXMLDeclaration(Writer wri)
Writes the XML declaration if xmlDeclaration is true.
|
protected 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 closeElement(org.w3c.dom.Element element, Writer out, int indent, String indentWith, boolean hasChildren) throws 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.IOException
- if an error happens while writing to the stream.public String encode(String value)
value
- the string to encode.public String encodeAttributeValue(String value)
value
- the string to encode.public String encodedata(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 void encodedata(Writer out, String value) throws IOException
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.out
- where to write the encoded data to.IOException
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.public boolean isReference(String ent)
ent
- the value to be checked.public void openElement(org.w3c.dom.Element element, Writer out, int indent, String indentWith) throws IOException
element
- the DOM element to writeout
- where to send the outputindent
- number ofindentWith
- string that should be used to indent the
corresponding tag.IOException
- if an error happens while writing to the stream.public void openElement(org.w3c.dom.Element element, Writer out, int indent, String indentWith, boolean hasChildren) throws 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.IOException
- if an error happens while writing to the stream.public void write(org.w3c.dom.Element root, OutputStream out) throws IOException
root
- the root element of the DOM tree.out
- the outputstream to write to.IOException
- if an error happens while writing to the stream.public void write(org.w3c.dom.Element element, Writer out, int indent, String indentWith) throws 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.IOException
- if an error happens while writing to the stream.public void writeXMLDeclaration(Writer wri) throws IOException
wri
- the writer to write to.IOException
- if there is an error.