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

com.hazelcast.org.apache.calcite.plan.RelTrait Maven / Gradle / Ivy

There is a newer version: 5.5.0
Show newest version
/*
 * 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.plan;

import com.hazelcast.org.apache.calcite.rel.RelDistributions;
import com.hazelcast.org.apache.calcite.rel.core.Project;
import com.hazelcast.org.apache.calcite.util.mapping.Mappings;

import com.hazelcast.org.checkerframework.checker.nullness.qual.Nullable;

/**
 * RelTrait represents the manifestation of a relational expression trait within
 * a trait definition. For example, a {@code CallingConvention.JAVA} is a trait
 * of the {@link ConventionTraitDef} trait definition.
 *
 * 

Note about equals() and hashCode()

* *

If all instances of RelTrait for a particular RelTraitDef are defined in * an {@code enum} and no new RelTraits can be introduced at runtime, you need * not override {@link #hashCode()} and {@link #equals(Object)}. If, however, * new RelTrait instances are generated at runtime (e.g. based on state external * to the planner), you must implement {@link #hashCode()} and * {@link #equals(Object)} for proper {@link RelTraitDef#canonize canonization} * of your RelTrait objects.

*/ public interface RelTrait { //~ Methods ---------------------------------------------------------------- /** * Returns the RelTraitDef that defines this RelTrait. * * @return the RelTraitDef that defines this RelTrait */ RelTraitDef getTraitDef(); /** * See note about equals() and hashCode(). */ @Override int hashCode(); /** * See note about equals() and hashCode(). */ @Override boolean equals(@Nullable Object o); /** * Returns whether this trait satisfies a given trait. * *

A trait satisfies another if it is the same or stricter. For example, * {@code ORDER BY x, y} satisfies {@code ORDER BY x}. * *

A trait's {@code satisfies} relation must be a partial order (reflexive, * anti-symmetric, transitive). Many traits cannot be "loosened"; their * {@code satisfies} is an equivalence relation, where only X satisfies X. * *

If a trait has multiple values * (see {@link com.hazelcast.org.apache.calcite.plan.RelCompositeTrait}) * a collection (T0, T1, ...) satisfies T if any Ti satisfies T. * * @param trait Given trait * @return Whether this trait subsumes a given trait */ boolean satisfies(RelTrait trait); /** * Returns a succinct name for this trait. The planner may use this String * to describe the trait. */ @Override String toString(); /** * Registers a trait instance with the planner. * *

This is an opportunity to add rules that relate to that trait. However, * typical implementations will do nothing.

* * @param planner Planner */ void register(RelOptPlanner planner); /** * Applies a mapping to this trait. * *

Some traits may be changed if the columns order is changed by a mapping * of the {@link Project} operator.

* *

For example, if relation {@code SELECT a, b ORDER BY a, b} is sorted by * columns [0, 1], then the project {@code SELECT b, a} over this relation * will be sorted by columns [1, 0]. In the same time project {@code SELECT b} * will not be sorted at all because it doesn't contain the collation * prefix and this method will return an empty collation.

* *

Other traits are independent from the columns remapping. For example * {@link Convention} or {@link RelDistributions#SINGLETON}.

* * @param mapping Mapping * @return trait with mapping applied */ default T apply(Mappings.TargetMapping mapping) { return (T) this; } /** * Returns whether this trait is the default trait value. */ default boolean isDefault() { return this == getTraitDef().getDefault(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy