Skip to content

Commit

Permalink
Simplify block creation for all null values
Browse files Browse the repository at this point in the history
  • Loading branch information
Praveen2112 authored and mbasmanova committed Sep 3, 2019
1 parent 2d19b6d commit ea257f5
Show file tree
Hide file tree
Showing 8 changed files with 9 additions and 27 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@
import com.facebook.presto.spi.Page;
import com.facebook.presto.spi.PrestoException;
import com.facebook.presto.spi.block.Block;
import com.facebook.presto.spi.block.BlockBuilder;
import com.facebook.presto.spi.block.LazyBlock;
import com.facebook.presto.spi.block.LazyBlockLoader;
import com.facebook.presto.spi.block.RunLengthEncodedBlock;
import com.facebook.presto.spi.type.Type;
import com.facebook.presto.spi.type.TypeManager;
import com.google.common.collect.ImmutableList;
Expand Down Expand Up @@ -96,11 +96,7 @@ public OrcBatchPageSource(
hiveColumnIndexes[columnIndex] = column.getHiveColumnIndex();

if (!recordReader.isColumnPresent(column.getHiveColumnIndex())) {
BlockBuilder blockBuilder = type.createBlockBuilder(null, MAX_BATCH_SIZE, NULL_ENTRY_SIZE);
for (int i = 0; i < MAX_BATCH_SIZE; i++) {
blockBuilder.appendNull();
}
constantBlocks[columnIndex] = blockBuilder.build();
constantBlocks[columnIndex] = RunLengthEncodedBlock.create(type, null, MAX_BATCH_SIZE);
}
}
types = typesBuilder.build();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,9 +92,7 @@ public Block readBlock(Type type)

if (dataStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,9 +93,7 @@ public Block readBlock(Type type)

if (dataStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -96,9 +96,7 @@ public Block readBlock(Type type)

if (decimalStream == null && scaleStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,9 +93,7 @@ public Block readBlock(Type type)

if (dataStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -94,9 +94,7 @@ public Block readBlock(Type type)

if (dataStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,9 +93,7 @@ public Block readBlock(Type type)

if (dataStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -111,9 +111,7 @@ public Block readBlock(Type type)

if (secondsStream == null && nanosStream == null && presentStream != null) {
presentStream.skip(nextBatchSize);
Block nullValueBlock = new RunLengthEncodedBlock(
type.createBlockBuilder(null, 1).appendNull().build(),
nextBatchSize);
Block nullValueBlock = RunLengthEncodedBlock.create(type, null, nextBatchSize);
readOffset = 0;
nextBatchSize = 0;
return nullValueBlock;
Expand Down

0 comments on commit ea257f5

Please sign in to comment.