com.hazelcast.org.apache.calcite.sql.fun.SqlCase 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 com.hazelcast.org.apache.calcite.sql.fun;
import com.hazelcast.org.apache.calcite.sql.SqlCall;
import com.hazelcast.org.apache.calcite.sql.SqlKind;
import com.hazelcast.org.apache.calcite.sql.SqlLiteral;
import com.hazelcast.org.apache.calcite.sql.SqlNode;
import com.hazelcast.org.apache.calcite.sql.SqlNodeList;
import com.hazelcast.org.apache.calcite.sql.SqlOperator;
import com.hazelcast.org.apache.calcite.sql.parser.SqlParserPos;
import com.hazelcast.org.apache.calcite.util.UnmodifiableArrayList;
import java.util.List;
/**
* A SqlCase
is a node of a parse tree which represents a case
* statement. It warrants its own node type just because we have a lot of
* methods to put somewhere.
*/
public class SqlCase extends SqlCall {
SqlNode value;
SqlNodeList whenList;
SqlNodeList thenList;
SqlNode elseExpr;
//~ Constructors -----------------------------------------------------------
/**
* Creates a SqlCase expression.
*
* @param pos Parser position
* @param value The value (null for boolean case)
* @param whenList List of all WHEN expressions
* @param thenList List of all THEN expressions
* @param elseExpr The implicit or explicit ELSE expression
*/
public SqlCase(SqlParserPos pos, SqlNode value, SqlNodeList whenList,
SqlNodeList thenList, SqlNode elseExpr) {
super(pos);
this.value = value;
this.whenList = whenList;
this.thenList = thenList;
this.elseExpr = elseExpr;
}
/**
* Creates a call to the switched form of the case operator, viz:
*
* CASE value
* WHEN whenList[0] THEN thenList[0]
* WHEN whenList[1] THEN thenList[1]
* ...
* ELSE elseClause
* END
*/
public static SqlCase createSwitched(SqlParserPos pos, SqlNode value,
SqlNodeList whenList, SqlNodeList thenList, SqlNode elseClause) {
if (null != value) {
List list = whenList.getList();
for (int i = 0; i < list.size(); i++) {
SqlNode e = list.get(i);
final SqlCall call;
if (e instanceof SqlNodeList) {
call = SqlStdOperatorTable.IN.createCall(pos, value, e);
} else {
call = SqlStdOperatorTable.EQUALS.createCall(pos, value, e);
}
list.set(i, call);
}
}
if (null == elseClause) {
elseClause = SqlLiteral.createNull(pos);
}
return new SqlCase(pos, null, whenList, thenList, elseClause);
}
//~ Methods ----------------------------------------------------------------
@Override public SqlKind getKind() {
return SqlKind.CASE;
}
public SqlOperator getOperator() {
return SqlStdOperatorTable.CASE;
}
public List getOperandList() {
return UnmodifiableArrayList.of(value, whenList, thenList, elseExpr);
}
@Override public void setOperand(int i, SqlNode operand) {
switch (i) {
case 0:
value = operand;
break;
case 1:
whenList = (SqlNodeList) operand;
break;
case 2:
thenList = (SqlNodeList) operand;
break;
case 3:
elseExpr = operand;
break;
default:
throw new AssertionError(i);
}
}
public SqlNode getValueOperand() {
return value;
}
public SqlNodeList getWhenOperands() {
return whenList;
}
public SqlNodeList getThenOperands() {
return thenList;
}
public SqlNode getElseOperand() {
return elseExpr;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy