@@ -1,9 +1,9 @@
|
||||
--- a/net/minecraft/server/FluidTypeFlowing.java
|
||||
+++ b/net/minecraft/server/FluidTypeFlowing.java
|
||||
@@ -14,13 +14,18 @@
|
||||
import java.util.function.IntFunction;
|
||||
import java.util.function.IntPredicate;
|
||||
import java.util.function.Supplier;
|
||||
@@ -10,6 +10,11 @@
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
+// CraftBukkit start
|
||||
+import org.bukkit.block.BlockFace;
|
||||
+import org.bukkit.craftbukkit.block.CraftBlock;
|
||||
@@ -12,15 +12,7 @@
|
||||
|
||||
public abstract class FluidTypeFlowing extends FluidType {
|
||||
|
||||
public static final BlockStateBoolean FALLING = BlockProperties.h;
|
||||
public static final BlockStateInteger LEVEL = BlockProperties.ag;
|
||||
private static final ThreadLocal<Object2ByteLinkedOpenHashMap<Block.a>> e = ThreadLocal.withInitial(() -> {
|
||||
- Object2ByteLinkedOpenHashMap object2bytelinkedopenhashmap = new Object2ByteLinkedOpenHashMap(200) {
|
||||
+ Object2ByteLinkedOpenHashMap object2bytelinkedopenhashmap = new Object2ByteLinkedOpenHashMap<Block.a>(200) { // CraftBukkit - decompile error
|
||||
protected void rehash(int i) {}
|
||||
};
|
||||
|
||||
@@ -145,6 +150,15 @@
|
||||
@@ -141,6 +146,15 @@
|
||||
Fluid fluid1 = this.a((IWorldReader) generatoraccess, blockposition1, iblockdata1);
|
||||
|
||||
if (this.a(generatoraccess, blockposition, iblockdata, EnumDirection.DOWN, blockposition1, iblockdata1, generatoraccess.getFluid(blockposition1), fluid1.c())) {
|
||||
@@ -36,7 +28,7 @@
|
||||
this.a(generatoraccess, blockposition1, iblockdata1, EnumDirection.DOWN, fluid1);
|
||||
if (this.a((IWorldReader) generatoraccess, blockposition) >= 3) {
|
||||
this.a(generatoraccess, blockposition, fluid, iblockdata);
|
||||
@@ -175,6 +189,15 @@
|
||||
@@ -171,6 +185,15 @@
|
||||
IBlockData iblockdata1 = generatoraccess.getType(blockposition1);
|
||||
|
||||
if (this.a(generatoraccess, blockposition, iblockdata, enumdirection, blockposition1, iblockdata1, generatoraccess.getFluid(blockposition1), fluid1.c())) {
|
||||
@@ -52,69 +44,3 @@
|
||||
this.a(generatoraccess, blockposition1, iblockdata1, enumdirection, fluid1);
|
||||
}
|
||||
}
|
||||
@@ -307,21 +330,25 @@
|
||||
if (enumdirection1 != enumdirection) {
|
||||
BlockPosition blockposition2 = blockposition.shift(enumdirection1);
|
||||
short short0 = a(blockposition1, blockposition2);
|
||||
- Pair pair = (Pair) short2objectmap.computeIfAbsent(short0, (i) -> {
|
||||
- IBlockData iblockdata = iworldreader.getType(blockposition);
|
||||
+ // CraftBukkit start - decompile errors
|
||||
+ Pair pair = (Pair) short2objectmap.computeIfAbsent(short0, (ix) -> {
|
||||
+ IBlockData iblockdatax = iworldreader.getType(blockposition2);
|
||||
|
||||
- return Pair.of(iblockdata, iblockdata.s());
|
||||
+ return Pair.of(iblockdatax, iblockdatax.s());
|
||||
});
|
||||
+ // CraftBukkit end
|
||||
IBlockData iblockdata1 = (IBlockData) pair.getFirst();
|
||||
Fluid fluid = (Fluid) pair.getSecond();
|
||||
|
||||
if (this.a(iworldreader, this.e(), blockposition, iblockdata, enumdirection1, blockposition2, iblockdata1, fluid)) {
|
||||
- boolean flag = short2booleanmap.computeIfAbsent(short0, (i) -> {
|
||||
- BlockPosition blockposition = blockposition1.down();
|
||||
- IBlockData iblockdata = iworldreader.getType(blockposition);
|
||||
+ // CraftBukkit start - decompile errors
|
||||
+ boolean flag = short2booleanmap.computeIfAbsent(short0, (ix) -> {
|
||||
+ BlockPosition blockpositionx = blockposition2.down();
|
||||
+ IBlockData iblockdatax = iworldreader.getType(blockpositionx);
|
||||
|
||||
- return this.a((IBlockAccess) iworldreader, this.e(), blockposition1, iblockdata1, blockposition, iblockdata);
|
||||
+ return this.a((IBlockAccess) iworldreader, this.e(), blockposition2, iblockdata1, blockpositionx, iblockdatax);
|
||||
});
|
||||
+ // CraftBukkit end
|
||||
|
||||
if (flag) {
|
||||
return i;
|
||||
@@ -383,22 +410,26 @@
|
||||
EnumDirection enumdirection = (EnumDirection) iterator.next();
|
||||
BlockPosition blockposition1 = blockposition.shift(enumdirection);
|
||||
short short0 = a(blockposition, blockposition1);
|
||||
- Pair pair = (Pair) short2objectopenhashmap.computeIfAbsent(short0, (i) -> {
|
||||
- IBlockData iblockdata = iworldreader.getType(blockposition);
|
||||
+ // CraftBukkit start - decompile errors
|
||||
+ Pair pair = (Pair) short2objectopenhashmap.computeIfAbsent(short0, (ix) -> {
|
||||
+ IBlockData iblockdatax = iworldreader.getType(blockposition1);
|
||||
|
||||
- return Pair.of(iblockdata, iblockdata.s());
|
||||
+ return Pair.of(iblockdatax, iblockdatax.s());
|
||||
});
|
||||
+ // CraftBukkit end
|
||||
IBlockData iblockdata1 = (IBlockData) pair.getFirst();
|
||||
Fluid fluid = (Fluid) pair.getSecond();
|
||||
Fluid fluid1 = this.a(iworldreader, blockposition1, iblockdata1);
|
||||
|
||||
if (this.a(iworldreader, fluid1.c(), blockposition, iblockdata, enumdirection, blockposition1, iblockdata1, fluid)) {
|
||||
BlockPosition blockposition2 = blockposition1.down();
|
||||
- boolean flag = short2booleanopenhashmap.computeIfAbsent(short0, (i) -> {
|
||||
- IBlockData iblockdata = iworldreader.getType(blockposition);
|
||||
+ // CraftBukkit start - decompile errors
|
||||
+ boolean flag = short2booleanopenhashmap.computeIfAbsent(short0, (ix) -> {
|
||||
+ IBlockData iblockdatax = iworldreader.getType(blockposition2);
|
||||
|
||||
- return this.a((IBlockAccess) iworldreader, this.e(), blockposition1, iblockdata1, blockposition, iblockdata);
|
||||
+ return this.a((IBlockAccess) iworldreader, this.e(), blockposition1, iblockdata1, blockposition2, iblockdatax);
|
||||
});
|
||||
+ // CraftBukkit end
|
||||
int j;
|
||||
|
||||
if (flag) {
|
||||
|
||||
Reference in New Issue
Block a user