com.hazelcast.org.apache.calcite.rel.metadata.RelMetadataQueryBase 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.metadata;
import com.hazelcast.org.apache.calcite.rel.RelNode;
import com.hazelcast.com.google.common.collect.HashBasedTable;
import com.hazelcast.com.google.common.collect.Table;
import com.hazelcast.org.checkerframework.checker.nullness.qual.Nullable;
import java.lang.reflect.Proxy;
import java.util.Map;
import java.util.function.Supplier;
import static com.hazelcast.org.apache.calcite.linq4j.Nullness.castNonNull;
import static java.util.Objects.requireNonNull;
/**
* Base class for the RelMetadataQuery that uses the metadata handler class
* generated by the Janino.
*
* To add a new implementation to this interface, follow
* these steps:
*
*
* - Extends {@link RelMetadataQuery} (name it MyRelMetadataQuery for example)
* to reuse the Calcite builtin metadata query interfaces. In this class, define all the
* extended Handlers for your metadata and implement the metadata query interfaces.
*
- Write your customized provider class
RelMdXyz
. Follow
* the pattern from an existing class such as {@link RelMdColumnOrigins},
* overloading on all of the logical relational expressions to which the query
* applies.
* - Add a {@code SOURCE} static member to each of your provider class, similar to
* {@link RelMdColumnOrigins#SOURCE}.
*
- Extends {@link DefaultRelMetadataProvider} (name it MyRelMetadataProvider for example)
* and supplement the "SOURCE"s into the builtin list
* (This is not required, use {@link ChainedRelMetadataProvider} to chain your customized
* "SOURCE"s with default ones also works).
*
- Set {@code MyRelMetadataProvider} into the cluster instance.
*
- Use
* {@link com.hazelcast.org.apache.calcite.plan.RelOptCluster#setMetadataQuerySupplier(Supplier)}
* to set the metadata query {@link Supplier} into the cluster instance. This {@link Supplier}
* should return a fresh new instance.
*
- Use the cluster instance to create
* {@link com.hazelcast.org.apache.calcite.sql2rel.SqlToRelConverter}.
* - Query your metadata within {@link com.hazelcast.org.apache.calcite.plan.RelOptRuleCall} with the
* interfaces you defined in {@code MyRelMetadataQuery}.
*
*/
public class RelMetadataQueryBase {
//~ Instance fields --------------------------------------------------------
/** Set of active metadata queries, and cache of previous results. */
public final Table map = HashBasedTable.create();
private final @Nullable MetadataHandlerProvider metadataHandlerProvider;
@Deprecated // to be removed before 2.0
public final @Nullable JaninoRelMetadataProvider metadataProvider;
//~ Static fields/initializers ---------------------------------------------
public static final ThreadLocal<@Nullable JaninoRelMetadataProvider> THREAD_PROVIDERS =
new ThreadLocal<>();
//~ Constructors -----------------------------------------------------------
@Deprecated // to be removed before 2.0
protected RelMetadataQueryBase(@Nullable JaninoRelMetadataProvider metadataProvider) {
this((MetadataHandlerProvider) metadataProvider);
}
@SuppressWarnings("deprecation")
protected RelMetadataQueryBase(@Nullable MetadataHandlerProvider provider) {
this.metadataHandlerProvider = provider;
this.metadataProvider = provider instanceof JaninoRelMetadataProvider
? (JaninoRelMetadataProvider) provider : null;
}
@Deprecated
protected static H initialHandler(Class handlerClass) {
return handlerClass.cast(
Proxy.newProxyInstance(RelMetadataQuery.class.getClassLoader(),
new Class[] {handlerClass}, (proxy, method, args) -> {
final RelNode r = requireNonNull((RelNode) args[0], "(RelNode) args[0]");
throw new JaninoRelMetadataProvider.NoHandler(r.getClass());
}));
}
//~ Methods ----------------------------------------------------------------
/** Re-generates the handler for a given kind of metadata, adding support for
* {@code class_} if it is not already present. */
@Deprecated // to be removed before 2.0
protected > H
revise(Class extends RelNode> class_, MetadataDef def) {
return (H) revise(def.handlerClass);
}
/** Re-generates the handler for a given kind of metadata, adding support for
* {@code class_} if it is not already present. */
protected > H revise(Class def) {
return getMetadataHandlerProvider().revise(def);
}
private MetadataHandlerProvider getMetadataHandlerProvider() {
requireNonNull(metadataHandlerProvider, "metadataHandlerProvider");
return castNonNull(metadataHandlerProvider);
}
/**
* Provide a handler for the requested metadata class.
* @param handlerClass The handler interface expected
* @param The metadata type the handler relates to.
* @return The handler implementation.
*/
protected > MH handler(Class handlerClass) {
return getMetadataHandlerProvider().handler(handlerClass);
}
/**
* Removes cached metadata values for specified RelNode.
*
* @param rel RelNode whose cached metadata should be removed
* @return true if cache for the provided RelNode was not empty
*/
public boolean clearCache(RelNode rel) {
Map
© 2015 - 2025 Weber Informatics LLC | Privacy Policy