io.trino.spi.function.table.TableFunctionProcessorState 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.spi.function.table;
import io.trino.spi.Experimental;
import io.trino.spi.Page;
import jakarta.annotation.Nullable;
import java.util.concurrent.CompletableFuture;
import static java.util.Objects.requireNonNull;
/**
* The result of processing input by {@link TableFunctionDataProcessor} or {@link TableFunctionSplitProcessor}.
* It can optionally include a portion of output data in the form of {@link Page}
* The returned {@link Page} should consist of:
* - proper columns produced by the table function
* - one column of type {@code BIGINT} for each table function's input table having the pass-through property (see {@link TableArgumentSpecification#isPassThroughColumns}),
* in order of the corresponding argument specifications. Entries in these columns are the indexes of input rows (from partition start) to be attached to output,
* or null to indicate that a row of nulls should be attached instead of an input row. The indexes are validated to be within the portion of the partition
* provided to the function so far.
* Note: when the input is empty, the only valid index value is null, because there are no input rows that could be attached to output. In such case, for performance
* reasons, the validation of indexes is skipped, and all pass-through columns are filled with nulls.
*/
@Experimental(eta = "2023-07-31")
public sealed interface TableFunctionProcessorState
permits TableFunctionProcessorState.Blocked, TableFunctionProcessorState.Finished, TableFunctionProcessorState.Processed
{
final class Blocked
implements TableFunctionProcessorState
{
private final CompletableFuture future;
private Blocked(CompletableFuture future)
{
this.future = requireNonNull(future, "future is null");
}
public static Blocked blocked(CompletableFuture future)
{
return new Blocked(future);
}
public CompletableFuture getFuture()
{
return future;
}
}
final class Finished
implements TableFunctionProcessorState
{
public static final Finished FINISHED = new Finished();
private Finished() {}
}
final class Processed
implements TableFunctionProcessorState
{
private final boolean usedInput;
private final Page result;
private Processed(boolean usedInput, @Nullable Page result)
{
this.usedInput = usedInput;
this.result = result;
}
public static Processed usedInput()
{
return new Processed(true, null);
}
public static Processed produced(Page result)
{
requireNonNull(result, "result is null");
return new Processed(false, result);
}
public static Processed usedInputAndProduced(Page result)
{
requireNonNull(result, "result is null");
return new Processed(true, result);
}
public boolean isUsedInput()
{
return usedInput;
}
public Page getResult()
{
return result;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy