mirror of
https://github.com/plexusorg/Plex-FAWE.git
synced 2025-01-10 01:37:37 +00:00
filter regions?
This commit is contained in:
parent
4116adcfef
commit
27ed596027
@ -0,0 +1,16 @@
|
|||||||
|
package com.boydti.fawe.beta;
|
||||||
|
|
||||||
|
public abstract class DelegateFilter implements IDelegateFilter {
|
||||||
|
private final Filter parent;
|
||||||
|
|
||||||
|
public DelegateFilter(Filter parent) {
|
||||||
|
this.parent = parent;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public Filter getParent() {
|
||||||
|
return parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public abstract Filter fork();
|
||||||
|
}
|
@ -1,7 +1,10 @@
|
|||||||
package com.boydti.fawe.beta;
|
package com.boydti.fawe.beta;
|
||||||
|
|
||||||
|
import com.sk89q.worldedit.regions.Region;
|
||||||
import com.sk89q.worldedit.world.block.BaseBlock;
|
import com.sk89q.worldedit.world.block.BaseBlock;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A filter is an interface used for setting blocks
|
* A filter is an interface used for setting blocks
|
||||||
*/
|
*/
|
||||||
@ -13,8 +16,8 @@ public interface Filter {
|
|||||||
* @param cz
|
* @param cz
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
default boolean appliesChunk(final int cx, final int cz) {
|
default Filter appliesChunk(final int cx, final int cz) {
|
||||||
return true;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -25,10 +28,14 @@ public interface Filter {
|
|||||||
* @param chunk
|
* @param chunk
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
default IChunk applyChunk(final IChunk chunk) {
|
default IChunk applyChunk(final IChunk chunk, @Nullable Region region) {
|
||||||
return chunk;
|
return chunk;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
default Filter appliesLayer(IChunk chunk, int layer) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Make changes to the block here<br>
|
* Make changes to the block here<br>
|
||||||
* - e.g. block.setId(...)<br>
|
* - e.g. block.setId(...)<br>
|
||||||
|
@ -1,15 +1,18 @@
|
|||||||
package com.boydti.fawe.beta;
|
package com.boydti.fawe.beta;
|
||||||
|
|
||||||
import com.sk89q.jnbt.CompoundTag;
|
import com.sk89q.jnbt.CompoundTag;
|
||||||
|
import com.sk89q.worldedit.regions.Region;
|
||||||
import com.sk89q.worldedit.world.block.BaseBlock;
|
import com.sk89q.worldedit.world.block.BaseBlock;
|
||||||
import com.sk89q.worldedit.world.block.BlockState;
|
import com.sk89q.worldedit.world.block.BlockState;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public interface FilterBlock {
|
public interface FilterBlock {
|
||||||
FilterBlock init(IQueueExtent queue);
|
FilterBlock init(IQueueExtent queue);
|
||||||
|
|
||||||
FilterBlock init(int X, int Z, IGetBlocks chunk);
|
FilterBlock init(int X, int Z, IGetBlocks chunk);
|
||||||
|
|
||||||
void filter(IGetBlocks get, ISetBlocks set, int layer, Filter filter);
|
void filter(IGetBlocks get, ISetBlocks set, int layer, Filter filter, @Nullable Region region);
|
||||||
|
|
||||||
void setOrdinal(int ordinal);
|
void setOrdinal(int ordinal);
|
||||||
|
|
||||||
|
@ -0,0 +1,54 @@
|
|||||||
|
package com.boydti.fawe.beta;
|
||||||
|
|
||||||
|
public interface IDelegateFilter extends Filter {
|
||||||
|
Filter getParent();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default Filter appliesChunk(int cx, int cz) {
|
||||||
|
Filter copy = getParent().appliesChunk(cx, cz);
|
||||||
|
if (copy == null) return null;
|
||||||
|
if (copy != getParent()) {
|
||||||
|
return newInstance(copy);
|
||||||
|
} else {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default IChunk applyChunk(IChunk chunk) {
|
||||||
|
return getParent().applyChunk(chunk);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default Filter appliesLayer(IChunk chunk, int layer) {
|
||||||
|
Filter copy = getParent().appliesLayer(chunk, layer);
|
||||||
|
if (copy == null) return null;
|
||||||
|
if (copy != getParent()) {
|
||||||
|
return newInstance(copy);
|
||||||
|
} else {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default void applyBlock(FilterBlock block) {
|
||||||
|
getParent().applyBlock(block);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default void finishChunk(IChunk chunk) {
|
||||||
|
getParent().finishChunk(chunk);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default void join() {
|
||||||
|
getParent().join();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default Filter fork() {
|
||||||
|
return newInstance(getParent().fork());
|
||||||
|
}
|
||||||
|
|
||||||
|
Filter newInstance(Filter other);
|
||||||
|
}
|
@ -27,10 +27,6 @@ public interface ISetBlocks extends IBlocks {
|
|||||||
|
|
||||||
void removeEntity(UUID uuid);
|
void removeEntity(UUID uuid);
|
||||||
|
|
||||||
default void optimize() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
BlockState getBlock(int x, int y, int z);
|
BlockState getBlock(int x, int y, int z);
|
||||||
|
|
||||||
char[] getArray(int layer);
|
char[] getArray(int layer);
|
||||||
|
@ -0,0 +1,37 @@
|
|||||||
|
package com.boydti.fawe.beta;
|
||||||
|
|
||||||
|
import com.sk89q.worldedit.regions.Region;
|
||||||
|
|
||||||
|
public class RegionFilter extends DelegateFilter {
|
||||||
|
private final Region region;
|
||||||
|
|
||||||
|
public RegionFilter(Filter parent, Region region) {
|
||||||
|
super(parent);
|
||||||
|
this.region = region;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Filter appliesChunk(int cx, int cz) {
|
||||||
|
return getParent().appliesChunk(cx, cz);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Filter appliesLayer(IChunk chunk, int layer) {
|
||||||
|
return getParent().appliesLayer(chunk, layer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void applyBlock(FilterBlock block) {
|
||||||
|
getParent().applyBlock(block);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void finishChunk(IChunk chunk) {
|
||||||
|
getParent().finishChunk(chunk);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Filter newInstance(Filter other) {
|
||||||
|
return new RegionFilter(other, region);
|
||||||
|
}
|
||||||
|
}
|
@ -170,13 +170,13 @@ public abstract class QueueHandler implements Trimable, Runnable {
|
|||||||
X = pos.getX();
|
X = pos.getX();
|
||||||
Z = pos.getZ();
|
Z = pos.getZ();
|
||||||
}
|
}
|
||||||
|
if (!newFilter.appliesChunk(X, Z)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
IChunk chunk = queue.getCachedChunk(X, Z);
|
IChunk chunk = queue.getCachedChunk(X, Z);
|
||||||
// Initialize
|
// Initialize
|
||||||
chunk.init(queue, X, Z);
|
chunk.init(queue, X, Z);
|
||||||
|
|
||||||
if (!newFilter.appliesChunk(X, Z)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
chunk = newFilter.applyChunk(chunk);
|
chunk = newFilter.applyChunk(chunk);
|
||||||
|
|
||||||
if (chunk == null) continue;
|
if (chunk == null) continue;
|
||||||
|
@ -1,8 +1,5 @@
|
|||||||
package com.boydti.fawe.beta.implementation.blocks;
|
package com.boydti.fawe.beta.implementation.blocks;
|
||||||
|
|
||||||
import com.boydti.fawe.beta.CharFilterBlock;
|
|
||||||
import com.boydti.fawe.beta.Filter;
|
|
||||||
import com.boydti.fawe.beta.FilterBlock;
|
|
||||||
import com.boydti.fawe.beta.IGetBlocks;
|
import com.boydti.fawe.beta.IGetBlocks;
|
||||||
import com.sk89q.worldedit.world.block.BaseBlock;
|
import com.sk89q.worldedit.world.block.BaseBlock;
|
||||||
import com.sk89q.worldedit.world.block.BlockState;
|
import com.sk89q.worldedit.world.block.BlockState;
|
||||||
|
@ -41,7 +41,7 @@ public abstract class ChunkHolder implements IChunk, Supplier<IGetBlocks> {
|
|||||||
final ISetBlocks set = getOrCreateSet();
|
final ISetBlocks set = getOrCreateSet();
|
||||||
block = block.init(X, Z, get);
|
block = block.init(X, Z, get);
|
||||||
for (int layer = 0; layer < 16; layer++) {
|
for (int layer = 0; layer < 16; layer++) {
|
||||||
if (!get.hasSection(layer)) continue;
|
if (!get.hasSection(layer) || !filter.appliesLayer(this, layer)) continue;
|
||||||
block.filter(get, set, layer, filter);
|
block.filter(get, set, layer, filter);
|
||||||
}
|
}
|
||||||
filter.finishChunk(this);
|
filter.finishChunk(this);
|
||||||
@ -98,13 +98,6 @@ public abstract class ChunkHolder implements IChunk, Supplier<IGetBlocks> {
|
|||||||
return get();
|
return get();
|
||||||
}
|
}
|
||||||
|
|
||||||
// @Override
|
|
||||||
// public void optimize() {
|
|
||||||
// if (set != null) {
|
|
||||||
// set.optimize();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(final IQueueExtent extent, final int X, final int Z) {
|
public void init(final IQueueExtent extent, final int X, final int Z) {
|
||||||
this.extent = extent;
|
this.extent = extent;
|
||||||
|
Loading…
Reference in New Issue
Block a user