mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-08 17:37:42 +01:00
Use constant default anvil loader
Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
parent
c95ced9493
commit
caa150d923
@ -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();
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -228,7 +229,7 @@ public class InstanceContainer extends Instance {
|
|||||||
// Clear cache
|
// Clear cache
|
||||||
this.chunks.remove(getChunkIndex(chunkX, chunkZ));
|
this.chunks.remove(getChunkIndex(chunkX, chunkZ));
|
||||||
chunk.unload();
|
chunk.unload();
|
||||||
if(chunkLoader != null) {
|
if (chunkLoader != null) {
|
||||||
chunkLoader.unloadChunk(chunk);
|
chunkLoader.unloadChunk(chunk);
|
||||||
}
|
}
|
||||||
var dispatcher = MinecraftServer.process().dispatcher();
|
var dispatcher = MinecraftServer.process().dispatcher();
|
||||||
|
Loading…
Reference in New Issue
Block a user