- All Superinterfaces:
- EventListener
- All Known Implementing Classes:
- CallbackParseListener,- DefaultParseListener
 This listener will be called when syntactic context allows for specific types
 of objects to be parsed. Implementations must return null if
 they are unable to parse anything at the given location, in case of which
 default parser behaviour will apply.
- Author:
- Lukas Eder
- 
Method SummaryModifier and TypeMethodDescriptionstatic CallbackParseListeneronParseCondition(Function<? super ParseContext,? extends Condition> onParseCondition)Create aParseListenerwith aparseCondition(ParseContext)implementation.static CallbackParseListeneronParseField(Function<? super ParseContext,? extends Field<?>> onParseField)Create aParseListenerwith aparseField(ParseContext)implementation.static CallbackParseListeneronParseTable(Function<? super ParseContext,? extends Table<?>> onParseTable)Create aParseListenerwith aparseTable(ParseContext)implementation.@Nullable ConditionparseCondition(ParseContext ctx)Attempt to parse aConditionexpression.@Nullable Field<?>parseField(ParseContext ctx)Attempt to parse aFieldexpression.@Nullable Table<?>parseTable(ParseContext ctx)Attempt to parse aTableexpression.
- 
Method Details- 
parseFieldAttempt to parse aFieldexpression.This parses a "term", meaning the callback does not interfere with any operators or operator precedence, but will be called only when a field term can appear. For example, with input SQL like A + B, the callback is called at the positions ofAandB. Client code does not have to (and should not) handle the+operator, or its precedence.- Returns:
- The Fieldexpression if a field could be parsed, ornullotherwise.
- Throws:
- ParserException- Any syntax error or other exception that may have occurred while attempting to parse a- Fieldexpression.
 
- 
parseTableAttempt to parse aTableexpression.This parses a "table factor", meaning the callback does not interfere with any operators or operator precedence, but will be called only when a condition term can appear. For example, with input SQL like A join B, the callback is called at the positions ofAandB. Client code does not have to (and should not) handle thejoinoperator, or its precedence.- Returns:
- The Tableexpression if a table could be parsed, ornullotherwise.
- Throws:
- ParserException- Any syntax error or other exception that may have occurred while attempting to parse a- Tableexpression.
 
- 
parseConditionAttempt to parse aConditionexpression.This parses a "predicate", meaning the callback does not interfere with any operators or operator precedence, but will be called only when a condition term can appear. For example, with input SQL like A or B, the callback is called at the positions ofAandB. Client code does not have to (and should not) handle theoroperator, or its precedence.- Returns:
- The Conditionexpression if a condition could be parsed, ornullotherwise.
- Throws:
- ParserException- Any syntax error or other exception that may have occurred while attempting to parse a- Conditionexpression.
 
- 
onParseFieldstatic CallbackParseListener onParseField(Function<? super ParseContext,? extends Field<?>> onParseField)Create aParseListenerwith aparseField(ParseContext)implementation.
- 
onParseTablestatic CallbackParseListener onParseTable(Function<? super ParseContext,? extends Table<?>> onParseTable)Create aParseListenerwith aparseTable(ParseContext)implementation.
- 
onParseConditionstatic CallbackParseListener onParseCondition(Function<? super ParseContext,? extends Condition> onParseCondition)Create aParseListenerwith aparseCondition(ParseContext)implementation.
 
-