diff --git a/forge1710/src/main/java/com/boydti/fawe/forge/v1710/ForgeChunk_All.java b/forge1710/src/main/java/com/boydti/fawe/forge/v1710/ForgeChunk_All.java index 82a801ff8..d2748773e 100644 --- a/forge1710/src/main/java/com/boydti/fawe/forge/v1710/ForgeChunk_All.java +++ b/forge1710/src/main/java/com/boydti/fawe/forge/v1710/ForgeChunk_All.java @@ -19,6 +19,7 @@ import java.util.Map; import java.util.Set; import java.util.UUID; +import com.boydti.fawe.object.visitor.FaweChunkVisitor; import net.minecraft.entity.Entity; import net.minecraft.entity.EntityList; import net.minecraft.entity.player.EntityPlayer; @@ -85,12 +86,33 @@ public NibbleArray getExtendedIdArray(int i) { return extended[i]; } + @Override public int getBlockCombinedId(int x, int y, int z) { int combined = super.getBlockCombinedId(x, y, z); return combined == 1 ? 0 : combined; } + @Override + public void forEachQueuedBlock(FaweChunkVisitor onEach) { + for (int y = 0; y < HEIGHT; y++) { + for (int z = 0; z < 16; z++) { + for (int x = 0; x < 16; x++) { + char[] array = getIdArray(FaweCache.getI(y, z, x)); + if (array == null) { + continue; + } + char raw = array[FaweCache.getJ(y, z, x)]; + if (raw == 0) { + continue; + } + int combined = raw == 1 ? 0 : raw; + onEach.run(x, y, z, combined); + } + } + } + } + @Override public void setBlock(int x, int y, int z, int id) { setBlock(x, y, z, id, 0);