@@ -1,6 +1,6 @@
|
||||
--- a/net/minecraft/world/level/material/FluidTypeFlowing.java
|
||||
+++ b/net/minecraft/world/level/material/FluidTypeFlowing.java
|
||||
@@ -32,6 +32,15 @@
|
||||
@@ -31,6 +31,15 @@
|
||||
import net.minecraft.world.phys.shapes.VoxelShape;
|
||||
import net.minecraft.world.phys.shapes.VoxelShapes;
|
||||
|
||||
@@ -16,10 +16,10 @@
|
||||
public abstract class FluidTypeFlowing extends FluidType {
|
||||
|
||||
public static final BlockStateBoolean FALLING = BlockProperties.FALLING;
|
||||
@@ -132,6 +141,15 @@
|
||||
Fluid fluid1 = this.a((IWorldReader) generatoraccess, blockposition1, iblockdata1);
|
||||
@@ -131,6 +140,15 @@
|
||||
Fluid fluid1 = this.getNewLiquid(generatoraccess, blockposition1, iblockdata1);
|
||||
|
||||
if (this.a(generatoraccess, blockposition, iblockdata, EnumDirection.DOWN, blockposition1, iblockdata1, generatoraccess.getFluid(blockposition1), fluid1.getType())) {
|
||||
if (this.canSpreadTo(generatoraccess, blockposition, iblockdata, EnumDirection.DOWN, blockposition1, iblockdata1, generatoraccess.getFluidState(blockposition1), fluid1.getType())) {
|
||||
+ // CraftBukkit start
|
||||
+ org.bukkit.block.Block source = CraftBlock.at(generatoraccess, blockposition);
|
||||
+ BlockFromToEvent event = new BlockFromToEvent(source, BlockFace.DOWN);
|
||||
@@ -29,13 +29,13 @@
|
||||
+ return;
|
||||
+ }
|
||||
+ // CraftBukkit end
|
||||
this.a(generatoraccess, blockposition1, iblockdata1, EnumDirection.DOWN, fluid1);
|
||||
if (this.a((IWorldReader) generatoraccess, blockposition) >= 3) {
|
||||
this.a(generatoraccess, blockposition, fluid, iblockdata);
|
||||
@@ -162,6 +180,15 @@
|
||||
IBlockData iblockdata1 = generatoraccess.getType(blockposition1);
|
||||
this.spreadTo(generatoraccess, blockposition1, iblockdata1, EnumDirection.DOWN, fluid1);
|
||||
if (this.sourceNeighborCount(generatoraccess, blockposition) >= 3) {
|
||||
this.spreadToSides(generatoraccess, blockposition, fluid, iblockdata);
|
||||
@@ -161,6 +179,15 @@
|
||||
IBlockData iblockdata1 = generatoraccess.getBlockState(blockposition1);
|
||||
|
||||
if (this.a(generatoraccess, blockposition, iblockdata, enumdirection, blockposition1, iblockdata1, generatoraccess.getFluid(blockposition1), fluid1.getType())) {
|
||||
if (this.canSpreadTo(generatoraccess, blockposition, iblockdata, enumdirection, blockposition1, iblockdata1, generatoraccess.getFluidState(blockposition1), fluid1.getType())) {
|
||||
+ // CraftBukkit start
|
||||
+ org.bukkit.block.Block source = CraftBlock.at(generatoraccess, blockposition);
|
||||
+ BlockFromToEvent event = new BlockFromToEvent(source, org.bukkit.craftbukkit.block.CraftBlock.notchToBlockFace(enumdirection));
|
||||
@@ -45,33 +45,33 @@
|
||||
+ continue;
|
||||
+ }
|
||||
+ // CraftBukkit end
|
||||
this.a(generatoraccess, blockposition1, iblockdata1, enumdirection, fluid1);
|
||||
this.spreadTo(generatoraccess, blockposition1, iblockdata1, enumdirection, fluid1);
|
||||
}
|
||||
}
|
||||
@@ -440,12 +467,23 @@
|
||||
@@ -439,12 +466,23 @@
|
||||
|
||||
if (fluid1.isEmpty()) {
|
||||
fluid = fluid1;
|
||||
- world.setTypeAndData(blockposition, Blocks.AIR.getBlockData(), 3);
|
||||
- world.setBlock(blockposition, Blocks.AIR.defaultBlockState(), 3);
|
||||
+ // CraftBukkit start
|
||||
+ FluidLevelChangeEvent event = CraftEventFactory.callFluidLevelChangeEvent(world, blockposition, Blocks.AIR.getBlockData());
|
||||
+ FluidLevelChangeEvent event = CraftEventFactory.callFluidLevelChangeEvent(world, blockposition, Blocks.AIR.defaultBlockState());
|
||||
+ if (event.isCancelled()) {
|
||||
+ return;
|
||||
+ }
|
||||
+ world.setTypeAndData(blockposition, ((CraftBlockData) event.getNewData()).getState(), 3);
|
||||
+ world.setBlock(blockposition, ((CraftBlockData) event.getNewData()).getState(), 3);
|
||||
+ // CraftBukkit end
|
||||
} else if (!fluid1.equals(fluid)) {
|
||||
fluid = fluid1;
|
||||
IBlockData iblockdata = fluid1.getBlockData();
|
||||
IBlockData iblockdata = fluid1.createLegacyBlock();
|
||||
-
|
||||
- world.setTypeAndData(blockposition, iblockdata, 2);
|
||||
- world.setBlock(blockposition, iblockdata, 2);
|
||||
+ // CraftBukkit start
|
||||
+ FluidLevelChangeEvent event = CraftEventFactory.callFluidLevelChangeEvent(world, blockposition, iblockdata);
|
||||
+ if (event.isCancelled()) {
|
||||
+ return;
|
||||
+ }
|
||||
+ world.setTypeAndData(blockposition, ((CraftBlockData) event.getNewData()).getState(), 2);
|
||||
+ world.setBlock(blockposition, ((CraftBlockData) event.getNewData()).getState(), 2);
|
||||
+ // CraftBukkit end
|
||||
world.getFluidTickList().a(blockposition, fluid1.getType(), i);
|
||||
world.applyPhysics(blockposition, iblockdata.getBlock());
|
||||
world.scheduleTick(blockposition, fluid1.getType(), i);
|
||||
world.updateNeighborsAt(blockposition, iblockdata.getBlock());
|
||||
}
|
||||
|
||||
@@ -3,42 +3,42 @@
|
||||
@@ -85,6 +85,13 @@
|
||||
|
||||
if (iblockdata.isAir()) {
|
||||
if (this.a((IWorldReader) world, blockposition1)) {
|
||||
if (this.hasFlammableNeighbours(world, blockposition1)) {
|
||||
+ // CraftBukkit start - Prevent lava putting something on fire
|
||||
+ if (world.getType(blockposition1).getBlock() != Blocks.FIRE) {
|
||||
+ if (world.getBlockState(blockposition1).getBlock() != Blocks.FIRE) {
|
||||
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockIgniteEvent(world, blockposition1, blockposition).isCancelled()) {
|
||||
+ continue;
|
||||
+ }
|
||||
+ }
|
||||
+ // CraftBukkit end
|
||||
world.setTypeUpdate(blockposition1, BlockFireAbstract.a((IBlockAccess) world, blockposition1));
|
||||
world.setBlockAndUpdate(blockposition1, BlockFireAbstract.getState(world, blockposition1));
|
||||
return;
|
||||
}
|
||||
@@ -101,6 +108,14 @@
|
||||
}
|
||||
|
||||
if (world.isEmpty(blockposition2.up()) && this.b(world, blockposition2)) {
|
||||
if (world.isEmptyBlock(blockposition2.above()) && this.isFlammable(world, blockposition2)) {
|
||||
+ // CraftBukkit start - Prevent lava putting something on fire
|
||||
+ BlockPosition up = blockposition2.up();
|
||||
+ if (world.getType(up).getBlock() != Blocks.FIRE) {
|
||||
+ BlockPosition up = blockposition2.above();
|
||||
+ if (world.getBlockState(up).getBlock() != Blocks.FIRE) {
|
||||
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockIgniteEvent(world, up, blockposition).isCancelled()) {
|
||||
+ continue;
|
||||
+ }
|
||||
+ }
|
||||
+ // CraftBukkit end
|
||||
world.setTypeUpdate(blockposition2.up(), BlockFireAbstract.a((IBlockAccess) world, blockposition2));
|
||||
world.setBlockAndUpdate(blockposition2.above(), BlockFireAbstract.getState(world, blockposition2));
|
||||
}
|
||||
}
|
||||
@@ -196,7 +211,11 @@
|
||||
|
||||
if (this.a((Tag) TagsFluid.LAVA) && fluid1.a((Tag) TagsFluid.WATER)) {
|
||||
if (this.is(TagsFluid.LAVA) && fluid1.is((Tag) TagsFluid.WATER)) {
|
||||
if (iblockdata.getBlock() instanceof BlockFluids) {
|
||||
- generatoraccess.setTypeAndData(blockposition, Blocks.STONE.getBlockData(), 3);
|
||||
- generatoraccess.setBlock(blockposition, Blocks.STONE.defaultBlockState(), 3);
|
||||
+ // CraftBukkit start
|
||||
+ if (!org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockFormEvent(generatoraccess.getMinecraftWorld(), blockposition, Blocks.STONE.getBlockData(), 3)) {
|
||||
+ if (!org.bukkit.craftbukkit.event.CraftEventFactory.handleBlockFormEvent(generatoraccess.getMinecraftWorld(), blockposition, Blocks.STONE.defaultBlockState(), 3)) {
|
||||
+ return;
|
||||
+ }
|
||||
+ // CraftBukkit end
|
||||
}
|
||||
|
||||
this.a(generatoraccess, blockposition);
|
||||
this.fizz(generatoraccess, blockposition);
|
||||
|
||||
Reference in New Issue
Block a user