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

com.hazelcast.jet.sql.impl.opt.physical.PhysicalRules Maven / Gradle / Ivy

/*
 * Copyright 2021 Hazelcast Inc.
 *
 * Licensed under the Hazelcast Community License (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://hazelcast.com/hazelcast-community-license
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.hazelcast.jet.sql.impl.opt.physical;

import com.hazelcast.org.apache.calcite.plan.volcano.AbstractConverter;
import com.hazelcast.org.apache.calcite.rel.core.RelFactories;
import com.hazelcast.org.apache.calcite.tools.RuleSet;
import com.hazelcast.org.apache.calcite.tools.RuleSets;

public final class PhysicalRules {

    private PhysicalRules() {
    }

    public static RuleSet getRuleSet() {
        return RuleSets.ofList(
                // Filter rules
                FilterPhysicalRule.INSTANCE,

                // Project rules
                ProjectPhysicalRule.INSTANCE,

                // Scan rules
                FullScanPhysicalRule.INSTANCE,
                IndexScanMapPhysicalRule.INSTANCE,

                // Aggregate rules
                AggregatePhysicalRule.INSTANCE,

                // Sort rules
                SortPhysicalRule.INSTANCE,

                // Join rules
                JoinPhysicalRule.INSTANCE,

                // Value rules
                ValuesPhysicalRule.INSTANCE,

                // DML rules
                InsertPhysicalRule.INSTANCE,
                SinkPhysicalRule.INSTANCE,
                UpdatePhysicalRule.INSTANCE,
                DeletePhysicalRule.INSTANCE,

                SelectByKeyMapPhysicalRule.INSTANCE,
                InsertMapPhysicalRule.INSTANCE,
                SinkMapPhysicalRule.INSTANCE,
                UpdateByKeyMapPhysicalRule.INSTANCE,
                DeleteByKeyMapPhysicalRule.INSTANCE,

                new AbstractConverter.ExpandConversionRule(RelFactories.LOGICAL_BUILDER)
        );
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy