Use constant default anvil loader

Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
TheMode 2022-10-27 15:52:59 +02:00
parent c95ced9493
commit caa150d923
2 changed files with 13 additions and 12 deletions

View File

@ -50,7 +50,7 @@ public class AnvilLoader implements IChunkLoader {
private final RegionCache perRegionLoadedChunks = new RegionCache(); private final RegionCache perRegionLoadedChunks = new RegionCache();
// thread local to avoid contention issues with locks // thread local to avoid contention issues with locks
private final ThreadLocal<Int2ObjectMap<BlockState>> blockStateId2ObjectCacheTLS = ThreadLocal.withInitial(() -> new Int2ObjectArrayMap<>()); private final ThreadLocal<Int2ObjectMap<BlockState>> blockStateId2ObjectCacheTLS = ThreadLocal.withInitial(Int2ObjectArrayMap::new);
public AnvilLoader(@NotNull Path path) { public AnvilLoader(@NotNull Path path) {
this.path = path; this.path = path;
@ -160,7 +160,7 @@ public class AnvilLoader implements IChunkLoader {
private void loadSections(Chunk chunk, ChunkReader chunkReader) { private void loadSections(Chunk chunk, ChunkReader chunkReader) {
final HashMap<String, Biome> biomeCache = new HashMap<>(); final HashMap<String, Biome> biomeCache = new HashMap<>();
for (var sectionNBT : chunkReader.getSections()) { for (NBTCompound sectionNBT : chunkReader.getSections()) {
ChunkSectionReader sectionReader = new ChunkSectionReader(chunkReader.getMinecraftVersion(), sectionNBT); ChunkSectionReader sectionReader = new ChunkSectionReader(chunkReader.getMinecraftVersion(), sectionNBT);
if (sectionReader.isSectionEmpty()) continue; if (sectionReader.isSectionEmpty()) continue;
@ -218,11 +218,11 @@ public class AnvilLoader implements IChunkLoader {
// Blocks // Blocks
final NBTList<NBTCompound> blockPalette = sectionReader.getBlockPalette(); final NBTList<NBTCompound> blockPalette = sectionReader.getBlockPalette();
if (blockPalette != null) { if (blockPalette != null) {
int[] blockStateIndices = sectionReader.getUncompressedBlockStateIDs(); final int[] blockStateIndices = sectionReader.getUncompressedBlockStateIDs();
Block[] convertedPalette = new Block[blockPalette.getSize()]; Block[] convertedPalette = new Block[blockPalette.getSize()];
for (int i = 0; i < convertedPalette.length; i++) { for (int i = 0; i < convertedPalette.length; i++) {
final NBTCompound paletteEntry = blockPalette.get(i); final NBTCompound paletteEntry = blockPalette.get(i);
String blockName = Objects.requireNonNull(paletteEntry.getString("Name")); final String blockName = Objects.requireNonNull(paletteEntry.getString("Name"));
if (blockName.equals("minecraft:air")) { if (blockName.equals("minecraft:air")) {
convertedPalette[i] = Block.AIR; convertedPalette[i] = Block.AIR;
} else { } else {
@ -256,9 +256,9 @@ public class AnvilLoader implements IChunkLoader {
for (int z = 0; z < Chunk.CHUNK_SECTION_SIZE; z++) { for (int z = 0; z < Chunk.CHUNK_SECTION_SIZE; z++) {
for (int x = 0; x < Chunk.CHUNK_SECTION_SIZE; x++) { for (int x = 0; x < Chunk.CHUNK_SECTION_SIZE; x++) {
try { try {
int blockIndex = y * Chunk.CHUNK_SECTION_SIZE * Chunk.CHUNK_SECTION_SIZE + z * Chunk.CHUNK_SECTION_SIZE + x; final int blockIndex = y * Chunk.CHUNK_SECTION_SIZE * Chunk.CHUNK_SECTION_SIZE + z * Chunk.CHUNK_SECTION_SIZE + x;
int paletteIndex = blockStateIndices[blockIndex]; final int paletteIndex = blockStateIndices[blockIndex];
Block block = convertedPalette[paletteIndex]; final Block block = convertedPalette[paletteIndex];
chunk.setBlock(x, y + yOffset, z, block); chunk.setBlock(x, y + yOffset, z, block);
} catch (Exception e) { } catch (Exception e) {
@ -303,7 +303,7 @@ public class AnvilLoader implements IChunkLoader {
@Override @Override
public @NotNull CompletableFuture<Void> saveInstance(@NotNull Instance instance) { public @NotNull CompletableFuture<Void> saveInstance(@NotNull Instance instance) {
final var nbt = instance.tagHandler().asCompound(); final NBTCompound nbt = instance.tagHandler().asCompound();
if (nbt.isEmpty()) { if (nbt.isEmpty()) {
// Instance has no data // Instance has no data
return AsyncUtils.VOID_FUTURE; return AsyncUtils.VOID_FUTURE;
@ -385,7 +385,7 @@ public class AnvilLoader implements IChunkLoader {
for (int x = 0; x < Chunk.CHUNK_SIZE_X; x++) { for (int x = 0; x < Chunk.CHUNK_SIZE_X; x++) {
final int y = sectionLocalY + sectionY * Chunk.CHUNK_SECTION_SIZE; final int y = sectionLocalY + sectionY * Chunk.CHUNK_SECTION_SIZE;
int blockIndex = x + sectionLocalY * 16 * 16 + z * 16; final int blockIndex = x + sectionLocalY * 16 * 16 + z * 16;
final Block block = chunk.getBlock(x, y, z); final Block block = chunk.getBlock(x, y, z);
@ -406,7 +406,7 @@ public class AnvilLoader implements IChunkLoader {
// Block entities // Block entities
final BlockHandler handler = block.handler(); final BlockHandler handler = block.handler();
var originalNBT = block.nbt(); final NBTCompound originalNBT = block.nbt();
if (originalNBT != null || handler != null) { if (originalNBT != null || handler != null) {
MutableNBTCompound nbt = originalNBT != null ? MutableNBTCompound nbt = originalNBT != null ?
originalNBT.toMutableCompound() : new MutableNBTCompound(); originalNBT.toMutableCompound() : new MutableNBTCompound();

View File

@ -48,6 +48,7 @@ import static net.minestom.server.utils.chunk.ChunkUtils.*;
* InstanceContainer is an instance that contains chunks in contrary to SharedInstance. * InstanceContainer is an instance that contains chunks in contrary to SharedInstance.
*/ */
public class InstanceContainer extends Instance { public class InstanceContainer extends Instance {
private static final AnvilLoader DEFAULT_LOADER = new AnvilLoader("world");
// the shared instances assigned to this instance // the shared instances assigned to this instance
private final List<SharedInstance> sharedInstances = new CopyOnWriteArrayList<>(); private final List<SharedInstance> sharedInstances = new CopyOnWriteArrayList<>();
@ -79,7 +80,7 @@ public class InstanceContainer extends Instance {
public InstanceContainer(@NotNull UUID uniqueId, @NotNull DimensionType dimensionType, @Nullable IChunkLoader loader) { public InstanceContainer(@NotNull UUID uniqueId, @NotNull DimensionType dimensionType, @Nullable IChunkLoader loader) {
super(uniqueId, dimensionType); super(uniqueId, dimensionType);
setChunkSupplier(DynamicChunk::new); setChunkSupplier(DynamicChunk::new);
setChunkLoader(Objects.requireNonNullElseGet(loader, () -> new AnvilLoader("world"))); setChunkLoader(Objects.requireNonNullElse(loader, DEFAULT_LOADER));
this.chunkLoader.loadInstance(this); this.chunkLoader.loadInstance(this);
} }