/* * Copyright 2014 - 2017 Blazebit. * * Licensed 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 com.blazebit.persistence.criteria.impl.expression; import com.blazebit.persistence.criteria.impl.BlazeCriteriaBuilderImpl; import com.blazebit.persistence.criteria.impl.ParameterVisitor; import com.blazebit.persistence.criteria.impl.RenderContext; import javax.persistence.criteria.Subquery; import java.io.Serializable; /** * @author Christian Beikov * @since 1.2.0 */ public class QuantifiableSubqueryExpression<Y> extends AbstractExpression<Y> implements Serializable { private static final long serialVersionUID = 1L; public static enum Quantor { ALL { String getOperator() { return "ALL "; } }, SOME { String getOperator() { return "SOME "; } }, ANY { String getOperator() { return "ANY "; } }; abstract String getOperator(); } private final Subquery<Y> subquery; private final Quantor quantor; public QuantifiableSubqueryExpression(BlazeCriteriaBuilderImpl criteriaBuilder, Class<Y> javaType, Subquery<Y> subquery, Quantor modifier) { super(criteriaBuilder, javaType); this.subquery = subquery; this.quantor = modifier; } @Override public void visitParameters(ParameterVisitor visitor) { // no-op } @Override public void render(RenderContext context) { context.getBuffer().append(quantor.getOperator()); context.apply(subquery); } }