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

io.deephaven.engine.page.IntChunkPage Maven / Gradle / Ivy

There is a newer version: 0.36.1
Show newest version
/**
 * Copyright (c) 2016-2022 Deephaven Data Labs and Patent Pending
 */
/*
 * ---------------------------------------------------------------------------------------------------------------------
 * AUTO-GENERATED CLASS - DO NOT EDIT MANUALLY - for any changes edit CharChunkPage and regenerate
 * ---------------------------------------------------------------------------------------------------------------------
 */
package io.deephaven.engine.page;

import io.deephaven.base.verify.Require;
import io.deephaven.chunk.*;
import io.deephaven.chunk.attributes.Any;
import io.deephaven.engine.rowset.RowSequence;
import org.jetbrains.annotations.NotNull;

public class IntChunkPage extends IntChunk implements ChunkPage {

    private final long mask;
    private final long firstRow;

    public static  IntChunkPage pageWrap(
            final long firstRow,
            @NotNull final int[] data,
            final int offset,
            final int capacity,
            final long mask) {
        return new IntChunkPage<>(firstRow, data, offset, capacity, mask);
    }

    public static  IntChunkPage pageWrap(
            final long firstRow,
            @NotNull final int[] data,
            final long mask) {
        return new IntChunkPage<>(firstRow, data, 0, data.length, mask);
    }

    private IntChunkPage(
            final long firstRow,
            @NotNull final int[] data,
            final int offset,
            final int capacity,
            final long mask) {
        super(data, offset, capacity);
        this.mask = mask;
        this.firstRow = Require.inRange(firstRow, "firstRow", mask, "mask");
    }

    @Override
    public final void fillChunkAppend(
            @NotNull final FillContext context,
            @NotNull final WritableChunk destination,
            @NotNull final RowSequence rowSequence) {
        WritableIntChunk to = destination.asWritableIntChunk();

        if (rowSequence.getAverageRunLengthEstimate() >= Chunk.SYSTEM_ARRAYCOPY_THRESHOLD) {
            rowSequence.forAllRowKeyRanges((final long rangeStartKey, final long rangeEndKey) -> to.appendTypedChunk(
                    this, getChunkOffset(rangeStartKey), (int) (rangeEndKey - rangeStartKey + 1)));
        } else {
            rowSequence.forAllRowKeys((final long key) -> to.add(get(getChunkOffset(key))));
        }
    }

    @Override
    public final long firstRowOffset() {
        return firstRow;
    }

    @Override
    public final long mask() {
        return mask;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy