Package org.eclipse.rdf4j.rio.rdfxml
Class RDFXMLParser
- java.lang.Object
- 
- org.eclipse.rdf4j.rio.helpers.AbstractRDFParser
- 
- org.eclipse.rdf4j.rio.helpers.XMLReaderBasedParser
- 
- org.eclipse.rdf4j.rio.rdfxml.RDFXMLParser
 
 
 
- 
- All Implemented Interfaces:
- RDFParser,- ErrorHandler
 
 public class RDFXMLParser extends XMLReaderBasedParser implements ErrorHandler A parser for XML-serialized RDF. This parser operates directly on the SAX events generated by a SAX-enabled XML parser. The XML parser should be compliant with SAX2. You should specify which SAX parser should be used by setting theorg.xml.sax.driverproperty. This parser is not thread-safe, therefore it's public methods are synchronized.To parse a document using this parser: - Create an instance of RDFXMLParser, optionally supplying it with your own ValueFactory.
- Set the RDFHandler.
- Optionally, set the ParseErrorListener and/or ParseLocationListener.
- Optionally, specify whether the parser should verify the data it parses and whether it should stop immediately when it finds an error in the data (both default to true).
- Call the parse method.
 // Use the SAX2-compliant Xerces parser: System.setProperty("org.xml.sax.driver", "org.apache.xerces.parsers.SAXParser"); RDFParser parser = new RDFXMLParser(); parser.setRDFHandler(myRDFHandler); parser.setParseErrorListener(myParseErrorListener); parser.setVerifyData(true); parser.stopAtFirstError(false); // Parse the data from inputStream, resolving any // relative URIs against http://foo/bar: parser.parse(inputStream, "http://foo/bar");Note that JAXP entity expansion limits may apply. Check the documentation on limits and using the jaxp.properties file if you get one of the following errors: JAXP00010001: The parser has encountered more than "64000" entity expansions in this document JAXP00010004: The accumulated size of entities is ... that exceeded the "50,000,000" limit As a work-around, try passing -Djdk.xml.totalEntitySizeLimit=0 -DentityExpansionLimit=0to the JVM.- Author:
- Arjohn Kampman
- See Also:
- ValueFactory,- RDFHandler,- ParseErrorListener,- ParseLocationListener
 
- 
- 
Field Summary- 
Fields inherited from class org.eclipse.rdf4j.rio.helpers.AbstractRDFParserrdfHandler, valueFactory
 
- 
 - 
Constructor SummaryConstructors Constructor Description RDFXMLParser()Creates a new RDFXMLParser that will use aSimpleValueFactoryto create RDF model objects.RDFXMLParser(ValueFactory valueFactory)Creates a new RDFXMLParser that will use the supplied ValueFactory to create RDF model objects.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected LiteralcreateLiteral(String label, String lang, IRI datatype)Creates aLiteralobject with the supplied parameters.protected ResourcecreateNode(String nodeID)voiderror(SAXParseException exception)Implementation of SAX ErrorHandler.errorvoidfatalError(SAXParseException exception)Implementation of SAX ErrorHandler.fatalErrorbooleangetParseStandAloneDocuments()Returns whether the parser is currently in a mode to parse stand-alone RDF documents.RDFFormatgetRDFFormat()Gets the RDF format that this parser can parse.SAXResultgetSAXResult(String baseURI)Collection<RioSetting<?>>getSupportedSettings()voidparse(InputStream in, String baseURI)Parses the data from the supplied InputStream, using the supplied baseURI to resolve any relative URI references.voidparse(Reader reader, String baseURI)Parses the data from the supplied Reader, using the supplied baseURI to resolve any relative URI references.protected voidreportError(Exception e, RioSetting<Boolean> setting)OverridesAbstractRDFParser.reportError(String, RioSetting), adding line- and column number information to the error.protected voidreportError(String msg, RioSetting<Boolean> setting)OverridesAbstractRDFParser.reportError(String, RioSetting), adding line- and column number information to the error.protected voidreportFatalError(Exception e)OverridesAbstractRDFParser.reportFatalError(Exception), adding line- and column number information to the error.protected voidreportFatalError(String msg)OverridesAbstractRDFParser.reportFatalError(String), adding line- and column number information to the error.protected voidreportWarning(String msg)OverridesAbstractRDFParser.reportWarning(String), adding line- and column number information to the error.protected voidsetBaseURI(String baseURI)Parses the supplied URI-string and sets it as the base URI for resolving relative URIs.protected voidsetBaseURI(ParsedIRI baseURI)Sets the base URI for resolving relative URIs.voidsetParseStandAloneDocuments(boolean standAloneDocs)Sets the parser in a mode to parse stand-alone RDF documents.voidwarning(SAXParseException exception)Implementation of SAX ErrorHandler.warning- 
Methods inherited from class org.eclipse.rdf4j.rio.helpers.XMLReaderBasedParsergetCompulsoryXmlFeatureSettings, getCompulsoryXmlPropertySettings, getOptionalXmlFeatureSettings, getOptionalXmlPropertySettings, getXMLReader
 - 
Methods inherited from class org.eclipse.rdf4j.rio.helpers.AbstractRDFParserclear, clearBNodeIDMap, createBNode, createBNode, createLiteral, createNode, createStatement, createStatement, createURI, getNamespace, getParseErrorListener, getParseLocationListener, getParserConfig, getRDFHandler, initializeNamespaceTableFromConfiguration, preserveBNodeIDs, reportError, reportError, reportError, reportFatalError, reportFatalError, reportFatalError, reportLocation, reportWarning, resolveURI, set, setNamespace, setParseErrorListener, setParseLocationListener, setParserConfig, setPreserveBNodeIDs, setRDFHandler, setValueFactory
 
- 
 
- 
- 
- 
Constructor Detail- 
RDFXMLParserpublic RDFXMLParser() Creates a new RDFXMLParser that will use aSimpleValueFactoryto create RDF model objects.
 - 
RDFXMLParserpublic RDFXMLParser(ValueFactory valueFactory) Creates a new RDFXMLParser that will use the supplied ValueFactory to create RDF model objects.- Parameters:
- valueFactory- A ValueFactory.
 
 
- 
 - 
Method Detail- 
getRDFFormatpublic final RDFFormat getRDFFormat() Description copied from interface:RDFParserGets the RDF format that this parser can parse.- Specified by:
- getRDFFormatin interface- RDFParser
 
 - 
setParseStandAloneDocumentspublic void setParseStandAloneDocuments(boolean standAloneDocs) Sets the parser in a mode to parse stand-alone RDF documents. In stand-alone RDF documents, the enclosing rdf:RDF root element is optional if this root element contains just one element (e.g. rdf:Description.
 - 
getParseStandAloneDocumentspublic boolean getParseStandAloneDocuments() Returns whether the parser is currently in a mode to parse stand-alone RDF documents.- See Also:
- setParseStandAloneDocuments(boolean)
 
 - 
parsepublic void parse(InputStream in, String baseURI) throws IOException, RDFParseException, RDFHandlerException Description copied from interface:RDFParserParses the data from the supplied InputStream, using the supplied baseURI to resolve any relative URI references.- Specified by:
- parsein interface- RDFParser
- Parameters:
- in- The InputStream from which to read the data.
- baseURI- The URI associated with the data in the InputStream. May be- null. Parsers for syntax formats that do not support relative URIs will ignore this argument.- Note that if the data contains an embedded base URI, that embedded base URI will overrule the value supplied here (see RFC 3986 section 5.1 for details). 
- Throws:
- IOException- If an I/O error occurred while data was read from the InputStream.
- RDFParseException- If the parser has found an unrecoverable parse error.
- RDFHandlerException- If the configured statement handler has encountered an unrecoverable error.
 
 - 
parsepublic void parse(Reader reader, String baseURI) throws IOException, RDFParseException, RDFHandlerException Description copied from interface:RDFParserParses the data from the supplied Reader, using the supplied baseURI to resolve any relative URI references.- Specified by:
- parsein interface- RDFParser
- Parameters:
- reader- The Reader from which to read the data.
- baseURI- The URI associated with the data in the InputStream. May be- null. Parsers for syntax formats that do not support relative URIs will ignore this argument.- Note that if the data contains an embedded base URI, that embedded base URI will overrule the value supplied here (see RFC 3986 section 5.1 for details). 
- Throws:
- IOException- If an I/O error occurred while data was read from the InputStream.
- RDFParseException- If the parser has found an unrecoverable parse error.
- RDFHandlerException- If the configured statement handler has encountered an unrecoverable error.
 
 - 
getSupportedSettingspublic Collection<RioSetting<?>> getSupportedSettings() - Specified by:
- getSupportedSettingsin interface- RDFParser
- Overrides:
- getSupportedSettingsin class- AbstractRDFParser
- Returns:
- A collection of RioSettings that are supported by this RDFParser.
 
 - 
setBaseURIprotected void setBaseURI(ParsedIRI baseURI) Description copied from class:AbstractRDFParserSets the base URI for resolving relative URIs.- Overrides:
- setBaseURIin class- AbstractRDFParser
 
 - 
setBaseURIprotected void setBaseURI(String baseURI) Description copied from class:AbstractRDFParserParses the supplied URI-string and sets it as the base URI for resolving relative URIs.- Overrides:
- setBaseURIin class- AbstractRDFParser
 
 - 
createNodeprotected Resource createNode(String nodeID) throws RDFParseException Description copied from class:AbstractRDFParser- Overrides:
- createNodein class- AbstractRDFParser
- Parameters:
- nodeID- node identifier
- Returns:
- blank node or skolem IRI
- Throws:
- RDFParseException
 
 - 
createLiteralprotected Literal createLiteral(String label, String lang, IRI datatype) throws RDFParseException Description copied from class:AbstractRDFParserCreates aLiteralobject with the supplied parameters.- Overrides:
- createLiteralin class- AbstractRDFParser
- Throws:
- RDFParseException
 
 - 
reportWarningprotected void reportWarning(String msg) OverridesAbstractRDFParser.reportWarning(String), adding line- and column number information to the error.- Overrides:
- reportWarningin class- AbstractRDFParser
 
 - 
reportErrorprotected void reportError(String msg, RioSetting<Boolean> setting) throws RDFParseException OverridesAbstractRDFParser.reportError(String, RioSetting), adding line- and column number information to the error.- Overrides:
- reportErrorin class- AbstractRDFParser
- Parameters:
- msg- The message to use for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- setting- The boolean setting that will be checked to determine if this is an issue that we need to look at at all. If this setting is true, then the error listener will receive the error, and if- ParserConfig.isNonFatalError(RioSetting)returns true an exception will be thrown.
- Throws:
- RDFParseException- If- RioConfig.get(RioSetting)returns true, and- ParserConfig.isNonFatalError(RioSetting)returns true for the given setting.
 
 - 
reportErrorprotected void reportError(Exception e, RioSetting<Boolean> setting) throws RDFParseException OverridesAbstractRDFParser.reportError(String, RioSetting), adding line- and column number information to the error.- Overrides:
- reportErrorin class- AbstractRDFParser
- Parameters:
- e- The exception whose message will be used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- setting- The boolean setting that will be checked to determine if this is an issue that we need to look at at all. If this setting is true, then the error listener will receive the error, and if- ParserConfig.isNonFatalError(RioSetting)returns true an exception will be thrown.
- Throws:
- RDFParseException- If- RioConfig.get(RioSetting)returns true, and- ParserConfig.isNonFatalError(RioSetting)returns true for the given setting.
 
 - 
reportFatalErrorprotected void reportFatalError(String msg) throws RDFParseException OverridesAbstractRDFParser.reportFatalError(String), adding line- and column number information to the error.- Overrides:
- reportFatalErrorin class- AbstractRDFParser
- Throws:
- RDFParseException
 
 - 
reportFatalErrorprotected void reportFatalError(Exception e) throws RDFParseException OverridesAbstractRDFParser.reportFatalError(Exception), adding line- and column number information to the error.- Overrides:
- reportFatalErrorin class- AbstractRDFParser
- Throws:
- RDFParseException
 
 - 
warningpublic void warning(SAXParseException exception) throws SAXException Implementation of SAX ErrorHandler.warning- Specified by:
- warningin interface- ErrorHandler
- Throws:
- SAXException
 
 - 
errorpublic void error(SAXParseException exception) throws SAXException Implementation of SAX ErrorHandler.error- Specified by:
- errorin interface- ErrorHandler
- Throws:
- SAXException
 
 - 
fatalErrorpublic void fatalError(SAXParseException exception) throws SAXException Implementation of SAX ErrorHandler.fatalError- Specified by:
- fatalErrorin interface- ErrorHandler
- Throws:
- SAXException
 
 
- 
 
-