Fast exit for retrieveAll

Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
TheMode 2022-05-19 12:39:27 +02:00
parent d4875b2838
commit f80f653ee0

View File

@ -216,6 +216,7 @@ final class FlexiblePalette implements SpecializedPalette, Cloneable {
} }
private void retrieveAll(@NotNull EntryConsumer consumer, boolean consumeEmpty) { private void retrieveAll(@NotNull EntryConsumer consumer, boolean consumeEmpty) {
if (!consumeEmpty && count == 0) return;
final long[] values = this.values; final long[] values = this.values;
final int dimension = this.dimension(); final int dimension = this.dimension();
final int bitsPerEntry = this.bitsPerEntry; final int bitsPerEntry = this.bitsPerEntry;
@ -228,31 +229,18 @@ final class FlexiblePalette implements SpecializedPalette, Cloneable {
final int shiftedDimensionBitCount = dimensionBitCount << 1; final int shiftedDimensionBitCount = dimensionBitCount << 1;
for (int i = 0; i < values.length; i++) { for (int i = 0; i < values.length; i++) {
final long value = values[i]; final long value = values[i];
int index = i * valuesPerLong; final int startIndex = i * valuesPerLong;
final int maxIndex = Math.min(index + valuesPerLong, size); final int endIndex = Math.min(startIndex + valuesPerLong, size);
if (value == 0) { for (int index = startIndex; index < endIndex; index++) {
// No values in this long, skip final int bitIndex = (index - startIndex) * bitsPerEntry;
if (consumeEmpty) { final int paletteIndex = (int) (value >> bitIndex & magicMask);
for (; index < maxIndex; index++) { if (consumeEmpty || paletteIndex != 0) {
final int y = index >> shiftedDimensionBitCount; final int y = index >> shiftedDimensionBitCount;
final int z = index >> dimensionBitCount & dimensionMinus; final int z = index >> dimensionBitCount & dimensionMinus;
final int x = index & dimensionMinus; final int x = index & dimensionMinus;
consumer.accept(x, y, z, 0);
}
}
} else {
int bitIndex = 0;
for (; index < maxIndex; index++) {
final short paletteIndex = (short) (value >> bitIndex & magicMask);
if (paletteIndex != 0 || consumeEmpty) {
final int result = ids != null ? ids[paletteIndex] : paletteIndex; final int result = ids != null ? ids[paletteIndex] : paletteIndex;
final int y = index >> shiftedDimensionBitCount;
final int z = index >> dimensionBitCount & dimensionMinus;
final int x = index & dimensionMinus;
consumer.accept(x, y, z, result); consumer.accept(x, y, z, result);
} }
bitIndex += bitsPerEntry;
}
} }
} }
} }
@ -262,15 +250,15 @@ final class FlexiblePalette implements SpecializedPalette, Cloneable {
assert paletteValues.length >= size; assert paletteValues.length >= size;
final int bitsPerEntry = this.bitsPerEntry; final int bitsPerEntry = this.bitsPerEntry;
final int valuesPerLong = 64 / bitsPerEntry; final int valuesPerLong = 64 / bitsPerEntry;
final long[] values = this.values;
final long clear = (1L << bitsPerEntry) - 1L; final long clear = (1L << bitsPerEntry) - 1L;
final long[] values = this.values;
for (int i = 0; i < values.length; i++) { for (int i = 0; i < values.length; i++) {
long block = values[i]; long block = values[i];
final int startIndex = i * valuesPerLong; final int startIndex = i * valuesPerLong;
final int endIndex = Math.min(startIndex + valuesPerLong, size) - startIndex; final int endIndex = Math.min(startIndex + valuesPerLong, size);
for (int index = 0; index < endIndex; index++) { for (int index = startIndex; index < endIndex; index++) {
final int bitIndex = index * bitsPerEntry; final int bitIndex = (index - startIndex) * bitsPerEntry;
block = block & ~(clear << bitIndex) | ((long) paletteValues[index + startIndex] << bitIndex); block = block & ~(clear << bitIndex) | ((long) paletteValues[index] << bitIndex);
} }
values[i] = block; values[i] = block;
} }