All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
io.trino.operator.scalar.ParametricScalar Maven / Gradle / Ivy
/*
* Licensed 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 io.trino.operator.scalar;
import com.google.common.annotations.VisibleForTesting;
import io.trino.metadata.FunctionBinding;
import io.trino.metadata.SignatureBinder;
import io.trino.metadata.SqlScalarFunction;
import io.trino.operator.ParametricImplementationsGroup;
import io.trino.operator.annotations.ImplementationDependency;
import io.trino.operator.scalar.annotations.ParametricScalarImplementation;
import io.trino.operator.scalar.annotations.ParametricScalarImplementation.ParametricScalarImplementationChoice;
import io.trino.spi.TrinoException;
import io.trino.spi.function.BoundSignature;
import io.trino.spi.function.FunctionDependencies;
import io.trino.spi.function.FunctionDependencyDeclaration;
import io.trino.spi.function.FunctionDependencyDeclaration.FunctionDependencyDeclarationBuilder;
import io.trino.spi.function.FunctionMetadata;
import io.trino.spi.function.FunctionNullability;
import io.trino.spi.function.Signature;
import java.util.Collection;
import java.util.Optional;
import static io.trino.spi.StandardErrorCode.AMBIGUOUS_FUNCTION_IMPLEMENTATION;
import static io.trino.spi.StandardErrorCode.FUNCTION_IMPLEMENTATION_ERROR;
import static io.trino.spi.StandardErrorCode.FUNCTION_IMPLEMENTATION_MISSING;
import static io.trino.util.Failures.checkCondition;
import static java.lang.String.format;
import static java.util.Objects.requireNonNull;
public class ParametricScalar
extends SqlScalarFunction
{
private final ParametricImplementationsGroup implementations;
public ParametricScalar(
Signature signature,
ScalarHeader details,
ParametricImplementationsGroup implementations,
boolean deprecated)
{
super(createFunctionMetadata(signature, details, deprecated, implementations.getFunctionNullability()));
this.implementations = requireNonNull(implementations);
}
private static FunctionMetadata createFunctionMetadata(Signature signature, ScalarHeader details, boolean deprecated, FunctionNullability functionNullability)
{
FunctionMetadata.Builder functionMetadata = FunctionMetadata.scalarBuilder(details.getName())
.signature(signature);
details.getAliases().forEach(functionMetadata::alias);
if (details.getDescription().isPresent()) {
functionMetadata.description(details.getDescription().get());
}
else {
functionMetadata.noDescription();
}
if (details.isHidden()) {
functionMetadata.hidden();
}
if (!details.isDeterministic()) {
functionMetadata.nondeterministic();
}
if (deprecated) {
functionMetadata.deprecated();
}
if (functionNullability.isReturnNullable()) {
functionMetadata.nullable();
}
functionMetadata.argumentNullability(functionNullability.getArgumentNullable());
return functionMetadata.build();
}
@VisibleForTesting
public ParametricImplementationsGroup getImplementations()
{
return implementations;
}
@Override
public FunctionDependencyDeclaration getFunctionDependencies()
{
FunctionDependencyDeclarationBuilder builder = FunctionDependencyDeclaration.builder();
declareDependencies(builder, implementations.getExactImplementations().values());
declareDependencies(builder, implementations.getSpecializedImplementations());
declareDependencies(builder, implementations.getGenericImplementations());
return builder.build();
}
private static void declareDependencies(FunctionDependencyDeclarationBuilder builder,
Collection implementations)
{
for (ParametricScalarImplementation implementation : implementations) {
for (ParametricScalarImplementationChoice choice : implementation.getChoices()) {
for (ImplementationDependency dependency : choice.getDependencies()) {
dependency.declareDependencies(builder);
}
for (ImplementationDependency dependency : choice.getConstructorDependencies()) {
dependency.declareDependencies(builder);
}
}
}
}
@Override
public SpecializedSqlScalarFunction specialize(BoundSignature boundSignature, FunctionDependencies functionDependencies)
{
FunctionMetadata metadata = getFunctionMetadata();
FunctionBinding functionBinding = SignatureBinder.bindFunction(metadata.getFunctionId(), metadata.getSignature(), boundSignature);
ParametricScalarImplementation exactImplementation = implementations.getExactImplementations().get(boundSignature.toSignature());
if (exactImplementation != null) {
Optional scalarFunctionImplementation = exactImplementation.specialize(functionBinding, functionDependencies);
checkCondition(scalarFunctionImplementation.isPresent(), FUNCTION_IMPLEMENTATION_ERROR, "Exact implementation of %s do not match expected java types", boundSignature.getName());
return scalarFunctionImplementation.get();
}
SpecializedSqlScalarFunction selectedImplementation = null;
for (ParametricScalarImplementation implementation : implementations.getSpecializedImplementations()) {
Optional scalarFunctionImplementation = implementation.specialize(functionBinding, functionDependencies);
if (scalarFunctionImplementation.isPresent()) {
checkCondition(selectedImplementation == null, AMBIGUOUS_FUNCTION_IMPLEMENTATION, "Ambiguous implementation for %s with bindings %s", metadata.getSignature(), boundSignature);
selectedImplementation = scalarFunctionImplementation.get();
}
}
if (selectedImplementation != null) {
return selectedImplementation;
}
for (ParametricScalarImplementation implementation : implementations.getGenericImplementations()) {
Optional scalarFunctionImplementation = implementation.specialize(functionBinding, functionDependencies);
if (scalarFunctionImplementation.isPresent()) {
checkCondition(selectedImplementation == null, AMBIGUOUS_FUNCTION_IMPLEMENTATION, "Ambiguous implementation for %s with bindings %s", metadata.getSignature(), boundSignature);
selectedImplementation = scalarFunctionImplementation.get();
}
}
if (selectedImplementation != null) {
return selectedImplementation;
}
throw new TrinoException(FUNCTION_IMPLEMENTATION_MISSING, format("Unsupported binding %s for signature %s", boundSignature, getFunctionMetadata().getSignature()));
}
}