diff --git a/Spigot-Server-Patches/Optimize-draining.patch b/Spigot-Server-Patches/Optimize-draining.patch new file mode 100644 index 0000000000..679bf19e29 --- /dev/null +++ b/Spigot-Server-Patches/Optimize-draining.patch @@ -0,0 +1,46 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Byteflux +Date: Fri, 10 Apr 2015 02:24:20 -0700 +Subject: [PATCH] Optimize draining + + +diff --git a/src/main/java/net/minecraft/server/BlockFlowing.java b/src/main/java/net/minecraft/server/BlockFlowing.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/BlockFlowing.java ++++ b/src/main/java/net/minecraft/server/BlockFlowing.java +@@ -0,0 +0,0 @@ public class BlockFlowing extends BlockFluids { + iblockdata = iblockdata.set(BlockFlowing.LEVEL, Integer.valueOf(i1)); + world.setTypeAndData(blockposition, iblockdata, 2); + world.a(blockposition, (Block) this, j); +- world.applyPhysics(blockposition, this); ++ // PaperSpigot start - Optimize draining ++ if (world.paperSpigotConfig.optimizeDraining) { ++ world.d(blockposition.west(), this); ++ world.d(blockposition.east(), this); ++ world.d(blockposition.up(), this); ++ world.d(blockposition.north(), this); ++ world.d(blockposition.south(), this); ++ world.spigotConfig.antiXrayInstance.updateNearbyBlocks(world, blockposition); // Spigot ++ } else { ++ world.applyPhysics(blockposition, this); ++ } ++ // PaperSpigot end + } + } + } else { +diff --git a/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java b/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java ++++ b/src/main/java/org/github/paperspigot/PaperSpigotWorldConfig.java +@@ -0,0 +0,0 @@ public class PaperSpigotWorldConfig + useAsyncLighting = getBoolean( "use-async-lighting", false ); + log( "World async lighting: " + useAsyncLighting ); + } ++ ++ public boolean optimizeDraining; ++ private void optimizeDraining() ++ { ++ optimizeDraining = getBoolean( "optimize-draining", false ); ++ } + } +-- \ No newline at end of file