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

io.trino.spi.block.BlockBuilder Maven / Gradle / Ivy

The newest version!
/*
 * 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.block;

import static io.trino.spi.block.BlockUtil.calculateBlockResetSize;

public interface BlockBuilder
{
    /**
     * Returns the number of positions in this block builder.
     */
    int getPositionCount();

    /**
     * Returns the size of this block as if it was compacted, ignoring any over-allocations
     * and any unloaded nested blocks.
     * For example, in dictionary blocks, this only counts each dictionary entry once,
     * rather than each time a value is referenced.
     */
    long getSizeInBytes();

    /**
     * Returns the retained size of this block in memory, including over-allocations.
     * This method is called from the innermost execution loop and must be fast.
     */
    long getRetainedSizeInBytes();

    /**
     * Append the specified value.
     */
    void append(ValueBlock block, int position);

    /**
     * Append the specified value multiple times.
     */
    void appendRepeated(ValueBlock block, int position, int count);

    /**
     * Append the values in the specified range.
     */
    void appendRange(ValueBlock block, int offset, int length);

    /**
     * Append the values at the specified positions.
     */
    void appendPositions(ValueBlock block, int[] positions, int offset, int length);

    /**
     * Appends a null value to the block.
     */
    BlockBuilder appendNull();

    /**
     * Rolls back added data to the specified position.
     * Resetting may result in a block without nulls with the may-have-nulls flag set.
     * The PageBuilder status will not be updated to reflect the removed data size.
     *
     * @throws IllegalArgumentException if the position is greater than the current position count
     */
    void resetTo(int position);

    /**
     * Builds the block. This method can be called multiple times.
     * The return value may be a block such as RLE to allow for optimizations when all block values are the same.
     */
    Block build();

    /**
     * Builds a ValueBlock. This method can be called multiple times.
     */
    ValueBlock buildValueBlock();

    /**
     * Creates a new block builder of the same type based on the current usage statistics of this block builder.
     */
    BlockBuilder newBlockBuilderLike(int expectedEntries, BlockBuilderStatus blockBuilderStatus);

    default BlockBuilder newBlockBuilderLike(BlockBuilderStatus blockBuilderStatus)
    {
        return newBlockBuilderLike(calculateBlockResetSize(getPositionCount()), blockBuilderStatus);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy