public interface XmlSerializer
PLEASE NOTE: This interface will be part of XmlPull 1.2 API. It is included as basis for discussion. It may change in any way.
Exceptions that may be thrown are: IOException or runtime exception (more runtime exceptions can be thrown but are not declared and as such have no semantics defined for this interface):
NOTE: writing CDSECT, ENTITY_REF, IGNORABLE_WHITESPACE, PROCESSING_INSTRUCTION, COMMENT, and DOCDECL in some implementations may not be supported (for example when serializing to WBXML). In such case IllegalStateException will be thrown and it is recommended to use an optional feature to signal that implementation is not supporting this kind of output.
Modifier and Type | Method and Description |
---|---|
XmlSerializer |
attribute(String namespace,
String name,
String value)
Write an attribute.
|
void |
cdsect(String text) |
void |
comment(String text) |
void |
docdecl(String text) |
void |
endDocument()
Finish writing.
|
XmlSerializer |
endTag(String namespace,
String name)
Write end tag.
|
void |
entityRef(String text) |
void |
flush()
Write all pending output to the stream.
|
int |
getDepth() |
boolean |
getFeature(String name)
Return the current value of the feature with given name.
|
String |
getName()
Returns the name of the current element as set by startTag().
|
String |
getNamespace()
Returns the namespace URI of the current element as set by startTag().
|
String |
getPrefix(String namespace,
boolean generatePrefix) |
Object |
getProperty(String name)
Look up the value of a property.
|
void |
ignorableWhitespace(String text) |
void |
processingInstruction(String text) |
void |
setFeature(String name,
boolean state)
Set feature identified by name (recommended to be URI for uniqueness).
|
void |
setOutput(OutputStream os,
String encoding)
Set to use binary output stream with given encoding.
|
void |
setOutput(Writer writer) |
void |
setPrefix(String prefix,
String namespace)
Binds the given prefix to the given namespace.
|
void |
setProperty(String name,
Object value)
Set the value of a property.
|
void |
startDocument(String encoding,
Boolean standalone)
Write <?xml declaration with encoding (if encoding not null) and standalone flag (if standalone not null)
This method can only be called just after setOutput.
|
XmlSerializer |
startTag(String namespace,
String name)
Writes a start tag with the given namespace and name.
|
XmlSerializer |
text(char[] buf,
int start,
int len)
Writes text, where special XML chars are escaped automatically
|
XmlSerializer |
text(String text) |
void setFeature(String name, boolean state) throws IllegalArgumentException, IllegalStateException
name
- feature namestate
- feature stateIllegalStateException
- If the feature is not supported or can not be setIllegalArgumentException
boolean getFeature(String name)
NOTE: unknown properties are always returned as null
name
- The name of feature to be retrieved.IllegalArgumentException
- if feature string is nullvoid setProperty(String name, Object value) throws IllegalArgumentException, IllegalStateException
name
- property namevalue
- property valueIllegalStateException
- if the property is not supported or can not be setIllegalArgumentException
Object getProperty(String name)
NOTE: unknown properties are always returned as null
name
- The name of property to be retrieved.void setOutput(OutputStream os, String encoding) throws IOException, IllegalArgumentException, IllegalStateException
os
- outencoding
- encodingIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal usevoid setOutput(Writer writer) throws IOException, IllegalArgumentException, IllegalStateException
writer
- Set the output to the given writer.
WARNING no information about encoding is available!
IOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal usevoid startDocument(String encoding, Boolean standalone) throws IOException, IllegalArgumentException, IllegalStateException
encoding
- document encodingstandalone
- standalone flag valueIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal usevoid endDocument() throws IOException, IllegalArgumentException, IllegalStateException
IOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal usevoid setPrefix(String prefix, String namespace) throws IOException, IllegalArgumentException, IllegalStateException
xmlns:prefix='namespace'
(or
xmlns:prefix="namespace"
depending what character is used to quote attribute value).
NOTE: this method MUST be called directly before startTag() and if anything but startTag() or setPrefix() is called next there will be exception.
NOTE: prefixes "xml" and "xmlns" are already bound and can not be redefined see: Namespaces in XML Errata.
NOTE: to set default namespace use as prefix empty string.
prefix
- must be not null (or IllegalArgumentException is thrown)namespace
- must be not nullIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal useString getPrefix(String namespace, boolean generatePrefix) throws IllegalArgumentException
namespace
- the namespacegeneratePrefix
- to generate the missing prefixNOTE: if the prefix is empty string "" and default namespace is bound to this prefix then empty string ("") is returned.
NOTE: prefixes "xml" and "xmlns" are already bound will have values as defined Namespaces in XML specification
IllegalArgumentException
- if nullint getDepth()
<!-- outside --> 0 <root> 1 sometext 1 <foobar> 2 </foobar> 2 </root> 1 <!-- outside --> 0
String getNamespace()
NOTE: that means in particular that:
String getName()
XmlSerializer startTag(String namespace, String name) throws IOException, IllegalArgumentException, IllegalStateException
namespace
- nsname
- tag nameIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal useXmlSerializer attribute(String namespace, String name, String value) throws IOException, IllegalArgumentException, IllegalStateException
name
- attribute namevalue
- attribute valuenamespace
- namespace to useIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal useXmlSerializer endTag(String namespace, String name) throws IOException, IllegalArgumentException, IllegalStateException
namespace
- nsname
- tag nameIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal useXmlSerializer text(String text) throws IOException, IllegalArgumentException, IllegalStateException
text
- Writes text, where special XML chars are escaped automaticallyIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal useXmlSerializer text(char[] buf, int start, int len) throws IOException, IllegalArgumentException, IllegalStateException
buf
- characterslen
- lenghtstart
- startIOException
- ioIllegalArgumentException
- if nullIllegalStateException
- illegal usevoid cdsect(String text) throws IOException, IllegalArgumentException, IllegalStateException
void entityRef(String text) throws IOException, IllegalArgumentException, IllegalStateException
void processingInstruction(String text) throws IOException, IllegalArgumentException, IllegalStateException
void comment(String text) throws IOException, IllegalArgumentException, IllegalStateException
void docdecl(String text) throws IOException, IllegalArgumentException, IllegalStateException
void ignorableWhitespace(String text) throws IOException, IllegalArgumentException, IllegalStateException
void flush() throws IOException
NOTE: if there is need to close start tag (so no more attribute() calls are allowed) but without flushing output call method text() with empty string (text("")).
IOException
- ioCopyright © 2001–2022 The Apache Software Foundation. All rights reserved.