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

io.trino.operator.join.PositionLinks 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.join;

import io.trino.spi.Page;

import java.util.List;

/**
 * This class is responsible for iterating over build rows, which have
 * same values in hash columns as given probe row (but according to
 * filterFunction can have non matching values on some other column).
 */
public interface PositionLinks
{
    long getSizeInBytes();

    /**
     * Initialize iteration over position links. Returns first potentially eligible
     * join position starting from (and including) position argument.
     * 

* When there are no more position -1 is returned */ int start(int position, int probePosition, Page allProbeChannelsPage); /** * Iterate over position links. When there are no more position -1 is returned. */ int next(int position, int probePosition, Page allProbeChannelsPage); interface FactoryBuilder { /** * @return value that should be used in future references to created position links */ int link(int left, int right); Factory build(); boolean isEmpty(); } interface Factory { /** * Separate JoinFilterFunctions have to be created and supplied for each thread using PositionLinks * since JoinFilterFunction is not thread safe... */ PositionLinks create(List searchFunctions); /** * @return a checksum for this {@link PositionLinks}, useful when entity is restored from spilled data */ long checksum(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy