All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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