CavePVP-Stuff/cSpigot-master/spigot-server-Patches/0067-Fast-draining.patch

102 lines
4.4 KiB
Diff
Raw Permalink Normal View History

2023-05-01 20:59:40 +02:00
From 030c40763669f96bfd691e81a5b4bd973995c4a0 Mon Sep 17 00:00:00 2001
From: Byteflux <byte@byteflux.net>
Date: Tue, 23 Jun 2015 23:32:56 -0700
Subject: [PATCH] Fast draining
diff --git a/src/main/java/net/minecraft/server/BlockFlowing.java b/src/main/java/net/minecraft/server/BlockFlowing.java
index cc45d601d..2b5866f2f 100644
--- a/src/main/java/net/minecraft/server/BlockFlowing.java
+++ b/src/main/java/net/minecraft/server/BlockFlowing.java
@@ -73,7 +73,7 @@ public class BlockFlowing extends BlockFluids {
}
}
- if (this.material == Material.LAVA && l < 8 && j1 < 8 && j1 > l && random.nextInt(4) != 0) {
+ if (!world.paperSpigotConfig.fastDrainLava && this.material == Material.LAVA && l < 8 && j1 < 8 && j1 > l && random.nextInt(4) != 0) { // PaperSpigot
i1 *= 4;
}
@@ -83,7 +83,7 @@ public class BlockFlowing extends BlockFluids {
}
} else {
l = j1;
- if (j1 < 0) {
+ if (j1 < 0 || canFastDrain(world, i, j, k)) { // PaperSpigot - Fast draining
world.setAir(i, j, k);
} else {
world.setData(i, j, k, j1, 2);
@@ -319,4 +319,52 @@ public class BlockFlowing extends BlockFluids {
}
return super.a(world);
}
+
+ /**
+ * PaperSpigot - Data check method for fast draining
+ */
+ public int getData(World world, int x, int y, int z) {
+ int data = this.e(world, x, y, z);
+ return data < 8 ? data : 0;
+ }
+
+ /**
+ * PaperSpigot - Checks surrounding blocks to determine if block can be fast drained
+ */
+ public boolean canFastDrain(World world, int x, int y, int z) {
+ boolean result = false;
+ int data = getData(world, x, y, z);
+ if (this.material == Material.WATER) {
+ if (world.paperSpigotConfig.fastDrainWater) {
+ result = true;
+ if (getData(world, x, y - 1, z) < 0) {
+ result = false;
+ } else if (world.getType(x, y, z - 1).getMaterial() == Material.WATER && getData(world, x, y, z - 1) < data) {
+ result = false;
+ } else if (world.getType(x, y, z + 1).getMaterial() == Material.WATER && getData(world, x, y, z + 1) < data) {
+ result = false;
+ } else if (world.getType(x - 1, y, z).getMaterial() == Material.WATER && getData(world, x - 1, y, z) < data) {
+ result = false;
+ } else if (world.getType(x + 1, y, z).getMaterial() == Material.WATER && getData(world, x + 1, y, z) < data) {
+ result = false;
+ }
+ }
+ } else if (this.material == Material.LAVA) {
+ if (world.paperSpigotConfig.fastDrainLava) {
+ result = true;
+ if (getData(world, x, y - 1, z) < 0 || world.getType(x, y + 1, z).getMaterial() != Material.AIR) {
+ result = false;
+ } else if (world.getType(x, y, z - 1).getMaterial() == Material.LAVA && getData(world, x, y, z - 1) < data) {
+ result = false;
+ } else if (world.getType(x, y, z + 1).getMaterial() == Material.LAVA && getData(world, x, y, z + 1) < data) {
+ result = false;
+ } else if (world.getType(x - 1, y, z).getMaterial() == Material.LAVA && getData(world, x - 1, y, z) < data) {
+ result = false;
+ } else if (world.getType(x + 1, y, z).getMaterial() == Material.LAVA && getData(world, x + 1, y, z) < data) {
+ result = false;
+ }
+ }
+ }
+ return result;
+ }
}
diff --git a/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java b/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java
index ec27f7934..0aea20787 100644
--- a/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java
+++ b/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java
@@ -265,4 +265,12 @@ public class PaperSpigotWorldConfig
{
optimizeExplosions = getBoolean( "optimize-explosions", false );
}
+
+ public boolean fastDrainLava;
+ public boolean fastDrainWater;
+ private void fastDraining()
+ {
+ fastDrainLava = getBoolean( "fast-drain.lava", false );
+ fastDrainWater = getBoolean( "fast-drain.water", false );
+ }
}
--
2.13.3