Package org.apache.iceberg.expressions
Class ExpressionVisitors
java.lang.Object
org.apache.iceberg.expressions.ExpressionVisitors
Utils for traversing
expressions
.-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
static class
static class
static class
-
Method Summary
Modifier and TypeMethodDescriptionstatic <R> R
visit
(Expression expr, ExpressionVisitors.CustomOrderExpressionVisitor<R> visitor) Traverses the givenexpression
with avisitor
.static <R> R
visit
(Expression expr, ExpressionVisitors.ExpressionVisitor<R> visitor) Traverses the givenexpression
with avisitor
.static Boolean
visitEvaluator
(Expression expr, ExpressionVisitors.ExpressionVisitor<Boolean> visitor) Traverses the givenexpression
with avisitor
.
-
Method Details
-
visit
Traverses the givenexpression
with avisitor
.The visitor will be called to handle each node in the expression tree in postfix order. Result values produced by child nodes are passed when parent nodes are handled.
- Type Parameters:
R
- the return type produced by the expression visitor- Parameters:
expr
- an expression to traversevisitor
- a visitor that will be called to handle each node in the expression tree- Returns:
- the value returned by the visitor for the root expression node
-
visitEvaluator
public static Boolean visitEvaluator(Expression expr, ExpressionVisitors.ExpressionVisitor<Boolean> visitor) Traverses the givenexpression
with avisitor
.The visitor will be called to handle only nodes required for determining result in the expression tree in postfix order. Result values produced by child nodes are passed when parent nodes are handled.
- Parameters:
expr
- an expression to traversevisitor
- a visitor that will be called to handle each node in the expression tree- Returns:
- the value returned by the visitor for the root expression node
-
visit
public static <R> R visit(Expression expr, ExpressionVisitors.CustomOrderExpressionVisitor<R> visitor) Traverses the givenexpression
with avisitor
.This passes a
Supplier
to each non-leafvisitor
method. The supplier returns the result of traversing child expressions. Getting the result of the supplier allows traversing the expression in the desired order.- Type Parameters:
R
- the return type produced by the expression visitor- Parameters:
expr
- an expression to traversevisitor
- a visitor that will be called to handle each node in the expression tree- Returns:
- the value returned by the visitor for the root expression node
-