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

io.trino.plugin.hive.ReaderColumns 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.plugin.hive;

import com.google.common.collect.ImmutableList;
import io.trino.spi.connector.ColumnHandle;

import java.util.List;

import static com.google.common.base.Preconditions.checkArgument;
import static java.util.Objects.requireNonNull;

/**
 * Stores a mapping between
 * - the projected columns required by a connector level pagesource and
 * -  the columns supplied by format-specific page source
 * 

* Currently used in {@link HivePageSource}, {@code io.trino.plugin.iceberg.IcebergPageSource}, * and {@code io.trino.plugin.deltalake.DeltaLakePageSource}. */ public class ReaderColumns { // columns to be read by the reader (ordered) private final List readerColumns; // indices for mapping expected column handles to the reader's column handles private final List readerBlockIndices; public ReaderColumns(List readerColumns, List readerBlockIndices) { this.readerColumns = ImmutableList.copyOf(requireNonNull(readerColumns, "readerColumns is null")); readerBlockIndices.forEach(value -> checkArgument(value >= 0 && value < readerColumns.size(), "block index out of bounds")); this.readerBlockIndices = ImmutableList.copyOf(requireNonNull(readerBlockIndices, "readerBlockIndices is null")); } /** * For a column required by the wrapper page source, returns the column read by the delegate page source or record cursor. */ public ColumnHandle getForColumnAt(int index) { checkArgument(index >= 0 && index < readerBlockIndices.size(), "index is not valid"); int readerIndex = readerBlockIndices.get(index); return readerColumns.get(readerIndex); } /** * For a channel expected by wrapper page source, returns the channel index in the underlying page source or record cursor. */ public int getPositionForColumnAt(int index) { checkArgument(index >= 0 && index < readerBlockIndices.size(), "index is invalid"); return readerBlockIndices.get(index); } /** * returns the actual list of columns being read by underlying page source or record cursor in order. */ public List get() { return readerColumns; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy