Package org.eclipse.rdf4j.rio.helpers
Class AbstractRDFParser
- java.lang.Object
- 
- org.eclipse.rdf4j.rio.helpers.AbstractRDFParser
 
- 
- All Implemented Interfaces:
- RDFParser
 - Direct Known Subclasses:
- BinaryRDFParser,- HDTParser,- JSONLDParser,- NTriplesParser,- RDFJSONParser,- TurtleParser,- XMLReaderBasedParser
 
 public abstract class AbstractRDFParser extends Object implements RDFParser Base class forRDFParsers offering common functionality for RDF parsers.- Author:
- Arjohn Kampman
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected RDFHandlerrdfHandlerThe RDFHandler that will handle the parsed RDF.protected ValueFactoryvalueFactoryThe ValueFactory to use for creating RDF model objects.
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedAbstractRDFParser()Creates a new RDFParserBase that will use aSimpleValueFactoryto create RDF model objects.protectedAbstractRDFParser(ValueFactory valueFactory)Creates a new RDFParserBase that will use the supplied ValueFactory to create RDF model objects.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected voidclear()Clears any information that has been collected while parsing.protected voidclearBNodeIDMap()Deprecated.Map is no longer used, callclear()instead.protected BNodecreateBNode()Deprecated.protected BNodecreateBNode(String nodeID)Deprecated.protected LiteralcreateLiteral(String label, String lang, IRI datatype)Creates aLiteralobject with the supplied parameters.protected LiteralcreateLiteral(String label, String lang, IRI datatype, long lineNo, long columnNo)Creates aLiteralobject with the supplied parameters, using the lineNo and columnNo to enhance error messages or exceptions that may be generated during the creation of the literal.protected ResourcecreateNode()protected ResourcecreateNode(String nodeID)protected StatementcreateStatement(Resource subj, IRI pred, Value obj)Creates a newStatementobject with the supplied components.protected StatementcreateStatement(Resource subj, IRI pred, Value obj, Resource context)Creates a newStatementobject with the supplied components.protected IRIcreateURI(String uri)Creates aIRIobject for the specified URI-string.protected StringgetNamespace(String prefix)Gets the namespace that is associated with the specified prefix or throws anRDFParseException.ParseErrorListenergetParseErrorListener()ParseLocationListenergetParseLocationListener()ParserConfiggetParserConfig()Retrieves the current parser configuration as a single object.RDFHandlergetRDFHandler()Collection<RioSetting<?>>getSupportedSettings()protected voidinitializeNamespaceTableFromConfiguration()booleanpreserveBNodeIDs()protected voidreportError(Exception e, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting)Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.protected voidreportError(Exception e, RioSetting<Boolean> relevantSetting)Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.protected voidreportError(String msg, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting)Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.protected voidreportError(String msg, Exception e, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting)Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.protected voidreportError(String msg, RioSetting<Boolean> relevantSetting)Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.protected voidreportFatalError(Exception e)Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards.protected voidreportFatalError(Exception e, long lineNo, long columnNo)Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException wrapped the supplied exception afterwards.protected voidreportFatalError(String msg)Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards.protected voidreportFatalError(String msg, long lineNo, long columnNo)Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException afterwards.protected voidreportFatalError(String message, Exception e, long lineNo, long columnNo)Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException wrapped the supplied exception afterwards.protected voidreportLocation(long lineNo, long columnNo)Reports the specified line- and column number to the registeredParseLocationListener, if any.protected voidreportWarning(String msg)Reports a warning to the registered ParseErrorListener, if any.protected voidreportWarning(String msg, long lineNo, long columnNo)Reports a warning with associated line- and column number to the registered ParseErrorListener, if any.protected IRIresolveURI(String uriSpec)Resolves a URI-string against the base URI and creates aIRIobject for it.<T> RDFParserset(RioSetting<T> setting, T value)Set a setting on the parser, and return this parser object to allow chaining.protected voidsetBaseURI(String uriSpec)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.protected voidsetNamespace(String prefix, String namespace)Associates the specified prefix to the specified namespace.RDFParsersetParseErrorListener(ParseErrorListener el)Sets the ParseErrorListener that will be notified of any errors that this parser finds during parsing.RDFParsersetParseLocationListener(ParseLocationListener el)Sets the ParseLocationListener that will be notified of the parser's progress during the parse process.RDFParsersetParserConfig(ParserConfig config)Sets all supplied parser configuration options.voidsetPreserveBNodeIDs(boolean preserveBNodeIDs)Set whether the parser should preserve bnode identifiers specified in the source (default is false).RDFParsersetRDFHandler(RDFHandler handler)Sets the RDFHandler that will handle the parsed RDF data.RDFParsersetValueFactory(ValueFactory valueFactory)Sets the ValueFactory that the parser will use to create Value objects for the parsed RDF data.
 
- 
- 
- 
Field Detail- 
rdfHandlerprotected RDFHandler rdfHandler The RDFHandler that will handle the parsed RDF.
 - 
valueFactoryprotected ValueFactory valueFactory The ValueFactory to use for creating RDF model objects.
 
- 
 - 
Constructor Detail- 
AbstractRDFParserprotected AbstractRDFParser() Creates a new RDFParserBase that will use aSimpleValueFactoryto create RDF model objects.
 - 
AbstractRDFParserprotected AbstractRDFParser(ValueFactory valueFactory) Creates a new RDFParserBase that will use the supplied ValueFactory to create RDF model objects.- Parameters:
- valueFactory- A ValueFactory.
 
 
- 
 - 
Method Detail- 
setValueFactorypublic RDFParser setValueFactory(ValueFactory valueFactory) Description copied from interface:RDFParserSets the ValueFactory that the parser will use to create Value objects for the parsed RDF data.- Specified by:
- setValueFactoryin interface- RDFParser
- Parameters:
- valueFactory- The value factory that the parser should use.
- Returns:
- Either a copy of this parser, if it is immutable, or this object, to allow chaining of method calls.
 
 - 
setRDFHandlerpublic RDFParser setRDFHandler(RDFHandler handler) Description copied from interface:RDFParserSets the RDFHandler that will handle the parsed RDF data.- Specified by:
- setRDFHandlerin interface- RDFParser
- Parameters:
- handler- The RDFHandler to handle the parsed data.
- Returns:
- Either a copy of this parser, if it is immutable, or this object, to allow chaining of method calls.
 
 - 
getRDFHandlerpublic RDFHandler getRDFHandler() 
 - 
setParseErrorListenerpublic RDFParser setParseErrorListener(ParseErrorListener el) Description copied from interface:RDFParserSets the ParseErrorListener that will be notified of any errors that this parser finds during parsing.- Specified by:
- setParseErrorListenerin interface- RDFParser
- Parameters:
- el- The ParseErrorListener that will be notified of errors or warnings.
- Returns:
- Either a copy of this parser, if it is immutable, or this object, to allow chaining of method calls.
 
 - 
getParseErrorListenerpublic ParseErrorListener getParseErrorListener() 
 - 
setParseLocationListenerpublic RDFParser setParseLocationListener(ParseLocationListener el) Description copied from interface:RDFParserSets the ParseLocationListener that will be notified of the parser's progress during the parse process.- Specified by:
- setParseLocationListenerin interface- RDFParser
- Parameters:
- el- The ParseLocationListener that will be notified of the parser's progress.
- Returns:
- Either a copy of this parser, if it is immutable, or this object, to allow chaining of method calls.
 
 - 
getParseLocationListenerpublic ParseLocationListener getParseLocationListener() 
 - 
setParserConfigpublic RDFParser setParserConfig(ParserConfig config) Description copied from interface:RDFParserSets all supplied parser configuration options.- Specified by:
- setParserConfigin interface- RDFParser
- Parameters:
- config- a parser configuration object.
- Returns:
- Either a copy of this parser, if it is immutable, or this object, to allow chaining of method calls.
 
 - 
getParserConfigpublic ParserConfig getParserConfig() Description copied from interface:RDFParserRetrieves the current parser configuration as a single object.- Specified by:
- getParserConfigin interface- RDFParser
- Returns:
- a parser configuration object representing the current configuration of the parser.
 
 - 
getSupportedSettingspublic Collection<RioSetting<?>> getSupportedSettings() - Specified by:
- getSupportedSettingsin interface- RDFParser
- Returns:
- A collection of RioSettings that are supported by this RDFParser.
 
 - 
setpublic <T> RDFParser set(RioSetting<T> setting, T value) Description copied from interface:RDFParserSet a setting on the parser, and return this parser object to allow chaining.
 - 
setPreserveBNodeIDspublic void setPreserveBNodeIDs(boolean preserveBNodeIDs) Description copied from interface:RDFParserSet whether the parser should preserve bnode identifiers specified in the source (default is false).- Specified by:
- setPreserveBNodeIDsin interface- RDFParser
 
 - 
preserveBNodeIDspublic boolean preserveBNodeIDs() 
 - 
setBaseURIprotected void setBaseURI(String uriSpec) Parses the supplied URI-string and sets it as the base URI for resolving relative URIs.
 - 
setBaseURIprotected void setBaseURI(ParsedIRI baseURI) Sets the base URI for resolving relative URIs.
 - 
setNamespaceprotected void setNamespace(String prefix, String namespace) Associates the specified prefix to the specified namespace.
 - 
getNamespaceprotected String getNamespace(String prefix) throws RDFParseException Gets the namespace that is associated with the specified prefix or throws anRDFParseException.- Throws:
- RDFParseException- if no namespace is associated with this prefix
 
 - 
clearprotected void clear() Clears any information that has been collected while parsing. This method must be called by subclasses when finishing the parse process.
 - 
initializeNamespaceTableFromConfigurationprotected void initializeNamespaceTableFromConfiguration() 
 - 
clearBNodeIDMap@Deprecated protected void clearBNodeIDMap() Deprecated.Map is no longer used, callclear()instead.Clears the map that keeps track of blank nodes that have been parsed. Normally, this map is clear when the document has been parsed completely, but subclasses can clear the map at other moments too, for example when a bnode scope ends.
 - 
resolveURIprotected IRI resolveURI(String uriSpec) throws RDFParseException Resolves a URI-string against the base URI and creates aIRIobject for it.- Throws:
- RDFParseException
 
 - 
createURIprotected IRI createURI(String uri) throws RDFParseException Creates aIRIobject for the specified URI-string.- Throws:
- RDFParseException
 
 - 
createNodeprotected Resource createNode() throws RDFParseException - Returns:
- blank node or skolem IRI
- Throws:
- RDFParseException
 
 - 
createNodeprotected Resource createNode(String nodeID) throws RDFParseException - Parameters:
- nodeID- node identifier
- Returns:
- blank node or skolem IRI
- Throws:
- RDFParseException
 
 - 
createBNode@Deprecated protected BNode createBNode() throws RDFParseException Deprecated.Creates a newBNodeobject.- Throws:
- RDFParseException
 
 - 
createBNode@Deprecated protected BNode createBNode(String nodeID) throws RDFParseException Deprecated.Creates aBNodeobject for the specified identifier.- Throws:
- RDFParseException
 
 - 
createLiteralprotected Literal createLiteral(String label, String lang, IRI datatype) throws RDFParseException Creates aLiteralobject with the supplied parameters.- Throws:
- RDFParseException
 
 - 
createLiteralprotected Literal createLiteral(String label, String lang, IRI datatype, long lineNo, long columnNo) throws RDFParseException Creates aLiteralobject with the supplied parameters, using the lineNo and columnNo to enhance error messages or exceptions that may be generated during the creation of the literal.
 - 
createStatementprotected Statement createStatement(Resource subj, IRI pred, Value obj) throws RDFParseException Creates a newStatementobject with the supplied components.- Throws:
- RDFParseException
 
 - 
createStatementprotected Statement createStatement(Resource subj, IRI pred, Value obj, Resource context) throws RDFParseException Creates a newStatementobject with the supplied components.- Throws:
- RDFParseException
 
 - 
reportLocationprotected void reportLocation(long lineNo, long columnNo)Reports the specified line- and column number to the registeredParseLocationListener, if any.
 - 
reportWarningprotected void reportWarning(String msg) Reports a warning to the registered ParseErrorListener, if any. This method simply callsreportWarning(String, long, long)supplying -1 for the line- and column number.
 - 
reportWarningprotected void reportWarning(String msg, long lineNo, long columnNo) Reports a warning with associated line- and column number to the registered ParseErrorListener, if any.
 - 
reportErrorprotected void reportError(String msg, RioSetting<Boolean> relevantSetting) throws RDFParseException Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.This method also throws an RDFParseExceptionwhen the given setting has been set to true and it is not a nonFatalError.- Parameters:
- msg- The message to use for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- relevantSetting- 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(String msg, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting) throws RDFParseException Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.This method also throws an RDFParseExceptionwhen the given setting has been set to true and it is not a nonFatalError.- Parameters:
- msg- The message to use for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- lineNo- Optional line number, should default to setting this as -1 if not known. Used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- columnNo- Optional column number, should default to setting this as -1 if not known. Used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- relevantSetting- 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> relevantSetting) throws RDFParseException Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.This method also throws an RDFParseExceptionwhen the given setting has been set to true and it is not a nonFatalError.- Parameters:
- e- The exception whose message will be used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- relevantSetting- 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, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting) throws RDFParseException Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.This method also throws an RDFParseExceptionwhen the given setting has been set to true and it is not a nonFatalError.- Parameters:
- e- The exception whose message will be used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- lineNo- Optional line number, should default to setting this as -1 if not known. Used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- columnNo- Optional column number, should default to setting this as -1 if not known. Used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- relevantSetting- 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(String msg, Exception e, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting) throws RDFParseException Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.This method also throws an RDFParseExceptionwhen the given setting has been set to true and it is not a nonFatalError.- Parameters:
- msg- The message to use for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- e- The exception whose message will be used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- lineNo- Optional line number, should default to setting this as -1 if not known. Used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- columnNo- Optional column number, should default to setting this as -1 if not known. Used for- ParseErrorListener.error(String, long, long)and for- RDFParseException(String, long, long).
- relevantSetting- 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 Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards. This method simply callsreportFatalError(String, long, long)supplying -1 for the line- and column number.- Throws:
- RDFParseException
 
 - 
reportFatalErrorprotected void reportFatalError(String msg, long lineNo, long columnNo) throws RDFParseException Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException afterwards.- Throws:
- RDFParseException
 
 - 
reportFatalErrorprotected void reportFatalError(Exception e) throws RDFParseException Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards. An exception is made for the case where the supplied exception is aRDFParseException; in that case the supplied exception is not wrapped in another ParseException and the error message is not reported to the ParseErrorListener, assuming that it has already been reported when the original ParseException was thrown.This method simply calls reportFatalError(Exception, long, long)supplying -1 for the line- and column number.- Throws:
- RDFParseException
 
 - 
reportFatalErrorprotected void reportFatalError(Exception e, long lineNo, long columnNo) throws RDFParseException Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException wrapped the supplied exception afterwards. An exception is made for the case where the supplied exception is aRDFParseException; in that case the supplied exception is not wrapped in another ParseException and the error message is not reported to the ParseErrorListener, assuming that it has already been reported when the original ParseException was thrown.- Throws:
- RDFParseException
 
 - 
reportFatalErrorprotected void reportFatalError(String message, Exception e, long lineNo, long columnNo) throws RDFParseException Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException wrapped the supplied exception afterwards. An exception is made for the case where the supplied exception is aRDFParseException; in that case the supplied exception is not wrapped in another ParseException and the error message is not reported to the ParseErrorListener, assuming that it has already been reported when the original ParseException was thrown.- Throws:
- RDFParseException
 
 
- 
 
-