Search in sources :

Example 6 with ChunkStore

use of org.terasology.engine.persistence.ChunkStore in project Terasology by MovingBlocks.

the class LocalChunkProvider method processReadyChunk.

private void processReadyChunk(final Chunk chunk) {
    Vector3ic chunkPos = chunk.getPosition();
    if (chunkCache.get(chunkPos) != null) {
        // TODO move it in pipeline;
        return;
    }
    chunkCache.put(new Vector3i(chunkPos), chunk);
    chunk.markReady();
    // TODO, it is not clear if the activate/addedBlocks event logic is correct.
    // See https://github.com/MovingBlocks/Terasology/issues/3244
    ChunkStore store = this.storageManager.loadChunkStore(chunkPos);
    TShortObjectMap<TIntList> mappings = createBatchBlockEventMappings(chunk);
    if (store != null) {
        store.restoreEntities();
        PerformanceMonitor.startActivity("Sending OnAddedBlocks");
        mappings.forEachEntry((id, positions) -> {
            if (positions.size() > 0) {
                blockManager.getBlock(id).getEntity().send(new OnAddedBlocks(positions, registry));
            }
            return true;
        });
        PerformanceMonitor.endActivity();
        // send on activate
        PerformanceMonitor.startActivity("Sending OnActivateBlocks");
        mappings.forEachEntry((id, positions) -> {
            if (positions.size() > 0) {
                blockManager.getBlock(id).getEntity().send(new OnActivatedBlocks(positions, registry));
            }
            return true;
        });
        PerformanceMonitor.endActivity();
    } else {
        PerformanceMonitor.startActivity("Generating queued Entities");
        generateQueuedEntities.remove(chunkPos).forEach(this::generateQueuedEntities);
        PerformanceMonitor.endActivity();
        // send on activate
        PerformanceMonitor.startActivity("Sending OnActivateBlocks");
        mappings.forEachEntry((id, positions) -> {
            if (positions.size() > 0) {
                blockManager.getBlock(id).getEntity().send(new OnActivatedBlocks(positions, registry));
            }
            return true;
        });
        PerformanceMonitor.endActivity();
        worldEntity.send(new OnChunkGenerated(chunkPos));
    }
    worldEntity.send(new OnChunkLoaded(chunkPos));
}
Also used : OnChunkLoaded(org.terasology.engine.world.chunks.event.OnChunkLoaded) OnActivatedBlocks(org.terasology.engine.world.block.OnActivatedBlocks) OnChunkGenerated(org.terasology.engine.world.chunks.event.OnChunkGenerated) Vector3ic(org.joml.Vector3ic) Vector3i(org.joml.Vector3i) OnAddedBlocks(org.terasology.engine.world.block.OnAddedBlocks) TIntList(gnu.trove.list.TIntList) ChunkStore(org.terasology.engine.persistence.ChunkStore)

Aggregations

ChunkStore (org.terasology.engine.persistence.ChunkStore)6 Chunk (org.terasology.engine.world.chunks.Chunk)4 ChunkImpl (org.terasology.engine.world.chunks.internal.ChunkImpl)4 Test (org.junit.jupiter.api.Test)3 ChunkProvider (org.terasology.engine.world.chunks.ChunkProvider)3 Vector3i (org.joml.Vector3i)2 Vector3ic (org.joml.Vector3ic)2 EngineEntityManager (org.terasology.engine.entitySystem.entity.internal.EngineEntityManager)2 StorageManager (org.terasology.engine.persistence.StorageManager)2 TIntList (gnu.trove.list.TIntList)1 ByteArrayInputStream (java.io.ByteArrayInputStream)1 IOException (java.io.IOException)1 GZIPInputStream (java.util.zip.GZIPInputStream)1 Vector3f (org.joml.Vector3f)1 EntityRef (org.terasology.engine.entitySystem.entity.EntityRef)1 LocationComponent (org.terasology.engine.logic.location.LocationComponent)1 OnActivatedBlocks (org.terasology.engine.world.block.OnActivatedBlocks)1 OnAddedBlocks (org.terasology.engine.world.block.OnAddedBlocks)1 OnChunkGenerated (org.terasology.engine.world.chunks.event.OnChunkGenerated)1 OnChunkLoaded (org.terasology.engine.world.chunks.event.OnChunkLoaded)1