mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-19 22:51:41 +01:00
Fast exit for retrieveAll
Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
parent
d4875b2838
commit
f80f653ee0
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user