Package org.eclipse.rdf4j.rio.helpers
Class RDFParserHelper
java.lang.Object
org.eclipse.rdf4j.rio.helpers.RDFParserHelper
Helper methods that may be used by 
RDFParser implementations.
 
 This class contains reference implementations of the workflows for ParseErrorListener,
 RDFParseException, ParserConfig, DatatypeHandler and LanguageHandler related methods
- Author:
- Peter Ansell
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedProtected constructor to prevent direct instantiation.
- 
Method SummaryModifier and TypeMethodDescriptionstatic final LiteralcreateLiteral(String label, String lang, IRI datatype, ParserConfig parserConfig, ParseErrorListener errListener, ValueFactory valueFactory) Create a literal using the given parameters, including iterative verification and normalization by anyDatatypeHandlerorLanguageHandlerimplementations that are found in theParserConfig.static LiteralcreateLiteral(String label, String lang, IRI datatype, ParserConfig parserConfig, ParseErrorListener errListener, ValueFactory valueFactory, long lineNo, long columnNo) Create a literal using the given parameters, including iterative verification and normalization by anyDatatypeHandlerorLanguageHandlerimplementations that are found in theParserConfig.static voidreportError(Exception e, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting, ParserConfig parserConfig, ParseErrorListener errListener) Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.static voidreportError(String msg, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting, ParserConfig parserConfig, ParseErrorListener errListener) Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.static voidreportError(String msg, RioSetting<Boolean> relevantSetting, ParserConfig parserConfig, ParseErrorListener errListener) Reports an error with associated line- and column number to the registered ParseErrorListener, if the given setting has been set to true.static voidreportFatalError(Exception e, long lineNo, long columnNo, ParseErrorListener errListener) 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.static voidreportFatalError(Exception e, ParseErrorListener errListener) Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards.static voidreportFatalError(String msg, long lineNo, long columnNo, ParseErrorListener errListener) Reports a fatal error with associated line- and column number to the registered ParseErrorListener, if any, and throws a ParseException afterwards.static voidreportFatalError(String message, Exception e, long lineNo, long columnNo, ParseErrorListener errListener) 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.static voidreportFatalError(String msg, ParseErrorListener errListener) Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards.
- 
Constructor Details- 
RDFParserHelperprotected RDFParserHelper()Protected constructor to prevent direct instantiation.
 
- 
- 
Method Details- 
createLiteralpublic static final Literal createLiteral(String label, String lang, IRI datatype, ParserConfig parserConfig, ParseErrorListener errListener, ValueFactory valueFactory) throws RDFParseException Create a literal using the given parameters, including iterative verification and normalization by anyDatatypeHandlerorLanguageHandlerimplementations that are found in theParserConfig.- Parameters:
- label- The value for- Literal.getLabel(), which may be iteratively normalized.
- lang- If this is not null, and the datatype is either not null, or is equal to- RDF.LANGSTRING, then a language literal will be created.
- datatype- If datatype is not null, and the datatype is not equal to- RDF.LANGSTRINGwith a non-null lang, then a datatype literal will be created.
- parserConfig- The source of parser settings, including the desired list of- DatatypeHandlerand- LanguageHandlers to use for verification and normalization of datatype and language literals respectively.
- errListener- The- ParseErrorListenerto use for signalling errors. This will be called if a setting is enabled by setting it to true in the- ParserConfig, after which the error may trigger an- RDFParseExceptionif the setting is not present in- ParserConfig.getNonFatalErrors().
- valueFactory- The- ValueFactoryto use for creating new- Literals using this method.
- Returns:
- A Literalcreated based on the given parameters.
- Throws:
- RDFParseException- If there was an error during the process that could not be recovered from, based on settings in the given parser config.
 
- 
createLiteralpublic static Literal createLiteral(String label, String lang, IRI datatype, ParserConfig parserConfig, ParseErrorListener errListener, ValueFactory valueFactory, long lineNo, long columnNo) throws RDFParseException Create a literal using the given parameters, including iterative verification and normalization by anyDatatypeHandlerorLanguageHandlerimplementations that are found in theParserConfig.- Parameters:
- label- The value for- Literal.getLabel(), which may be iteratively normalized.
- lang- If this is not null, and the datatype is either not null, or is equal to- RDF.LANGSTRING, then a language literal will be created.
- datatype- If datatype is not null, and the datatype is not equal to- RDF.LANGSTRINGwith a non-null lang, then a datatype literal will be created.
- parserConfig- The source of parser settings, including the desired list of- DatatypeHandlerand- LanguageHandlers to use for verification and normalization of datatype and language literals respectively.
- errListener- The- ParseErrorListenerto use for signalling errors. This will be called if a setting is enabled by setting it to true in the- ParserConfig, after which the error may trigger an- RDFParseExceptionif the setting is not present in- ParserConfig.getNonFatalErrors().
- valueFactory- The- ValueFactoryto use for creating new- Literals using this method.
- 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).
- Returns:
- A Literalcreated based on the given parameters.
- Throws:
- RDFParseException- If there was an error during the process that could not be recovered from, based on settings in the given parser config.
 
- 
reportErrorpublic static void reportError(String msg, RioSetting<Boolean> relevantSetting, ParserConfig parserConfig, ParseErrorListener errListener) 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.
- parserConfig- The- ParserConfigto use for determining if the error is first sent to the ParseErrorListener, and whether it is then also non-fatal to avoid throwing an- RDFParseException.
- errListener- The- ParseErrorListenerthat will be sent messages about errors that are enabled.
- Throws:
- RDFParseException- If- RioConfig.get(RioSetting)returns true, and- ParserConfig.isNonFatalError(RioSetting)returns true for the given setting.
 
- 
reportErrorpublic static void reportError(String msg, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting, ParserConfig parserConfig, ParseErrorListener errListener) 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.
- parserConfig- The- ParserConfigto use for determining if the error is first sent to the ParseErrorListener, and whether it is then also non-fatal to avoid throwing an- RDFParseException.
- errListener- The- ParseErrorListenerthat will be sent messages about errors that are enabled.
- Throws:
- RDFParseException- If- RioConfig.get(RioSetting)returns true, and- ParserConfig.isNonFatalError(RioSetting)returns true for the given setting.
 
- 
reportErrorpublic static void reportError(Exception e, long lineNo, long columnNo, RioSetting<Boolean> relevantSetting, ParserConfig parserConfig, ParseErrorListener errListener) 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 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.
- parserConfig- The- ParserConfigto use for determining if the error is first sent to the ParseErrorListener, and whether it is then also non-fatal to avoid throwing an- RDFParseException.
- errListener- The- ParseErrorListenerthat will be sent messages about errors that are enabled.
- Throws:
- RDFParseException- If- RioConfig.get(RioSetting)returns true, and- ParserConfig.isNonFatalError(RioSetting)returns true for the given setting.
 
- 
reportFatalErrorpublic static void reportFatalError(String msg, ParseErrorListener errListener) throws RDFParseException Reports a fatal error to the registered ParseErrorListener, if any, and throws a ParseException afterwards. This method simply callsreportFatalError(String, long, long, ParseErrorListener)supplying -1 for the line- and column number.- Throws:
- RDFParseException
 
- 
reportFatalErrorpublic static void reportFatalError(String msg, long lineNo, long columnNo, ParseErrorListener errListener) 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
 
- 
reportFatalErrorpublic static void reportFatalError(Exception e, ParseErrorListener errListener) 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, ParseErrorListener)supplying -1 for the line- and column number.- Throws:
- RDFParseException
 
- 
reportFatalErrorpublic static void reportFatalError(Exception e, long lineNo, long columnNo, ParseErrorListener errListener) 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
 
- 
reportFatalErrorpublic static void reportFatalError(String message, Exception e, long lineNo, long columnNo, ParseErrorListener errListener) 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
 
 
-