org.eclipse.persistence.internal.jpa.querydef.FunctionExpressionImpl Maven / Gradle / Ivy
Show all versions of eclipselink Show documentation
/*******************************************************************************
* Copyright (c) 2011, 2013 Oracle and/or its affiliates. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Gordon Yorke - Initial development
*
******************************************************************************/
package org.eclipse.persistence.internal.jpa.querydef;
import java.util.ArrayList;
import java.util.List;
import javax.persistence.criteria.Expression;
import javax.persistence.metamodel.Metamodel;
/**
*
* Purpose: Contains the implementation of the Predicate interface of the JPA
* criteria API.
*
* Description: The predicate forms the least specific expression node. Predicates
* result in boolean expressions that are combined to form the final expression.
*
*
* @see javax.persistence.criteria Predicate
*
* @author gyorke
* @since EclipseLink 1.2
*/
public class FunctionExpressionImpl extends ExpressionImpl{
protected String operator;
protected List expressions;
protected FunctionExpressionImpl (Metamodel metamodel, Class resultClass, org.eclipse.persistence.expressions.Expression expressionNode, List> compoundExpressions){
super(metamodel, resultClass, expressionNode);
if (compoundExpressions != null){
this.expressions = compoundExpressions;
}else{
this.expressions = new ArrayList();
}
}
public FunctionExpressionImpl (Metamodel metamodel, Class resultClass, org.eclipse.persistence.expressions.Expression expressionNode, List> compoundExpressions, String operator){
this(metamodel, resultClass, expressionNode, compoundExpressions);
this.operator = operator;
}
/**
* Return the top-level conjuncts or disjuncts of the predicate.
*
* @return list boolean expressions forming the predicate
*/
public List> getChildExpressions(){
return expressions;
}
/**
* @return the operator
*/
public String getOperation() {
return operator;
}
@Override
public boolean isCompoundExpression(){
return true;
}
@Override
public boolean isExpression(){
return false;
}
public void findRootAndParameters(CommonAbstractCriteriaImpl query){
if (this.expressions != null){
for (Object exp : this.expressions){
((InternalSelection)exp).findRootAndParameters(query);
}
}
}
}