mirror of
https://github.com/plexusorg/Plex-FAWE.git
synced 2024-09-19 13:58:22 +00:00
8c0195970b
* Consistenty use javax annotations. - Unfortunately jetbrains annotations seem to be exposed transitively via core somewhere, but with the correct IDE settings, annotations can be defaulted to javax - Cleaning up of import order in #1195 - Must be merged before #1195 * Add and apply .editorconfig from P2 - Does not rearrange entries * Address some comments * add back some javadoc comments * Address final comments Co-authored-by: NotMyFault <mc.cache@web.de>
97 lines
2.6 KiB
Java
97 lines
2.6 KiB
Java
package com.fastasyncworldedit.core.extent;
|
|
|
|
import com.fastasyncworldedit.core.object.FaweLimit;
|
|
import com.fastasyncworldedit.core.queue.IChunk;
|
|
import com.fastasyncworldedit.core.queue.IChunkGet;
|
|
import com.fastasyncworldedit.core.queue.IChunkSet;
|
|
import com.sk89q.worldedit.extent.Extent;
|
|
import com.sk89q.worldedit.regions.Region;
|
|
import com.sk89q.worldedit.regions.RegionIntersection;
|
|
|
|
import java.util.Arrays;
|
|
import java.util.Collection;
|
|
import java.util.concurrent.Future;
|
|
|
|
public class MultiRegionExtent extends FaweRegionExtent {
|
|
|
|
private final RegionIntersection intersection;
|
|
private final Region[] regions;
|
|
private Region region;
|
|
private int index;
|
|
|
|
/**
|
|
* Create a new instance.
|
|
*
|
|
* @param extent the extent
|
|
*/
|
|
public MultiRegionExtent(Extent extent, FaweLimit limit, Region[] regions) {
|
|
super(extent, limit);
|
|
this.index = 0;
|
|
this.region = regions[0];
|
|
this.regions = regions;
|
|
this.intersection = new RegionIntersection(Arrays.asList(regions));
|
|
}
|
|
|
|
@Override
|
|
public boolean contains(int x, int y, int z) {
|
|
if (region.contains(x, y, z)) {
|
|
return true;
|
|
}
|
|
for (int i = 0; i < regions.length; i++) {
|
|
if (i != index) {
|
|
Region current = regions[i];
|
|
if (current.contains(x, y, z)) {
|
|
region = current;
|
|
index = i;
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public boolean processGet(int chunkX, int chunkZ) {
|
|
for (Region region : regions) {
|
|
if (region.containsChunk(chunkX, chunkZ)) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public boolean contains(int x, int z) {
|
|
if (region.contains(x, z)) {
|
|
return true;
|
|
}
|
|
for (int i = 0; i < regions.length; i++) {
|
|
if (i != index) {
|
|
Region current = regions[i];
|
|
if (current.contains(x, z)) {
|
|
region = current;
|
|
index = i;
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public Collection<Region> getRegions() {
|
|
return Arrays.asList(regions);
|
|
}
|
|
|
|
@Override
|
|
public IChunkSet processSet(IChunk chunk, IChunkGet get, IChunkSet set) {
|
|
return intersection.processSet(chunk, get, set);
|
|
}
|
|
|
|
@Override
|
|
public Future<IChunkSet> postProcessSet(IChunk chunk, IChunkGet get, IChunkSet set) {
|
|
return intersection.postProcessSet(chunk, get, set);
|
|
}
|
|
|
|
}
|