com.hazelcast.org.apache.calcite.rel.mutable.MutableProject 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.rel.mutable;
import com.hazelcast.org.apache.calcite.rel.core.Project;
import com.hazelcast.org.apache.calcite.rel.type.RelDataType;
import com.hazelcast.org.apache.calcite.rex.RexNode;
import com.hazelcast.org.apache.calcite.rex.RexUtil;
import com.hazelcast.org.apache.calcite.sql.validate.SqlValidatorUtil;
import com.hazelcast.org.apache.calcite.util.Litmus;
import com.hazelcast.org.apache.calcite.util.Pair;
import com.hazelcast.org.apache.calcite.util.mapping.Mappings;
import java.util.List;
import java.util.Objects;
/** Mutable equivalent of {@link com.hazelcast.org.apache.calcite.rel.core.Project}. */
public class MutableProject extends MutableSingleRel {
public final List projects;
private MutableProject(RelDataType rowType, MutableRel input,
List projects) {
super(MutableRelType.PROJECT, rowType, input);
this.projects = projects;
assert RexUtil.compatibleTypes(projects, rowType, Litmus.THROW);
}
/**
* Creates a MutableProject.
*
* @param rowType Row type
* @param input Input relational expression
* @param projects List of expressions for the input columns
*/
public static MutableProject of(RelDataType rowType, MutableRel input,
List projects) {
return new MutableProject(rowType, input, projects);
}
/**
* Creates a MutableProject.
*
* @param input Input relational expression
* @param exprList List of expressions for the input columns
* @param fieldNameList Aliases of the expressions, or null to generate
*/
public static MutableRel of(MutableRel input, List exprList,
List fieldNameList) {
final RelDataType rowType =
RexUtil.createStructType(input.cluster.getTypeFactory(), exprList,
fieldNameList, SqlValidatorUtil.F_SUGGESTER);
return of(rowType, input, exprList);
}
@Override public boolean equals(Object obj) {
return obj == this
|| obj instanceof MutableProject
&& MutableRel.PAIRWISE_STRING_EQUIVALENCE.equivalent(
projects, ((MutableProject) obj).projects)
&& input.equals(((MutableProject) obj).input);
}
@Override public int hashCode() {
return Objects.hash(input,
MutableRel.PAIRWISE_STRING_EQUIVALENCE.hash(projects));
}
@Override public StringBuilder digest(StringBuilder buf) {
return buf.append("Project(projects: ").append(projects).append(")");
}
/** Returns a list of (expression, name) pairs. */
public final List> getNamedProjects() {
return Pair.zip(projects, rowType.getFieldNames());
}
public Mappings.TargetMapping getMapping() {
return Project.getMapping(input.rowType.getFieldCount(), projects);
}
@Override public MutableRel clone() {
return MutableProject.of(rowType, input.clone(), projects);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy