|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
Define an interface to serialziation of XML Infoset. This interface abstracts away if serialized XML is XML 1.0 comaptible text or other formats of XML 1.0 serializations (such as binary XML for example with WBXML).
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 recommened to use an optional feature to signal that implementation is not supporting this kind of output.
Method Summary | |
XmlSerializer |
attribute(java.lang.String namespace,
java.lang.String name,
java.lang.String value)
Write an attribute. |
void |
cdsect(java.lang.String text)
|
void |
comment(java.lang.String text)
|
void |
docdecl(java.lang.String text)
|
void |
endDocument()
Finish writing. |
XmlSerializer |
endTag(java.lang.String namespace,
java.lang.String name)
Write end tag. |
void |
entityRef(java.lang.String text)
|
void |
flush()
Write all pending output to the stream. |
int |
getDepth()
Returns the current depth of the element. |
boolean |
getFeature(java.lang.String name)
Return the current value of the feature with given name. |
java.lang.String |
getName()
Returns the name of the current element as set by startTag(). |
java.lang.String |
getNamespace()
Returns the namespace URI of the current element as set by startTag(). |
java.lang.String |
getPrefix(java.lang.String namespace,
boolean generatePrefix)
Return namespace that corresponds to given prefix If there is no prefix bound to this namespace return null but if generatePrefix is false then return generated prefix. |
java.lang.Object |
getProperty(java.lang.String name)
Look up the value of a property. |
void |
ignorableWhitespace(java.lang.String text)
|
void |
processingInstruction(java.lang.String text)
|
void |
setFeature(java.lang.String name,
boolean state)
Set feature identified by name (recommended to be URI for uniqueness). |
void |
setOutput(java.io.OutputStream os,
java.lang.String encoding)
Set to use binary output stream with given encoding. |
void |
setOutput(java.io.Writer writer)
Set the output to the given writer. |
void |
setPrefix(java.lang.String prefix,
java.lang.String namespace)
Binds the given prefix to the given namespace. |
void |
setProperty(java.lang.String name,
java.lang.Object value)
Set the value of a property. |
void |
startDocument(java.lang.String encoding,
java.lang.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(java.lang.String namespace,
java.lang.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(java.lang.String text)
Writes text, where special XML chars are escaped automatically |
Method Detail |
public void setFeature(java.lang.String name, boolean state) throws java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.lang.IllegalStateException
- If the feature is not supported or can not be set
java.lang.IllegalArgumentException
public boolean getFeature(java.lang.String name)
NOTE: unknown properties are always returned as null
name
- The name of feature to be retrieved.
java.lang.IllegalArgumentException
- if feature string is nullpublic void setProperty(java.lang.String name, java.lang.Object value) throws java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.lang.IllegalStateException
- if the property is not supported or can not be set
java.lang.IllegalArgumentException
public java.lang.Object getProperty(java.lang.String name)
NOTE: unknown properties are
name
- The name of property to be retrieved.
public void setOutput(java.io.OutputStream os, java.lang.String encoding) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void setOutput(java.io.Writer writer) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
WARNING no information about encoding is available!
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void startDocument(java.lang.String encoding, java.lang.Boolean standalone) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void endDocument() throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void setPrefix(java.lang.String prefix, java.lang.String namespace) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.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 null
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public java.lang.String getPrefix(java.lang.String namespace, boolean generatePrefix) throws java.lang.IllegalArgumentException
NOTE: if the prefix is empty string "" and defualt 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
java.lang.IllegalArgumentException
public int getDepth()
<!-- outside --> 0 <root> 1 sometext 1 <foobar> 2 </foobar> 2 </root> 1 <!-- outside --> 0
public java.lang.String getNamespace()
NOTE: that measn in particaulr that:
public java.lang.String getName()
public XmlSerializer startTag(java.lang.String namespace, java.lang.String name) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public XmlSerializer attribute(java.lang.String namespace, java.lang.String name, java.lang.String value) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public XmlSerializer endTag(java.lang.String namespace, java.lang.String name) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
Background: in kXML endTag had no arguments, and non matching tags were very difficult to find... If namespace is null no namespace prefix is printed but just name. If namespace is empty string then serialzier will make sure that default empty namespace is declared (in XML 1.0 xmlns='').
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public XmlSerializer text(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public XmlSerializer text(char[] buf, int start, int len) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void cdsect(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void entityRef(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void processingInstruction(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void comment(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void docdecl(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void ignorableWhitespace(java.lang.String text) throws java.io.IOException, java.lang.IllegalArgumentException, java.lang.IllegalStateException
java.io.IOException
java.lang.IllegalArgumentException
java.lang.IllegalStateException
public void flush() throws java.io.IOException
NOTE: if there is need to close start tag (so no more attribute() calls are allowed) but without flushinging output call method text() with empty string (text("")).
java.io.IOException
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |