mirror of
https://github.com/plexusorg/Plex-FAWE.git
synced 2025-07-16 03:24:03 +00:00
replace synchronisation with Striped access semaphore locks
This commit is contained in:
@@ -9,6 +9,7 @@ import com.boydti.fawe.object.collection.BitArray;
|
||||
import com.boydti.fawe.util.MathMan;
|
||||
import com.boydti.fawe.util.ReflectionUtils;
|
||||
import com.boydti.fawe.util.TaskManager;
|
||||
import com.google.common.util.concurrent.Striped;
|
||||
import com.sk89q.worldedit.math.BlockVector3;
|
||||
import com.sk89q.worldedit.world.block.BlockState;
|
||||
import com.sk89q.worldedit.world.block.BlockTypesCache;
|
||||
@@ -18,6 +19,7 @@ import java.lang.invoke.MethodHandles;
|
||||
import java.lang.reflect.Method;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.concurrent.Semaphore;
|
||||
import java.util.concurrent.locks.ReentrantLock;
|
||||
import net.jpountz.util.UnsafeUtils;
|
||||
import net.minecraft.server.v1_15_R1.*;
|
||||
@@ -52,6 +54,8 @@ public final class BukkitAdapter_1_15 extends NMSAdapter {
|
||||
|
||||
private static final Field fieldLock;
|
||||
|
||||
private static final Striped<Semaphore> stripe = Striped.lazyWeakSemaphore(5, 1);
|
||||
|
||||
static {
|
||||
try {
|
||||
fieldSize = DataPaletteBlock.class.getDeclaredField("i");
|
||||
@@ -122,10 +126,15 @@ public final class BukkitAdapter_1_15 extends NMSAdapter {
|
||||
}
|
||||
}
|
||||
|
||||
public static Chunk ensureLoaded(net.minecraft.server.v1_15_R1.World nmsWorld, int X, int Z) {
|
||||
Chunk nmsChunk;
|
||||
synchronized (nmsWorld) {
|
||||
public static Chunk ensureLoaded(World nmsWorld, int X, int Z) {
|
||||
Semaphore lock = stripe.get(nmsWorld.hashCode());
|
||||
Chunk nmsChunk = null;
|
||||
try {
|
||||
lock.acquire();
|
||||
nmsChunk = nmsWorld.getChunkIfLoaded(X, Z);
|
||||
} catch (InterruptedException ignored) {
|
||||
} finally {
|
||||
lock.release();
|
||||
}
|
||||
if (nmsChunk != null) {
|
||||
return nmsChunk;
|
||||
@@ -134,7 +143,8 @@ public final class BukkitAdapter_1_15 extends NMSAdapter {
|
||||
return nmsWorld.getChunkAt(X, Z);
|
||||
}
|
||||
if (PaperLib.isPaper()) {
|
||||
synchronized (nmsWorld) {
|
||||
try {
|
||||
lock.acquire();
|
||||
CraftWorld craftWorld = nmsWorld.getWorld();
|
||||
CompletableFuture<org.bukkit.Chunk> future = craftWorld.getChunkAtAsync(X, Z, true);
|
||||
try {
|
||||
@@ -143,6 +153,9 @@ public final class BukkitAdapter_1_15 extends NMSAdapter {
|
||||
} catch (Throwable e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
} catch (InterruptedException ignored) {
|
||||
} finally {
|
||||
lock.release();
|
||||
}
|
||||
}
|
||||
// TODO optimize
|
||||
|
Reference in New Issue
Block a user