/**
*
* Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
**/
package lucee.runtime.sql.exp.op;
import java.util.Iterator;
import java.util.List;
import lucee.runtime.sql.exp.Expression;
import lucee.runtime.sql.exp.ExpressionSupport;
public class OperationN extends ExpressionSupport implements Operation {
private String operator;
private List operants;
public OperationN(String operator, List operants) {
this.operator=operator;
this.operants=operants;
}
@Override
public String toString(boolean noAlias) {
if(!hasIndex() || noAlias) {
StringBuffer sb=new StringBuffer();
sb.append(operator);
sb.append('(');
Iterator it = operants.iterator();
boolean isFirst=true;
while(it.hasNext()) {
if(!isFirst)sb.append(',');
Expression exp=(Expression) it.next();
sb.append(exp.toString(!operator.equalsIgnoreCase("cast")));
isFirst=false;
}
sb.append(')');
return sb.toString();
}
return toString(true)+" as "+getAlias();
}
/**
* @return the operants
*/
public Expression[] getOperants() {
if(operants==null) return new Expression[0];
return (Expression[]) operants.toArray(new Expression[operants.size()]);
}
/**
* @return the operator
*/
public String getOperator() {
return operator;
}
}