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

com.hazelcast.org.apache.calcite.schema.FunctionContext 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.schema;

import com.hazelcast.org.apache.calcite.linq4j.function.Experimental;
import com.hazelcast.org.apache.calcite.rel.type.RelDataTypeFactory;

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

/**
 * Information about a function call that is passed to the constructor of a
 * function instance.
 *
 * 

This may enable a function to perform work up front, during construction, * rather than each time it is invoked. Here is an example of such a function: * *

 * class RegexMatchesFunction {
 *   final java.util.regex.Pattern pattern;
 *
 *   public RegexMatchesFunction(FunctionContext cx) {
 *     String pattern = cx.argumentValueAs(String.class);
 *     this.compiledPattern = java.util.regex.Pattern.compile(pattern);
 *   }
 *
 *   public boolean eval(String pattern, String s) {
 *     return this.compiledPattern.matches(s);
 *   }
 * }
 * 
* *

Register it in the model as follows: * *

 *   functions: [
 *     {
 *       name: 'REGEX_MATCHES',
 *       className: 'com.example.RegexMatchesFun'
 *     }
 *   ]
 * 
* *

and use it in a query: * *

 * SELECT empno, ename
 * FROM Emp
 * WHERE regex_matches('J.*ES', ename);
 *
 * +-------+--------+
 * | EMPNO | ENAME  |
 * +-------+--------+
 * | 7900  | JAMES  |
 * | 7566  | JONES  |
 * +-------+--------+
 * 
* *

When executing the query, Calcite will create an instance of * {@code RegexMatchesFunction} and call the {@code eval} method on that * instance once per row. * *

If the {@code eval} method was static, or if the function's * constructor had zero parameters, the {@code eval} method would have to call * {@code java.util.regex.Pattern.compile(pattern)} to compile the pattern each * time. * *

This interface is marked {@link Experimental}, which means that we may * change or remove methods, or the entire interface, without notice. But * probably we will add methods over time, which will just your UDFs more * information to work with. */ @Experimental public interface FunctionContext { /** Returns the type factory. */ RelDataTypeFactory getTypeFactory(); /** Returns the number of parameters. */ int getParameterCount(); /** Returns whether the value of an argument is constant. * * @param ordinal Argument ordinal, starting from 0 */ boolean isArgumentConstant(int ordinal); /** Returns the value of an argument to this function, * null if the argument is the NULL literal. * * @param ordinal Argument ordinal, starting from 0 * @param valueClass Type of value * * @throws ClassCastException if argument cannot be converted to * {@code valueClass} * * @throws IllegalArgumentException if argument is not constant */ @Nullable V getArgumentValueAs(int ordinal, Class valueClass); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy