Class MXSerializer
- All Implemented Interfaces:
- XmlSerializer
Implemented features:
- FEATURE_NAMES_INTERNED - when enabled all returned names (namespaces, prefixes) will be interned and it is required that all names passed as arguments MUST be interned
- FEATURE_SERIALIZER_ATTVALUE_USE_APOSTROPHE
Implemented properties:
- PROPERTY_SERIALIZER_INDENTATION
- PROPERTY_SERIALIZER_LINE_SEPARATOR
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected booleanprotected intprotected char[]protected intprotected booleanprotected String[]protected String[]protected int[]protected final Stringprotected final Stringprotected booleanprotected char[]protected intprotected Stringprotected Stringprotected Stringprotected intprotected booleanprotected intprotected String[]protected String[]protected intprotected Writerprotected booleanprotected static final String[]protected static final Stringprotected final Stringprotected final Stringprotected booleanprotected booleanprotected booleanprotected booleanprotected booleanprotected booleanprotected booleanprotected static final Stringprotected static final String
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionWrite an attribute.voidprotected voidvoidvoidvoidFinish writing.Write end tag.protected voidprotected voidvoidvoidflush()Write all pending output to the stream.intgetDepth()booleangetFeature(String name) Return the current value of the feature with given name.getName()Returns the name of the current element as set by startTag().Returns the namespace URI of the current element as set by startTag().getProperty(String name) Look up the value of a property.voidignorableWhitespace(String text) protected StringlookupOrDeclarePrefix(String namespace) protected static final Stringprintable(char ch) protected static final StringvoidprocessingInstruction(String text) protected voidFor maximum efficiency when writing indents the required output is pre-computed This is internal function that recomputes buffer after user requested changes.protected voidreset()voidsetFeature(String name, boolean state) Set feature identified by name (recommended to be URI for uniqueness).voidsetOutput(OutputStream os, String encoding) Set to use binary output stream with given encoding.voidvoidBinds the given prefix to the given namespace.voidsetProperty(String name, Object value) Set the value of a property.voidstartDocument(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.Writes a start tag with the given namespace and name.text(char[] buf, int start, int len) Writes text, where special XML chars are escaped automaticallyprotected voidwriteAttributeValue(String value, Writer out) protected voidwriteElementContent(char[] buf, int off, int len, Writer out) protected voidwriteElementContent(String text, Writer out) protected void
- 
Field Details- 
XML_URI- See Also:
 
- 
XMLNS_URI- See Also:
 
- 
FEATURE_SERIALIZER_ATTVALUE_USE_APOSTROPHE- See Also:
 
- 
FEATURE_NAMES_INTERNED- See Also:
 
- 
PROPERTY_SERIALIZER_INDENTATION- See Also:
 
- 
PROPERTY_SERIALIZER_LINE_SEPARATOR- See Also:
 
- 
PROPERTY_LOCATION- See Also:
 
- 
namesInternedprotected boolean namesInterned
- 
attributeUseApostropheprotected boolean attributeUseApostrophe
- 
indentationString
- 
lineSeparator
- 
location
- 
out
- 
autoDeclaredPrefixesprotected int autoDeclaredPrefixes
- 
depthprotected int depth
- 
elNamespace
- 
elName
- 
elNamespaceCountprotected int[] elNamespaceCount
- 
namespaceEndprotected int namespaceEnd
- 
namespacePrefix
- 
namespaceUri
- 
finishedprotected boolean finished
- 
pastRootprotected boolean pastRoot
- 
setPrefixCalledprotected boolean setPrefixCalled
- 
startTagIncompleteprotected boolean startTagIncomplete
- 
doIndentprotected boolean doIndent
- 
seenTagprotected boolean seenTag
- 
seenBracketprotected boolean seenBracket
- 
seenBracketBracketprotected boolean seenBracketBracket
- 
bufprotected char[] buf
- 
precomputedPrefixes
- 
offsetNewLineprotected int offsetNewLine
- 
indentationJumpprotected int indentationJump
- 
indentationBufprotected char[] indentationBuf
- 
maxIndentLevelprotected int maxIndentLevel
- 
writeLineSeparatorprotected boolean writeLineSeparator
- 
writeIndentationprotected boolean writeIndentation
 
- 
- 
Constructor Details- 
MXSerializerpublic MXSerializer()
 
- 
- 
Method Details- 
resetprotected void reset()
- 
ensureElementsCapacityprotected void ensureElementsCapacity()
- 
ensureNamespacesCapacityprotected void ensureNamespacesCapacity()
- 
setFeaturepublic void setFeature(String name, boolean state) throws IllegalArgumentException, IllegalStateException Description copied from interface:XmlSerializerSet feature identified by name (recommended to be URI for uniqueness). Some well known optional features are defined in http://www.xmlpull.org/v1/doc/features.html. If feature is not recognized or can not be set then IllegalStateException MUST be thrown.- Specified by:
- setFeaturein interface- XmlSerializer
- Parameters:
- name- feature name
- state- feature state
- Throws:
- IllegalStateException- If the feature is not supported or can not be set
- IllegalArgumentException
 
- 
getFeatureDescription copied from interface:XmlSerializerReturn the current value of the feature with given name.NOTE: unknown properties are always returned as null - Specified by:
- getFeaturein interface- XmlSerializer
- Parameters:
- name- The name of feature to be retrieved.
- Returns:
- The value of named feature.
- Throws:
- IllegalArgumentException- if feature string is null
 
- 
rebuildIndentationBufprotected void rebuildIndentationBuf()For maximum efficiency when writing indents the required output is pre-computed This is internal function that recomputes buffer after user requested changes.
- 
writeIndent- Throws:
- IOException
 
- 
setPropertypublic void setProperty(String name, Object value) throws IllegalArgumentException, IllegalStateException Description copied from interface:XmlSerializerSet the value of a property. (the property name is recommended to be URI for uniqueness). Some well known optional properties are defined in http://www.xmlpull.org/v1/doc/properties.html. If property is not recognized or can not be set then IllegalStateException MUST be thrown.- Specified by:
- setPropertyin interface- XmlSerializer
- Parameters:
- name- property name
- value- property value
- Throws:
- IllegalStateException- if the property is not supported or can not be set
- IllegalArgumentException
 
- 
getPropertyDescription copied from interface:XmlSerializerLook up the value of a property. The property name is any fully-qualified URI. INOTE: unknown properties are always returned as null - Specified by:
- getPropertyin interface- XmlSerializer
- Parameters:
- name- The name of property to be retrieved.
- Returns:
- The value of named property.
- Throws:
- IllegalArgumentException
 
- 
getWriter
- 
setOutput- Specified by:
- setOutputin interface- XmlSerializer
- Parameters:
- writer- Set the output to the given writer.- WARNING no information about encoding is available! 
 
- 
setOutputDescription copied from interface:XmlSerializerSet to use binary output stream with given encoding.- Specified by:
- setOutputin interface- XmlSerializer
- Parameters:
- os- out
- encoding- encoding
- Throws:
- IOException- io
 
- 
startDocumentDescription copied from interface:XmlSerializerWrite <?xml declaration with encoding (if encoding not null) and standalone flag (if standalone not null) This method can only be called just after setOutput.- Specified by:
- startDocumentin interface- XmlSerializer
- Parameters:
- encoding- document encoding
- standalone- standalone flag value
- Throws:
- IOException- io
 
- 
endDocumentDescription copied from interface:XmlSerializerFinish writing. All unclosed start tags will be closed and output will be flushed. After calling this method no more output can be serialized until next call to setOutput()- Specified by:
- endDocumentin interface- XmlSerializer
- Throws:
- IOException- io
 
- 
setPrefixDescription copied from interface:XmlSerializerBinds the given prefix to the given namespace. This call is valid for the next element including child elements. The prefix and namespace MUST be always declared even if prefix is not used in element (startTag() or attribute()) - for XML 1.0 it must result in declaringxmlns:prefix='namespace'(orxmlns: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. - Specified by:
- setPrefixin interface- XmlSerializer
- Parameters:
- prefix- must be not null (or IllegalArgumentException is thrown)
- namespace- must be not null
- Throws:
- IOException- io
 
- 
lookupOrDeclarePrefix
- 
getPrefix- Specified by:
- getPrefixin interface- XmlSerializer
- Parameters:
- namespace- the namespace
- generatePrefix- to generate the missing prefix
- Returns:
- 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.
 NOTE: 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 
 
- 
getDepthpublic int getDepth()- Specified by:
- getDepthin interface- XmlSerializer
- Returns:
- the current depth of the element. Outside the root element, the depth is 0. The depth is incremented by 1
 when startTag() is called. The depth is decremented after the call to endTag() event was observed.
 <!-- outside --> 0 <root> 1 sometext 1 <foobar> 2 </foobar> 2 </root> 1 <!-- outside --> 0
 
- 
getNamespaceDescription copied from interface:XmlSerializerReturns the namespace URI of the current element as set by startTag().NOTE: that means in particular that: - if there was startTag("", ...) then getNamespace() returns ""
- if there was startTag(null, ...) then getNamespace() returns null
 - Specified by:
- getNamespacein interface- XmlSerializer
- Returns:
- namespace set by startTag() that is currently in scope
 
- 
getNameDescription copied from interface:XmlSerializerReturns the name of the current element as set by startTag(). It can only be null before first call to startTag() or when last endTag() is called to close first startTag().- Specified by:
- getNamein interface- XmlSerializer
- Returns:
- namespace set by startTag() that is currently in scope
 
- 
startTagDescription copied from interface:XmlSerializerWrites a start tag with the given namespace and name. If there is no prefix defined for the given namespace, a prefix will be defined automatically. The explicit prefixes for namespaces can be established by calling setPrefix() immediately before this method. If namespace is null no namespace prefix is printed but just name. If namespace is empty string then serializer will make sure that default empty namespace is declared (in XML 1.0 xmlns='') or throw IllegalStateException if default namespace is already bound to non-empty string.- Specified by:
- startTagin interface- XmlSerializer
- Parameters:
- namespace- ns
- name- tag name
- Returns:
- XmlSerializer
- Throws:
- IOException- io
 
- 
attributeDescription copied from interface:XmlSerializerWrite an attribute. Calls to attribute() MUST follow a call to startTag() immediately. If there is no prefix defined for the given namespace, a prefix will be defined automatically. If namespace is null or empty string no namespace prefix is printed but just name.- Specified by:
- attributein interface- XmlSerializer
- Parameters:
- namespace- namespace to use
- name- attribute name
- value- attribute value
- Returns:
- XmlSerializer
- Throws:
- IOException- io
 
- 
closeStartTag- Throws:
- IOException
 
- 
endTagDescription copied from interface:XmlSerializerWrite end tag. Repetition of namespace and name is just for avoiding errors. 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 serializer will make sure that default empty namespace is declared (in XML 1.0 xmlns='').- Specified by:
- endTagin interface- XmlSerializer
- Parameters:
- namespace- ns
- name- tag name
- Returns:
- XmlSerializer
- Throws:
- IOException- io
 
- 
text- Specified by:
- textin interface- XmlSerializer
- Parameters:
- text- Writes text, where special XML chars are escaped automatically
- Returns:
- XmlSerializer
- Throws:
- IOException- io
 
- 
textDescription copied from interface:XmlSerializerWrites text, where special XML chars are escaped automatically- Specified by:
- textin interface- XmlSerializer
- Parameters:
- buf- characters
- start- start
- len- lenght
- Returns:
- XmlSerializer
- Throws:
- IOException- io
 
- 
cdsect- Specified by:
- cdsectin interface- XmlSerializer
- Throws:
- IOException
 
- 
entityRef- Specified by:
- entityRefin interface- XmlSerializer
- Throws:
- IOException
 
- 
processingInstruction- Specified by:
- processingInstructionin interface- XmlSerializer
- Throws:
- IOException
 
- 
comment- Specified by:
- commentin interface- XmlSerializer
- Throws:
- IOException
 
- 
docdecl- Specified by:
- docdeclin interface- XmlSerializer
- Throws:
- IOException
 
- 
ignorableWhitespace- Specified by:
- ignorableWhitespacein interface- XmlSerializer
- Throws:
- IOException
 
- 
flushDescription copied from interface:XmlSerializerWrite all pending output to the stream. If method startTag() or attribute() was called then start tag is closed (final >) before flush() is called on underlying output stream.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("")). - Specified by:
- flushin interface- XmlSerializer
- Throws:
- IOException- io
 
- 
writeAttributeValue- Throws:
- IOException
 
- 
writeElementContent- Throws:
- IOException
 
- 
writeElementContent- Throws:
- IOException
 
- 
printable
- 
printable
 
-