Class MetaschemaXmlReader
- java.lang.Object
- 
- gov.nist.secauto.metaschema.databind.io.xml.MetaschemaXmlReader
 
- 
- All Implemented Interfaces:
- IParsingContext<org.codehaus.stax2.XMLEventReader2,IXmlProblemHandler>,- IXmlParsingContext
 
 public class MetaschemaXmlReader extends Object implements IXmlParsingContext 
- 
- 
Constructor SummaryConstructors Constructor Description MetaschemaXmlReader(org.codehaus.stax2.XMLEventReader2 reader)Construct a new Module-aware XML parser using the default problem handler.MetaschemaXmlReader(org.codehaus.stax2.XMLEventReader2 reader, IXmlProblemHandler problemHandler)Construct a new Module-aware parser.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description IXmlProblemHandlergetProblemHandler()A handler that provides callbacks used to resolve parsing issues.org.codehaus.stax2.XMLEventReader2getReader()The parser used for reading data associated with the supported format.protected booleanisNextInstance(IBoundNamedModelInstance targetInstance)Determine if the next data to read corresponds to the next model instance.<CLASS> CLASSread(IAssemblyClassBinding targetDefinition)Parses XML into a bound object based on the provideddefinition.<T> TreadDefinitionValue(IClassBinding targetDefinition, Object parentObject, StartElement start)Reads a XML element storing the associated data in a Java class instance, returning the resulting instance.protected voidreadFieldValue(IFieldClassBinding targetDefinition, Object targetObject)Read the XML element and text data described by thetargetDefinitionand apply it to the providedtargetObject.protected voidreadFlagInstances(IClassBinding targetDefinition, Object targetObject, StartElement start)Read the XML attribute data described by thetargetDefinitionand apply it to the providedtargetObject.protected voidreadModelInstances(IAssemblyClassBinding targetDefinition, Object targetObject, StartElement start)Read the XML element data described by thetargetDefinitionand apply it to the providedtargetObject.protected ObjectreadModelInstanceValue(IBoundAssemblyInstance instance, Object parentObject, StartElement start)Read the XML data associated with theinstanceand apply it to the providedparentObject.protected ObjectreadModelInstanceValue(IBoundFieldInstance instance, Object parentObject, StartElement start)Revise<T> TreadModelInstanceValue(IBoundNamedModelInstance instance, Object parentObject, StartElement start)Read the XML data associated with thetargetInstanceand apply it to the providedparentObject.protected booleanreadModelInstanceValues(IBoundNamedModelInstance instance, Object parentObject, StartElement start)Read the data associated with theinstanceand apply it to the providedparentObject.
 
- 
- 
- 
Constructor Detail- 
MetaschemaXmlReaderpublic MetaschemaXmlReader(@NonNull org.codehaus.stax2.XMLEventReader2 reader) Construct a new Module-aware XML parser using the default problem handler.- Parameters:
- reader- the XML reader to parse with
- See Also:
- DefaultXmlProblemHandler
 
 - 
MetaschemaXmlReaderpublic MetaschemaXmlReader(@NonNull org.codehaus.stax2.XMLEventReader2 reader, @NonNull IXmlProblemHandler problemHandler) Construct a new Module-aware parser.- Parameters:
- reader- the XML reader to parse with
- problemHandler- the problem handler implementation to use
 
 
- 
 - 
Method Detail- 
getReaderpublic org.codehaus.stax2.XMLEventReader2 getReader() Description copied from interface:IParsingContextThe parser used for reading data associated with the supported format.- Specified by:
- getReaderin interface- IParsingContext<org.codehaus.stax2.XMLEventReader2,IXmlProblemHandler>
- Returns:
- the parser
 
 - 
getProblemHandlerpublic IXmlProblemHandler getProblemHandler() Description copied from interface:IParsingContextA handler that provides callbacks used to resolve parsing issues.- Specified by:
- getProblemHandlerin interface- IParsingContext<org.codehaus.stax2.XMLEventReader2,IXmlProblemHandler>
- Returns:
- the configured handler
 
 - 
read@NonNull public <CLASS> CLASS read(@NonNull IAssemblyClassBinding targetDefinition) throws IOException, XMLStreamException Parses XML into a bound object based on the provideddefinition.Parses the XMLStreamConstants.START_DOCUMENT, the root element, and theXMLStreamConstants.END_DOCUMENT.- Type Parameters:
- CLASS- the returned object type
- Parameters:
- targetDefinition- the definition describing the root element data to read
- Returns:
- the parsed object
- Throws:
- XMLStreamException- if an error occurred while parsing XML events
- IOException- if an error occurred while parsing the input
 
 - 
readDefinitionValuepublic <T> T readDefinitionValue(IClassBinding targetDefinition, Object parentObject, StartElement start) throws IOException, XMLStreamException Description copied from interface:IXmlParsingContextReads a XML element storing the associated data in a Java class instance, returning the resulting instance.When called the next XMLEventof theXMLStreamReader2is expected to be aXMLStreamConstants.START_ELEMENTthat is the XML element associated with the Java class.After returning the next XMLEventof theXMLStreamReader2is expected to be a the next event after theXMLStreamConstants.END_ELEMENTfor the XMLXMLStreamConstants.START_ELEMENTelement associated with the Java class.- Specified by:
- readDefinitionValuein interface- IXmlParsingContext
- Type Parameters:
- T- the resulting object type
- Parameters:
- targetDefinition- the Module definition that describes the syntax of the data to read
- parentObject- the Java object parent of the target object, which can be- nullif there is no parent
- start- the XML element start and attribute data previously parsed
- Returns:
- the Java object containing the data parsed by this method
- Throws:
- IOException- if an error occurred while parsing the input
- XMLStreamException- if an error occurred while parsing XML events
 
 - 
readFlagInstancesprotected void readFlagInstances(@NonNull IClassBinding targetDefinition, @NonNull Object targetObject, @NonNull StartElement start) throws IOException, XMLStreamException Read the XML attribute data described by thetargetDefinitionand apply it to the providedtargetObject.- Parameters:
- targetDefinition- the Module definition that describes the syntax of the data to read
- targetObject- the Java object that data parsed by this method will be stored in
- start- the containing XML element that was previously parsed
- Throws:
- IOException- if an error occurred while parsing the input
- XMLStreamException- if an error occurred while parsing XML events
 
 - 
readModelInstancesprotected void readModelInstances(@NonNull IAssemblyClassBinding targetDefinition, @NonNull Object targetObject, @NonNull StartElement start) throws IOException, XMLStreamException Read the XML element data described by thetargetDefinitionand apply it to the providedtargetObject.- Parameters:
- targetDefinition- the Module definition that describes the syntax of the data to read
- targetObject- the Java object that data parsed by this method will be stored in
- start- the XML element start and attribute data previously parsed
- Throws:
- IOException- if an error occurred while parsing the input
- XMLStreamException- if an error occurred while parsing XML events
 
 - 
readFieldValueprotected void readFieldValue(@NonNull IFieldClassBinding targetDefinition, @NonNull Object targetObject) throws IOException Read the XML element and text data described by thetargetDefinitionand apply it to the providedtargetObject.- Parameters:
- targetDefinition- the Module definition that describes the syntax of the data to read
- targetObject- the Java object that data parsed by this method will be stored in
- Throws:
- IOException- if an error occurred while parsing the input
 
 - 
isNextInstanceprotected boolean isNextInstance(@NonNull IBoundNamedModelInstance targetInstance) throws XMLStreamException Determine if the next data to read corresponds to the next model instance.- Parameters:
- targetInstance- the model instance that describes the syntax of the data to read
- Returns:
- trueif the Module instance needs to be parsed, or- falseotherwise
- Throws:
- XMLStreamException- if an error occurred while parsing XML events
 
 - 
readModelInstanceValuesprotected boolean readModelInstanceValues(@NonNull IBoundNamedModelInstance instance, @NonNull Object parentObject, @NonNull StartElement start) throws IOException, XMLStreamException Read the data associated with theinstanceand apply it to the providedparentObject.- Parameters:
- instance- the instance to parse data for
- parentObject- the Java object that data parsed by this method will be stored in
- start- the XML element start and attribute data previously parsed
- Returns:
- trueif the instance was parsed, or- falseif the data did not contain information for this instance
- Throws:
- IOException- if an error occurred while parsing the input
- XMLStreamException- if an error occurred while parsing XML events
 
 - 
readModelInstanceValuepublic <T> T readModelInstanceValue(IBoundNamedModelInstance instance, Object parentObject, StartElement start) throws XMLStreamException, IOException Description copied from interface:IXmlParsingContextRead the XML data associated with thetargetInstanceand apply it to the providedparentObject.- Specified by:
- readModelInstanceValuein interface- IXmlParsingContext
- Type Parameters:
- T- the resulting object type
- Parameters:
- instance- the instance to parse data for
- parentObject- the Java object that data parsed by this method will be stored in
- start- the XML element start and attribute data previously parsed
- Returns:
- the Java object read, or nullif no data was read
- Throws:
- XMLStreamException- if an error occurred while parsing XML events
- IOException- if an error occurred while parsing the input
 
 - 
readModelInstanceValue@Nullable protected Object readModelInstanceValue(@NonNull IBoundAssemblyInstance instance, @NonNull Object parentObject, @NonNull StartElement start) throws XMLStreamException, IOException Read the XML data associated with theinstanceand apply it to the providedparentObject.- Parameters:
- instance- the instance to parse data for
- parentObject- the Java object that data parsed by this method will be stored in
- start- the XML element start and attribute data previously parsed
- Returns:
- the Java object read, or nullif no data was read
- Throws:
- IOException- if an error occurred while parsing the input
- XMLStreamException- if an error occurred while parsing XML events
 
 - 
readModelInstanceValue@NonNull protected Object readModelInstanceValue(@NonNull IBoundFieldInstance instance, @NonNull Object parentObject, @NonNull StartElement start) throws XMLStreamException, IOException ReviseReads an individual XML item from the XML stream. - Parameters:
- instance- the instance to parse data for
- parentObject- the Java object that data parsed by this method will be stored in
- start- the XML element start and attribute data previously parsed
- Returns:
- the Java object read, or nullif no data was read
- Throws:
- IOException- if an error occurred while parsing the input
- XMLStreamException- if an error occurred while parsing XML events
 
 
- 
 
-