2015-05-25 18:37:24 +08:00
|
|
|
--- a/net/minecraft/server/BlockCactus.java
|
|
|
|
+++ b/net/minecraft/server/BlockCactus.java
|
2014-11-26 05:32:16 +08:00
|
|
|
@@ -3,6 +3,8 @@
|
|
|
|
import java.util.Iterator;
|
|
|
|
import java.util.Random;
|
|
|
|
|
|
|
|
+import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit
|
|
|
|
+
|
|
|
|
public class BlockCactus extends Block {
|
|
|
|
|
|
|
|
public static final BlockStateInteger AGE = BlockStateInteger.of("age", 0, 15);
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -30,9 +32,10 @@
|
2014-12-11 08:13:27 +08:00
|
|
|
int j = ((Integer) iblockdata.get(BlockCactus.AGE)).intValue();
|
|
|
|
|
|
|
|
if (j == 15) {
|
|
|
|
- world.setTypeUpdate(blockposition1, this.getBlockData());
|
2014-12-11 08:44:30 +08:00
|
|
|
+ // world.setTypeUpdate(blockposition1, this.getBlockData()); // CraftBukkit
|
2014-11-26 05:32:16 +08:00
|
|
|
IBlockData iblockdata1 = iblockdata.set(BlockCactus.AGE, Integer.valueOf(0));
|
|
|
|
|
|
|
|
+ CraftEventFactory.handleBlockGrowEvent(world, blockposition1.getX(), blockposition1.getY(), blockposition1.getZ(), this, 0); // CraftBukkit
|
2014-12-11 08:44:30 +08:00
|
|
|
world.setTypeAndData(blockposition, iblockdata1, 4);
|
2014-11-26 05:32:16 +08:00
|
|
|
this.doPhysics(world, blockposition1, iblockdata1, this);
|
|
|
|
} else {
|
2016-03-01 05:32:46 +08:00
|
|
|
@@ -87,7 +90,9 @@
|
2014-11-26 05:32:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public void a(World world, BlockPosition blockposition, IBlockData iblockdata, Entity entity) {
|
|
|
|
+ CraftEventFactory.blockDamage = world.getWorld().getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()); // CraftBukkit
|
|
|
|
entity.damageEntity(DamageSource.CACTUS, 1.0F);
|
|
|
|
+ CraftEventFactory.blockDamage = null; // CraftBukkit
|
|
|
|
}
|
|
|
|
|
|
|
|
public IBlockData fromLegacyData(int i) {
|