org.apache.hudi.expression.Predicates Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.hudi.expression;
import org.apache.hudi.internal.schema.Type;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
public class Predicates {
public static TrueExpression alwaysTrue() {
return TrueExpression.get();
}
public static FalseExpression alwaysFalse() {
return FalseExpression.get();
}
public static And and(Expression left, Expression right) {
return new And(left, right);
}
public static Or or(Expression left, Expression right) {
return new Or(left, right);
}
public static BinaryComparison gt(Expression left, Expression right) {
return new BinaryComparison(left, Expression.Operator.GT, right);
}
public static BinaryComparison lt(Expression left, Expression right) {
return new BinaryComparison(left, Expression.Operator.LT, right);
}
public static BinaryComparison eq(Expression left, Expression right) {
return new BinaryComparison(left, Expression.Operator.EQ, right);
}
public static BinaryComparison gteq(Expression left, Expression right) {
return new BinaryComparison(left, Expression.Operator.GT_EQ, right);
}
public static BinaryComparison lteq(Expression left, Expression right) {
return new BinaryComparison(left, Expression.Operator.LT_EQ, right);
}
public static StringStartsWith startsWith(Expression left, Expression right) {
return new StringStartsWith(left, right);
}
public static StringContains contains(Expression left, Expression right) {
return new StringContains(left, right);
}
public static In in(Expression left, List validExpressions) {
return new In(left, validExpressions);
}
public static IsNull isNull(Expression child) {
return new IsNull(child);
}
public static IsNotNull isNotNull(Expression child) {
return new IsNotNull(child);
}
public static Not not(Expression expr) {
return new Not(expr);
}
public static class TrueExpression extends LeafExpression implements Predicate {
private static final TrueExpression INSTANCE = new TrueExpression();
public static TrueExpression get() {
return INSTANCE;
}
@Override
public Boolean eval(StructLike data) {
return true;
}
@Override
public Operator getOperator() {
return Operator.TRUE;
}
@Override
public T accept(ExpressionVisitor exprVisitor) {
return exprVisitor.alwaysTrue();
}
@Override
public String toString() {
return "TRUE";
}
}
public static class FalseExpression extends LeafExpression implements Predicate {
private static final FalseExpression INSTANCE = new FalseExpression();
public static FalseExpression get() {
return INSTANCE;
}
@Override
public Boolean eval(StructLike data) {
return false;
}
@Override
public Operator getOperator() {
return Operator.FALSE;
}
@Override
public T accept(ExpressionVisitor exprVisitor) {
return exprVisitor.alwaysFalse();
}
@Override
public String toString() {
return "FALSE";
}
}
public static class And extends BinaryExpression implements Predicate {
public And(Expression left, Expression right) {
super(left, Operator.AND, right);
}
@Override
public Boolean eval(StructLike data) {
if (getLeft() instanceof FalseExpression || getRight() instanceof FalseExpression) {
return false;
}
Object left = getLeft().eval(data);
if (left != null && !(Boolean) left) {
return false;
} else {
Object right = getRight().eval(data);
if (right != null && !(Boolean) right) {
return false;
} else {
if (left != null && right != null) {
return true;
} else {
return false;
}
}
}
}
@Override
public T accept(ExpressionVisitor exprVisitor) {
return exprVisitor.visitAnd(this);
}
@Override
public String toString() {
return "(" + getLeft() + " " + getOperator().symbol + " " + getRight() + ")";
}
}
public static class Or extends BinaryExpression implements Predicate {
public Or(Expression left, Expression right) {
super(left, Operator.OR, right);
}
@Override
public Boolean eval(StructLike data) {
if (getLeft() instanceof TrueExpression || getRight() instanceof TrueExpression) {
return true;
}
Object left = getLeft().eval(data);
if (left == null) {
return false;
}
if ((Boolean) left) {
return true;
} else {
Object right = getRight().eval(data);
return right != null && (Boolean) right;
}
}
@Override
public T accept(ExpressionVisitor exprVisitor) {
return exprVisitor.visitOr(this);
}
@Override
public String toString() {
return "(" + getLeft() + " " + getOperator().symbol + " " + getRight() + ")";
}
}
public static class StringStartsWith extends BinaryExpression implements Predicate {
StringStartsWith(Expression left, Expression right) {
super(left, Operator.STARTS_WITH, right);
}
@Override
public String toString() {
return getLeft().toString() + ".startWith(" + getRight().toString() + ")";
}
@Override
public Object eval(StructLike data) {
return getLeft().eval(data).toString().startsWith(getRight().eval(data).toString());
}
}
public static class StringContains extends BinaryExpression implements Predicate {
StringContains(Expression left, Expression right) {
super(left, Operator.CONTAINS, right);
}
@Override
public String toString() {
return getLeft().toString() + ".contains(" + getRight().toString() + ")";
}
@Override
public Object eval(StructLike data) {
return getLeft().eval(data).toString().contains(getRight().eval(data).toString());
}
}
public static class In implements Predicate {
protected final Expression value;
protected final List validValues;
public In(Expression value, List validValues) {
this.value = value;
this.validValues = validValues;
}
@Override
public List getChildren() {
ArrayList children = new ArrayList<>(validValues.size() + 1);
children.add(value);
children.addAll(validValues);
return children;
}
@Override
public Boolean eval(StructLike data) {
Set
© 2015 - 2025 Weber Informatics LLC | Privacy Policy