Package org.jibx.runtime.impl
Class MarshallingContext
- java.lang.Object
-
- org.jibx.runtime.impl.MarshallingContext
-
- All Implemented Interfaces:
IMarshallingContext
public class MarshallingContext extends Object implements IMarshallingContext
JiBX serializer supplying convenience methods for marshalling. Most of these methods are designed for use in code generated by the binding generator.- Author:
- Dennis M. Sosnoski
-
-
Field Summary
Fields Modifier and Type Field Description protected Objectm_userContextUser context object (not used by JiBX, only for user convenience).static StringXML_NAMESPACEFixed XML namespace.
-
Constructor Summary
Constructors Constructor Description MarshallingContext(String[] classes, String[] mcs, String[] uris, IBindingFactory ifact)Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddMarshalling(String mapname, String name)Define marshalling for class.MarshallingContextattribute(int index, String name, int value)Generate integer attribute.MarshallingContextattribute(int index, String name, int value, String[] table)Generate enumeration attribute.MarshallingContextattribute(int index, String name, String value)Generate text attribute.StringbuildNameString(int index, String name)Build name with optional namespace.MarshallingContextcloseStartContent()Close start tag with content to follow.MarshallingContextcloseStartEmpty()Close start tag with no content (empty tag).MarshallingContextcontent(int value)Add integer content to current element.MarshallingContextcontent(int value, String[] table)Add enumeration content to current element.MarshallingContextcontent(String value)Add text content to current element.MarshallingContextelement(int index, String name, int value)Generate complete element with integer content.MarshallingContextelement(int index, String name, int value, String[] table)Generate complete element with enumeration content.MarshallingContextelement(int index, String name, String value)Generate complete element with text content.voidendDocument()End document.MarshallingContextendTag(int index, String name)Generate end tag for element.IBindingFactorygetFactory()Return the binding factory used to create this unmarshaller.HashMapgetIdMap()Get shared ID map.intgetIndent()Get current nesting indent spaces.IMarshallergetMarshaller(String mapname)Find the marshaller for a particular class index in the current context.String[]getNamespaces()Get namespace URIs for mapping.intgetStackDepth()Get current marshalling object stack depth.ObjectgetStackObject(int depth)Get object from marshalling stack.ObjectgetStackTop()Get top object on marshalling stack.ObjectgetUserContext()Get the user context object.IXMLWritergetXmlWriter()Get the writer being used for output.MarshallingContextmarshalCollection(ArrayList col)Marshal all items in a collection.MarshallingContextmarshalCollection(Collection col)Marshal all items in a collection.MarshallingContextmarshalCollection(Vector col)Marshal all items in a collection.voidmarshalDocument(Object root)Marshal document from root object without XML declaration.voidmarshalDocument(Object root, String enc, Boolean alone)Marshal document from root object.voidmarshalDocument(Object root, String enc, Boolean alone, OutputStream outs)Marshal document from root object to output stream with encoding.voidmarshalDocument(Object root, String enc, Boolean alone, Writer outw)Marshal document from root object to writer.protected voidmarshalRoot(Object root)Marshal document from root object.voidpopNamespaces()End use of namespace indexes from a separate binding.voidpopObject()Pop marshalled object from stack.voidpushNamespaces(String factname)Use namespace indexes from a separate binding, as identified by that binding's factory class name.voidpushObject(Object obj)Push created object to marshalling stack.voidremoveMarshalling(String mapname)Undefine marshalling for element.voidreset()Reset to initial state for reuse.voidsetFromContext(MarshallingContext parent)Initializes the context to use the same marshalled text destination and parameters as another marshalling context.voidsetIndent(int count)Set nesting indent spaces.voidsetIndent(int count, String newline, char indent)Set nesting indentation.voidsetOutput(OutputStream outs, String enc)Set output stream and encoding.voidsetOutput(OutputStream outs, String enc, ICharacterEscaper esc)Set output stream with encoding and escaper.voidsetOutput(Writer outw)Set output writer.voidsetOutput(Writer outw, ICharacterEscaper esc)Set output writer and escaper.voidsetUserContext(Object obj)Set a user context object.voidsetXmlWriter(IXMLWriter xwrite)Set the writer being used for output.voidstartDocument(String enc, Boolean alone)Start document.voidstartDocument(String enc, Boolean alone, OutputStream outs)Start document with output stream and encoding.voidstartDocument(String enc, Boolean alone, Writer outw)Start document with writer.MarshallingContextstartTag(int index, String name)Generate start tag for element without attributes.MarshallingContextstartTagAttributes(int index, String name)Generate start tag for element with attributes.MarshallingContextstartTagNamespaces(int index, String name, int[] nums, String[] prefs)Generate start tag for element with namespaces.MarshallingContextwriteCData(String text)Write CDATA text to document.MarshallingContextwriteContent(String text)Write content value with character entity substitutions.
-
-
-
Field Detail
-
XML_NAMESPACE
public static final String XML_NAMESPACE
Fixed XML namespace.- See Also:
- Constant Field Values
-
m_userContext
protected Object m_userContext
User context object (not used by JiBX, only for user convenience).
-
-
Constructor Detail
-
MarshallingContext
public MarshallingContext(String[] classes, String[] mcs, String[] uris, IBindingFactory ifact)
Constructor.- Parameters:
classes- ordered array of class names included in mapping definition (reference kept, must be constant)mcs- names of marshaller classes for indexes with fixed marshallers (as opposed to mapping slots, which may be overridden; reference kept, must be constant)uris- ordered array of URIs for namespaces used in binding (must be constant; the value in position 0 must always be the empty string "", and the value in position 1 must always be the XML namespace "http://www.w3.org/XML/1998/namespace")ifact- binding factory creating this unmarshaller
-
-
Method Detail
-
setOutput
public void setOutput(OutputStream outs, String enc, ICharacterEscaper esc) throws JiBXException
Set output stream with encoding and escaper. This forces handling of the output stream to use the Java character encoding support with the supplied escaper.- Specified by:
setOutputin interfaceIMarshallingContext- Parameters:
outs- stream for document data outputenc- document output encoding, ornulluses UTF-8 defaultesc- escaper for writing characters to stream- Throws:
JiBXException- if error setting output
-
setOutput
public void setOutput(OutputStream outs, String enc) throws JiBXException
Set output stream and encoding. This uses the standard escaper for the specified encoding.- Specified by:
setOutputin interfaceIMarshallingContext- Parameters:
outs- stream for document data outputenc- document output encoding, ornullfor default- Throws:
JiBXException- if error creating setting output
-
setOutput
public void setOutput(Writer outw, ICharacterEscaper esc)
Set output writer and escaper.- Specified by:
setOutputin interfaceIMarshallingContext- Parameters:
outw- writer for document data outputesc- escaper for writing characters
-
setOutput
public void setOutput(Writer outw)
Set output writer.- Specified by:
setOutputin interfaceIMarshallingContext- Parameters:
outw- writer for document data output
-
getXmlWriter
public IXMLWriter getXmlWriter()
Get the writer being used for output.- Specified by:
getXmlWriterin interfaceIMarshallingContext- Returns:
- XML writer used for output
-
setXmlWriter
public void setXmlWriter(IXMLWriter xwrite)
Set the writer being used for output.- Specified by:
setXmlWriterin interfaceIMarshallingContext- Parameters:
xwrite- XML writer used for output
-
getIndent
public int getIndent()
Get current nesting indent spaces. This returns the number of spaces used to show indenting, if used.- Specified by:
getIndentin interfaceIMarshallingContext- Returns:
- number of spaces indented per level, or negative if indentation disabled
-
setIndent
public void setIndent(int count)
Set nesting indent spaces. This is advisory only, and implementations of this interface are free to ignore it. The intent is to indicate that the generated output should use indenting to illustrate element nesting.- Specified by:
setIndentin interfaceIMarshallingContext- Parameters:
count- number of spaces to indent per level, or disable indentation if negative
-
setIndent
public void setIndent(int count, String newline, char indent)Set nesting indentation. This is advisory only, and implementations of this interface are free to ignore it. The intent is to indicate that the generated output should use indenting to illustrate element nesting.- Specified by:
setIndentin interfaceIMarshallingContext- Parameters:
count- number of character to indent per level, or disable indentation if negative (zero means new line only)newline- sequence of characters used for a line ending (nullmeans use the single character '\n')indent- whitespace character used for indentation
-
setFromContext
public void setFromContext(MarshallingContext parent) throws IOException
Initializes the context to use the same marshalled text destination and parameters as another marshalling context. This method is designed for use when an initial context needs to create and invoke a secondary context (generally from a different binding) in the course of an marshalling operation. Note that once the secondary context has been used it's generally necessary to do aXMLWriterBase.flush()operation on the writer used by the that context before resuming output on the parent.- Parameters:
parent- context supplying target for marshalled document text- Throws:
IOException- on error writing output
-
reset
public void reset()
Reset to initial state for reuse. The context is serially reusable, as long as this method is called to clear any retained state information between uses. It is automatically called when output is set.- Specified by:
resetin interfaceIMarshallingContext
-
getFactory
public IBindingFactory getFactory()
Return the binding factory used to create this unmarshaller.- Returns:
- binding factory
-
getNamespaces
public String[] getNamespaces()
Get namespace URIs for mapping. This gets the full ordered array of namespaces known in the binding used for this marshalling, where the index number of each namespace URI is the namespace index used to lookup the prefix when marshalling a name in that namespace. The returned array must not be modified.- Returns:
- array of namespaces
-
startDocument
public void startDocument(String enc, Boolean alone) throws JiBXException
Start document. This can only be validly called immediately following one of the set output methods; otherwise the output document will be corrupt.- Specified by:
startDocumentin interfaceIMarshallingContext- Parameters:
enc- document encoding,nullif not specifiedalone- standalone document flag,nullif not specified- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
startDocument
public void startDocument(String enc, Boolean alone, OutputStream outs) throws JiBXException
Start document with output stream and encoding. The effect is the same as from first setting the output stream and encoding, then making the call to start document.- Specified by:
startDocumentin interfaceIMarshallingContext- Parameters:
enc- document encoding,nullif not specifiedalone- standalone document flag,nullif not specifiedouts- stream for document data output- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
startDocument
public void startDocument(String enc, Boolean alone, Writer outw) throws JiBXException
Start document with writer. The effect is the same as from first setting the writer, then making the call to start document.- Specified by:
startDocumentin interfaceIMarshallingContext- Parameters:
enc- document encoding,nullif not specifiedalone- standalone document flag,nullif not specifiedoutw- writer for document data output- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
endDocument
public void endDocument() throws JiBXExceptionEnd document. Finishes all output and closes the document. Note that if this is called with an imcomplete marshalling the result will not be well-formed XML.- Specified by:
endDocumentin interfaceIMarshallingContext- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
buildNameString
public String buildNameString(int index, String name)
Build name with optional namespace. Just returns the appropriate name format.- Parameters:
index- namespace URI index numbername- local name part of name- Returns:
- formatted name string
-
startTag
public MarshallingContext startTag(int index, String name) throws JiBXException
Generate start tag for element without attributes.- Parameters:
index- namespace URI index numbername- element name- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
startTagAttributes
public MarshallingContext startTagAttributes(int index, String name) throws JiBXException
Generate start tag for element with attributes. This only opens the start tag, allowing attributes to be added immediately following this call.- Parameters:
index- namespace URI index numbername- element name- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
attribute
public MarshallingContext attribute(int index, String name, String value) throws JiBXException
Generate text attribute. This can only be used following an open start tag with attributes.- Parameters:
index- namespace URI index numbername- attribute namevalue- text value for attribute (cannot benull)- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
attribute
public MarshallingContext attribute(int index, String name, int value) throws JiBXException
Generate integer attribute. This can only be used following an open start tag.- Parameters:
index- namespace URI index numbername- attribute namevalue- integer value for attribute- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
attribute
public MarshallingContext attribute(int index, String name, int value, String[] table) throws JiBXException
Generate enumeration attribute. The actual text to be written is obtained by indexing into the supplied array of values. This can only be used following an open start tag.- Parameters:
index- namespace URI index numbername- attribute namevalue- integer enumeration value (zero-based)table- text values in enumeration- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
closeStartContent
public MarshallingContext closeStartContent() throws JiBXException
Close start tag with content to follow.- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
closeStartEmpty
public MarshallingContext closeStartEmpty() throws JiBXException
Close start tag with no content (empty tag).- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
content
public MarshallingContext content(String value) throws JiBXException
Add text content to current element.- Parameters:
value- text element content- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
content
public MarshallingContext content(int value) throws JiBXException
Add integer content to current element.- Parameters:
value- integer element content- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
content
public MarshallingContext content(int value, String[] table) throws JiBXException
Add enumeration content to current element. The actual text to be written is obtained by indexing into the supplied array of values.- Parameters:
value- integer enumeration value (zero-based)table- text values in enumeration- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
endTag
public MarshallingContext endTag(int index, String name) throws JiBXException
Generate end tag for element.- Parameters:
index- namespace URI index numbername- element name- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
element
public MarshallingContext element(int index, String name, String value) throws JiBXException
Generate complete element with text content.- Parameters:
index- namespace URI index numbername- element namevalue- text element content- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
element
public MarshallingContext element(int index, String name, int value) throws JiBXException
Generate complete element with integer content.- Parameters:
index- namespace URI index numbername- element namevalue- integer element content- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
element
public MarshallingContext element(int index, String name, int value, String[] table) throws JiBXException
Generate complete element with enumeration content. The actual text to be written is obtained by indexing into the supplied array of values.- Parameters:
index- namespace URI index numbername- element namevalue- integer enumeration value (zero-based)table- text values in enumeration- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
writeCData
public MarshallingContext writeCData(String text) throws IOException
Write CDATA text to document.- Parameters:
text- content value text- Returns:
- this context (to allow chained calls)
- Throws:
IOException- on error writing to document
-
writeContent
public MarshallingContext writeContent(String text) throws IOException
Write content value with character entity substitutions.- Parameters:
text- content value text- Returns:
- this context (to allow chained calls)
- Throws:
IOException- on error writing to document
-
marshalCollection
public MarshallingContext marshalCollection(Collection col) throws JiBXException
Marshal all items in a collection. This variation is for generic collections.- Parameters:
col- collection of items to be marshalled- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalCollection
public MarshallingContext marshalCollection(ArrayList col) throws JiBXException
Marshal all items in a collection. This variation is for ArrayList collections.- Parameters:
col- collection of items to be marshalled- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalCollection
public MarshallingContext marshalCollection(Vector col) throws JiBXException
Marshal all items in a collection. This variation is for Vector collections.- Parameters:
col- collection of items to be marshalled- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
addMarshalling
public void addMarshalling(String mapname, String name) throws JiBXException
Define marshalling for class. Adds the marshalling definition for a particular mapping name.- Parameters:
mapname- mapping name associated with unmarshallername- marshaller class name handling- Throws:
JiBXException- if unknown mapping name
-
removeMarshalling
public void removeMarshalling(String mapname) throws JiBXException
Undefine marshalling for element. Removes the marshalling definition for a particular mapping name.- Parameters:
mapname- mapping name associated with unmarshaller- Throws:
JiBXException- if unknown mapping name
-
startTagNamespaces
public MarshallingContext startTagNamespaces(int index, String name, int[] nums, String[] prefs) throws JiBXException
Generate start tag for element with namespaces. This creates the actual start tag, along with any necessary namespace declarations. Previously active namespace declarations are not duplicated. The tag is left incomplete, allowing other attributes to be added. TODO: Handle nested default namespaces declarations, prefixes for outers- Parameters:
index- namespace URI index numbername- element namenums- array of namespace indexes defined by this element (must be constant, reference is kept until end of element)prefs- array of namespace prefixes mapped by this element (nonullvalues, use "" for default namespace declaration)- Returns:
- this context (to allow chained calls)
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
getMarshaller
public IMarshaller getMarshaller(String mapname) throws JiBXException
Find the marshaller for a particular class index in the current context.- Specified by:
getMarshallerin interfaceIMarshallingContext- Parameters:
mapname- marshaller mapping name (generally the class name to be handled, or abstract mapping type name)- Returns:
- marshalling handler for class
- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalRoot
protected void marshalRoot(Object root) throws JiBXException
Marshal document from root object. This internal method just verifies that the object is marshallable, then calls the marshal method on the object itself.- Parameters:
root- object at root of structure to be marshalled, which must have a top-level mapping in the binding- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalDocument
public void marshalDocument(Object root) throws JiBXException
Marshal document from root object without XML declaration. This can only be validly called immediately following one of the set output methods; otherwise the output document will be corrupt. The effect of this method is the same as the sequence of a call to marshal the root object using this context followed by a call toendDocument().- Specified by:
marshalDocumentin interfaceIMarshallingContext- Parameters:
root- object at root of structure to be marshalled, which must have a top-level mapping in the binding- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalDocument
public void marshalDocument(Object root, String enc, Boolean alone) throws JiBXException
Marshal document from root object. This can only be validly called immediately following one of the set output methods; otherwise the output document will be corrupt. The effect of this method is the same as the sequence of a call tostartDocument(java.lang.String, java.lang.Boolean), a call to marshal the root object using this context, and finally a call toendDocument().- Specified by:
marshalDocumentin interfaceIMarshallingContext- Parameters:
root- object at root of structure to be marshalled, which must have a top-level mapping in the bindingenc- document encoding,nullif not specifiedalone- standalone document flag,nullif not specified- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalDocument
public void marshalDocument(Object root, String enc, Boolean alone, OutputStream outs) throws JiBXException
Marshal document from root object to output stream with encoding. The effect of this method is the same as the sequence of a call tostartDocument(java.lang.String, java.lang.Boolean), a call to marshal the root object using this context, and finally a call toendDocument().- Specified by:
marshalDocumentin interfaceIMarshallingContext- Parameters:
root- object at root of structure to be marshalled, which must have a top-level mapping in the bindingenc- document encoding,nullif not specifiedalone- standalone document flag,nullif not specifiedouts- stream for document data output- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
marshalDocument
public void marshalDocument(Object root, String enc, Boolean alone, Writer outw) throws JiBXException
Marshal document from root object to writer. The effect of this method is the same as the sequence of a call tostartDocument(java.lang.String, java.lang.Boolean), a call to marshal the root object using this context, and finally a call toendDocument().- Specified by:
marshalDocumentin interfaceIMarshallingContext- Parameters:
root- object at root of structure to be marshalled, which must have a top-level mapping in the bindingenc- document encoding,nullif not specifiedalone- standalone document flag,nullif not specifiedoutw- writer for document data output- Throws:
JiBXException- on any error (possibly wrapping other exception)
-
pushNamespaces
public void pushNamespaces(String factname)
Use namespace indexes from a separate binding, as identified by that binding's factory class name. The target binding must be a precompiled base binding of the binding used to create this marshalling context, either directly or by way of some other precompiled base binding(s).- Specified by:
pushNamespacesin interfaceIMarshallingContext- Parameters:
factname- binding factory class name for binding defining namespaces
-
popNamespaces
public void popNamespaces()
End use of namespace indexes from a separate binding. This will undo the effect of the most-recent call topushNamespaces(String), restoring whatever namespace usage was in effect prior to that call.- Specified by:
popNamespacesin interfaceIMarshallingContext
-
getIdMap
public HashMap getIdMap()
Get shared ID map. The ID map returned is not used directly by the marshalling code, but is provided to support user extensions.- Returns:
- ID map
-
setUserContext
public void setUserContext(Object obj)
Set a user context object. This context object is not used directly by JiBX, but can be accessed by all types of user extension methods. The context object is automatically cleared by thereset()method, so to make use of this you need to first call the appropriate version of thesetOutput()method, then this method, and finally one of themarshalDocumentmethods which uses the previously-set output (not the ones which take a stream or writer as parameter, since they callsetOutput()themselves).- Specified by:
setUserContextin interfaceIMarshallingContext- Parameters:
obj- user context object, ornullif clearing existing context object- See Also:
getUserContext()
-
getUserContext
public Object getUserContext()
Get the user context object.- Specified by:
getUserContextin interfaceIMarshallingContext- Returns:
- user context object, or
nullif no context object set - See Also:
setUserContext(Object)
-
pushObject
public void pushObject(Object obj)
Push created object to marshalling stack. This must be called before beginning the marshalling of the object. It is only called for objects with structure, not for those converted directly to and from text.- Specified by:
pushObjectin interfaceIMarshallingContext- Parameters:
obj- object being marshalled
-
popObject
public void popObject() throws JiBXExceptionPop marshalled object from stack.- Specified by:
popObjectin interfaceIMarshallingContext- Throws:
JiBXException- if no object on stack
-
getStackDepth
public int getStackDepth()
Get current marshalling object stack depth. This allows tracking nested calls to marshal one object while in the process of marshalling another object. The bottom item on the stack is always the root object being marshalled.- Specified by:
getStackDepthin interfaceIMarshallingContext- Returns:
- number of objects in marshalling stack
-
getStackObject
public Object getStackObject(int depth)
Get object from marshalling stack. This stack allows tracking nested calls to marshal one object while in the process of marshalling another object. The bottom item on the stack is always the root object being marshalled.- Specified by:
getStackObjectin interfaceIMarshallingContext- Parameters:
depth- object depth in stack to be retrieved (must be in the range of zero to the current depth minus one).- Returns:
- object from marshalling stack
-
getStackTop
public Object getStackTop()
Get top object on marshalling stack. This is safe to call even when no objects are on the stack.- Specified by:
getStackTopin interfaceIMarshallingContext- Returns:
- object from marshalling stack, or
nullif none
-
-