mirror of
https://github.com/Minestom/Minestom.git
synced 2024-09-29 23:17:59 +02:00
162 lines
5.0 KiB
Java
162 lines
5.0 KiB
Java
package net.minestom.server.instance;
|
|
|
|
import net.minestom.server.data.Data;
|
|
import net.minestom.server.entity.Player;
|
|
import net.minestom.server.instance.batch.BlockBatch;
|
|
import net.minestom.server.instance.batch.ChunkBatch;
|
|
import net.minestom.server.storage.StorageLocation;
|
|
import net.minestom.server.utils.BlockPosition;
|
|
import net.minestom.server.utils.Position;
|
|
import net.minestom.server.utils.chunk.ChunkCallback;
|
|
import net.minestom.server.utils.time.TimeUnit;
|
|
import org.jetbrains.annotations.NotNull;
|
|
import org.jetbrains.annotations.Nullable;
|
|
|
|
import java.util.Collection;
|
|
import java.util.UUID;
|
|
|
|
/**
|
|
* The {@link SharedInstance} is an instance that shares the same chunks as its linked {@link InstanceContainer},
|
|
* entities are separated.
|
|
*/
|
|
public class SharedInstance extends Instance {
|
|
|
|
private final InstanceContainer instanceContainer;
|
|
|
|
public SharedInstance(@NotNull UUID uniqueId, @NotNull InstanceContainer instanceContainer) {
|
|
super(uniqueId, instanceContainer.getDimensionType());
|
|
this.instanceContainer = instanceContainer;
|
|
}
|
|
|
|
@Override
|
|
public void refreshBlockStateId(@NotNull BlockPosition blockPosition, short blockStateId) {
|
|
this.instanceContainer.refreshBlockStateId(blockPosition, blockStateId);
|
|
}
|
|
|
|
@Override
|
|
public boolean breakBlock(@NotNull Player player, @NotNull BlockPosition blockPosition) {
|
|
return instanceContainer.breakBlock(player, blockPosition);
|
|
}
|
|
|
|
@Override
|
|
public void loadChunk(int chunkX, int chunkZ, @Nullable ChunkCallback callback) {
|
|
this.instanceContainer.loadChunk(chunkX, chunkZ, callback);
|
|
}
|
|
|
|
@Override
|
|
public void loadOptionalChunk(int chunkX, int chunkZ, @Nullable ChunkCallback callback) {
|
|
this.instanceContainer.loadOptionalChunk(chunkX, chunkZ, callback);
|
|
}
|
|
|
|
@Override
|
|
public void unloadChunk(@NotNull Chunk chunk) {
|
|
instanceContainer.unloadChunk(chunk);
|
|
}
|
|
|
|
@Override
|
|
public Chunk getChunk(int chunkX, int chunkZ) {
|
|
return instanceContainer.getChunk(chunkX, chunkZ);
|
|
}
|
|
|
|
@Override
|
|
public void saveChunkToStorage(@NotNull Chunk chunk, @Nullable Runnable callback) {
|
|
this.instanceContainer.saveChunkToStorage(chunk, callback);
|
|
}
|
|
|
|
@Override
|
|
public void saveChunksToStorage(@Nullable Runnable callback) {
|
|
instanceContainer.saveChunksToStorage(callback);
|
|
}
|
|
|
|
@Override
|
|
public BlockBatch createBlockBatch() {
|
|
return instanceContainer.createBlockBatch();
|
|
}
|
|
|
|
@Override
|
|
public ChunkBatch createChunkBatch(@NotNull Chunk chunk) {
|
|
return instanceContainer.createChunkBatch(chunk);
|
|
}
|
|
|
|
@Override
|
|
public void setChunkGenerator(ChunkGenerator chunkGenerator) {
|
|
this.instanceContainer.setChunkGenerator(chunkGenerator);
|
|
}
|
|
|
|
@Override
|
|
public ChunkGenerator getChunkGenerator() {
|
|
return instanceContainer.getChunkGenerator();
|
|
}
|
|
|
|
@NotNull
|
|
@Override
|
|
public Collection<Chunk> getChunks() {
|
|
return instanceContainer.getChunks();
|
|
}
|
|
|
|
@Override
|
|
public StorageLocation getStorageLocation() {
|
|
return instanceContainer.getStorageLocation();
|
|
}
|
|
|
|
@Override
|
|
public void setStorageLocation(StorageLocation storageLocation) {
|
|
this.instanceContainer.setStorageLocation(storageLocation);
|
|
}
|
|
|
|
@Override
|
|
public void retrieveChunk(int chunkX, int chunkZ, @Nullable ChunkCallback callback) {
|
|
this.instanceContainer.retrieveChunk(chunkX, chunkZ, callback);
|
|
}
|
|
|
|
@Override
|
|
protected void createChunk(int chunkX, int chunkZ, ChunkCallback callback) {
|
|
this.instanceContainer.createChunk(chunkX, chunkZ, callback);
|
|
}
|
|
|
|
@Override
|
|
public void enableAutoChunkLoad(boolean enable) {
|
|
instanceContainer.enableAutoChunkLoad(enable);
|
|
}
|
|
|
|
@Override
|
|
public boolean hasEnabledAutoChunkLoad() {
|
|
return instanceContainer.hasEnabledAutoChunkLoad();
|
|
}
|
|
|
|
@Override
|
|
public boolean isInVoid(@NotNull Position position) {
|
|
return instanceContainer.isInVoid(position);
|
|
}
|
|
|
|
@Override
|
|
public void setBlockStateId(int x, int y, int z, short blockStateId, Data data) {
|
|
this.instanceContainer.setBlockStateId(x, y, z, blockStateId, data);
|
|
}
|
|
|
|
@Override
|
|
public void setCustomBlock(int x, int y, int z, short customBlockId, Data data) {
|
|
this.instanceContainer.setCustomBlock(x, y, z, customBlockId, data);
|
|
}
|
|
|
|
@Override
|
|
public void setSeparateBlocks(int x, int y, int z, short blockStateId, short customBlockId, Data data) {
|
|
this.instanceContainer.setSeparateBlocks(x, y, z, blockStateId, customBlockId, data);
|
|
}
|
|
|
|
@Override
|
|
public void scheduleUpdate(int time, @NotNull TimeUnit unit, @NotNull BlockPosition position) {
|
|
this.instanceContainer.scheduleUpdate(time, unit, position);
|
|
}
|
|
|
|
/**
|
|
* Gets the {@link InstanceContainer} from where this instance takes its chunks from.
|
|
*
|
|
* @return the associated {@link InstanceContainer}
|
|
*/
|
|
@NotNull
|
|
public InstanceContainer getInstanceContainer() {
|
|
return instanceContainer;
|
|
}
|
|
}
|