Class XmlFieldFormat
- java.lang.Object
-
- org.beanio.internal.parser.format.xml.XmlFieldFormat
-
- All Implemented Interfaces:
FieldFormat
,XmlNode
- Direct Known Subclasses:
XmlAttributeField
,XmlElementField
,XmlTextField
public abstract class XmlFieldFormat extends java.lang.Object implements FieldFormat, XmlNode
Base class for XMLFieldFormat
implementations.- Since:
- 2.0
-
-
Field Summary
-
Fields inherited from interface org.beanio.internal.parser.format.xml.XmlNode
XML_TYPE_ATTRIBUTE, XML_TYPE_ELEMENT, XML_TYPE_NONE, XML_TYPE_TEXT
-
-
Constructor Summary
Constructors Constructor Description XmlFieldFormat()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description java.lang.String
extract(UnmarshallingContext context, boolean reportErrors)
Extracts the field text from a record.protected abstract java.lang.String
extractText(XmlUnmarshallingContext context)
Extracts a field from a record during unmarshalling.java.lang.String
getName()
Returns the field name.FieldPadding
getPadding()
Returns the field padding, or null if the field text is not padded.int
getSize()
Returns the size of the field.void
insertField(MarshallingContext context, java.lang.String fieldText)
Inserts field text into a record.protected abstract void
insertText(XmlMarshallingContext context, java.lang.String text)
Inserts a field into the record during marshalling.boolean
insertValue(MarshallingContext context, java.lang.Object value)
Inserts a value into a record.boolean
isLazy()
TODO rename isLazy to something better?? Returns whether this field is optionally present in the record.void
setLazy(boolean lazy)
void
setName(java.lang.String name)
Sets the field name.void
setPadding(FieldPadding padding)
Sets the field padding.protected void
toParamString(java.lang.StringBuilder s)
Called bytoString()
to append attributes of this field.java.lang.String
toString()
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.beanio.internal.parser.FieldFormat
isNillable
-
Methods inherited from interface org.beanio.internal.parser.format.xml.XmlNode
getLocalName, getNamespace, getPrefix, getType, isNamespaceAware, isNillable, isRepeating
-
-
-
-
Method Detail
-
insertValue
public boolean insertValue(MarshallingContext context, java.lang.Object value)
Description copied from interface:FieldFormat
Inserts a value into a record. This method is called before type conversion. If the method returns false, type conversion is invoked andFieldFormat.insertField(MarshallingContext, String)
is called. If the method returns true,FieldFormat.insertField(MarshallingContext, String)
is not invoked.- Specified by:
insertValue
in interfaceFieldFormat
- Parameters:
context
- theMarshallingContext
value
- the value to insert into the record- Returns:
- true if type conversion is required and
FieldFormat.insertField(MarshallingContext, String)
must be invoked, false otherwise
-
insertField
public void insertField(MarshallingContext context, java.lang.String fieldText)
Description copied from interface:FieldFormat
Inserts field text into a record.- Specified by:
insertField
in interfaceFieldFormat
- Parameters:
context
- theMarshallingContext
holding the recordfieldText
- the field text to insert into the record
-
insertText
protected abstract void insertText(XmlMarshallingContext context, java.lang.String text)
Inserts a field into the record during marshalling.- Parameters:
context
- theXmlMarshallingContext
holding the recordtext
- the field text to insert
-
extract
public java.lang.String extract(UnmarshallingContext context, boolean reportErrors)
Description copied from interface:FieldFormat
Extracts the field text from a record. Returnsnull
if the field was not present in the record.May return
Value.INVALID
if the field is invalid, orValue.NIL
if the field is explicitly set to nil or null such as in an XML or JSON formatted stream.Implementations should also remove any field padding before returning the text.
- Specified by:
extract
in interfaceFieldFormat
- Parameters:
context
- theUnmarshallingContext
holding the record- Returns:
- the field text
-
extractText
protected abstract java.lang.String extractText(XmlUnmarshallingContext context)
Extracts a field from a record during unmarshalling.- Parameters:
context
- theXmlUnmarshallingContext
holding the record- Returns:
- the extracted field text
-
getSize
public int getSize()
Description copied from interface:FieldFormat
Returns the size of the field. Fixed length formats should return the field length, while other formats should simply return 1.- Specified by:
getSize
in interfaceFieldFormat
- Returns:
- the size of the field
-
getName
public java.lang.String getName()
Returns the field name.- Returns:
- the field name
-
setName
public void setName(java.lang.String name)
Sets the field name.- Parameters:
name
- the field name
-
isLazy
public boolean isLazy()
Description copied from interface:FieldFormat
TODO rename isLazy to something better?? Returns whether this field is optionally present in the record.- Specified by:
isLazy
in interfaceFieldFormat
- Returns:
- true if lazy, false otherwise
-
setLazy
public void setLazy(boolean lazy)
-
getPadding
public FieldPadding getPadding()
Returns the field padding, or null if the field text is not padded.- Returns:
- the field padding or null
-
setPadding
public void setPadding(FieldPadding padding)
Sets the field padding.- Parameters:
padding
- the field padding
-
toParamString
protected void toParamString(java.lang.StringBuilder s)
Called bytoString()
to append attributes of this field.- Parameters:
s
- the text to append
-
toString
public java.lang.String toString()
- Overrides:
toString
in classjava.lang.Object
-
-