Improve anvil block loading performance

This commit is contained in:
TheMode 2021-07-20 23:40:23 +02:00
parent cb21b0baf5
commit bad206d504

View File

@ -88,8 +88,7 @@ public class AnvilLoader implements IChunkLoader {
loadBlocks(chunk, fileChunk); loadBlocks(chunk, fileChunk);
loadTileEntities(chunk, fileChunk); loadTileEntities(chunk, fileChunk);
// Lights // Lights
final var chunkSections = fileChunk.getSections(); for (var chunkSection : fileChunk.getSections()) {
for (var chunkSection : chunkSections) {
Section section = chunk.getSection(chunkSection.getY()); Section section = chunk.getSection(chunkSection.getY());
section.setSkyLight(chunkSection.getSkyLights()); section.setSkyLight(chunkSection.getSkyLights());
section.setBlockLight(chunkSection.getBlockLights()); section.setBlockLight(chunkSection.getBlockLights());
@ -116,11 +115,16 @@ public class AnvilLoader implements IChunkLoader {
} }
private void loadBlocks(Chunk chunk, ChunkColumn fileChunk) { private void loadBlocks(Chunk chunk, ChunkColumn fileChunk) {
for (int x = 0; x < Chunk.CHUNK_SIZE_X; x++) { for (var section : fileChunk.getSections()) {
for (int z = 0; z < Chunk.CHUNK_SIZE_Z; z++) { if (section.getEmpty()) {
for (int y = 0; y < 256; y++) { // TODO don't hardcode height continue;
}
final int yOffset = Chunk.CHUNK_SECTION_SIZE * section.getY();
for (int x = 0; x < Chunk.CHUNK_SECTION_SIZE; x++) {
for (int z = 0; z < Chunk.CHUNK_SECTION_SIZE; z++) {
for (int y = 0; y < Chunk.CHUNK_SECTION_SIZE; y++) {
try { try {
final BlockState blockState = fileChunk.getBlockState(x, y, z); final BlockState blockState = section.get(x, y, z);
Block block = Block.fromNamespaceId(blockState.getName()); Block block = Block.fromNamespaceId(blockState.getName());
if (block == null) { if (block == null) {
// Invalid block // Invalid block
@ -130,7 +134,7 @@ public class AnvilLoader implements IChunkLoader {
if (!properties.isEmpty()) { if (!properties.isEmpty()) {
block = block.withProperties(properties); block = block.withProperties(properties);
} }
chunk.setBlock(x, y, z, block); chunk.setBlock(x, y + yOffset, z, block);
} catch (Exception e) { } catch (Exception e) {
EXCEPTION_MANAGER.handleException(e); EXCEPTION_MANAGER.handleException(e);
} }
@ -138,6 +142,7 @@ public class AnvilLoader implements IChunkLoader {
} }
} }
} }
}
private void loadTileEntities(Chunk loadedChunk, ChunkColumn fileChunk) { private void loadTileEntities(Chunk loadedChunk, ChunkColumn fileChunk) {
for (NBTCompound te : fileChunk.getTileEntities()) { for (NBTCompound te : fileChunk.getTileEntities()) {