summaryrefslogtreecommitdiffstats
path: root/nms-patches/Explosion.patch
diff options
context:
space:
mode:
authorThinkofdeath <thinkofdeath@spigotmc.org>2015-03-22 19:42:46 +0000
committerThinkofdeath <thinkofdeath@spigotmc.org>2015-03-22 19:42:46 +0000
commite387d8dc7752a7f03e6baa1dadaf66ec2e7e3512 (patch)
tree1044384b20d328d5cea040e4732c9a1e4a02dd2d /nms-patches/Explosion.patch
parent22c613d8690880ca7d269db709054b4886429d98 (diff)
downloadcraftbukkit-e387d8dc7752a7f03e6baa1dadaf66ec2e7e3512.tar
craftbukkit-e387d8dc7752a7f03e6baa1dadaf66ec2e7e3512.tar.gz
craftbukkit-e387d8dc7752a7f03e6baa1dadaf66ec2e7e3512.tar.lz
craftbukkit-e387d8dc7752a7f03e6baa1dadaf66ec2e7e3512.tar.xz
craftbukkit-e387d8dc7752a7f03e6baa1dadaf66ec2e7e3512.zip
Implement BlockExplodeEvent
Diffstat (limited to 'nms-patches/Explosion.patch')
-rw-r--r--nms-patches/Explosion.patch46
1 files changed, 31 insertions, 15 deletions
diff --git a/nms-patches/Explosion.patch b/nms-patches/Explosion.patch
index bbbdf5b2..9d351af5 100644
--- a/nms-patches/Explosion.patch
+++ b/nms-patches/Explosion.patch
@@ -1,6 +1,6 @@
---- /home/matt/mc-dev-private//net/minecraft/server/Explosion.java 2015-02-26 22:40:22.747608138 +0000
-+++ src/main/java/net/minecraft/server/Explosion.java 2015-02-26 22:40:22.747608138 +0000
-@@ -9,6 +9,12 @@
+--- /home/matt/mc-dev-private//net/minecraft/server/Explosion.java 2015-03-22 19:42:34.893852628 +0000
++++ src/main/java/net/minecraft/server/Explosion.java 2015-03-22 19:42:34.893852628 +0000
+@@ -9,6 +9,13 @@
import java.util.Map;
import java.util.Random;
@@ -8,12 +8,13 @@
+import org.bukkit.craftbukkit.event.CraftEventFactory;
+import org.bukkit.event.entity.EntityExplodeEvent;
+import org.bukkit.Location;
++import org.bukkit.event.block.BlockExplodeEvent;
+// CraftBukkit end
+
public class Explosion {
private final boolean a;
-@@ -18,15 +24,16 @@
+@@ -18,15 +25,16 @@
private final double posX;
private final double posY;
private final double posZ;
@@ -32,7 +33,7 @@
this.posX = d0;
this.posY = d1;
this.posZ = d2;
-@@ -35,6 +42,11 @@
+@@ -35,6 +43,11 @@
}
public void a() {
@@ -44,7 +45,7 @@
HashSet hashset = Sets.newHashSet();
boolean flag = true;
-@@ -68,7 +80,7 @@
+@@ -68,7 +81,7 @@
f -= (f2 + 0.3F) * 0.3F;
}
@@ -53,7 +54,7 @@
hashset.add(blockposition);
}
-@@ -112,7 +124,14 @@
+@@ -112,7 +125,14 @@
double d12 = (double) this.world.a(vec3d, entity.getBoundingBox());
double d13 = (1.0D - d7) * d12;
@@ -69,7 +70,7 @@
double d14 = EnchantmentProtection.a(entity, d13);
entity.motX += d8 * d14;
-@@ -140,6 +159,35 @@
+@@ -140,6 +160,50 @@
BlockPosition blockposition;
if (this.b) {
@@ -87,17 +88,32 @@
+ }
+ }
+
-+ EntityExplodeEvent event = new EntityExplodeEvent(explode, location, blockList, 0.3F);
-+ this.world.getServer().getPluginManager().callEvent(event);
++ boolean cancelled;
++ List<org.bukkit.block.Block> bukkitBlocks;
++ float yield;
++
++ if (explode != null) {
++ EntityExplodeEvent event = new EntityExplodeEvent(explode, location, blockList, 0.3F);
++ this.world.getServer().getPluginManager().callEvent(event);
++ cancelled = event.isCancelled();
++ bukkitBlocks = event.blockList();
++ yield = event.getYield();
++ } else {
++ BlockExplodeEvent event = new BlockExplodeEvent(location.getBlock(), blockList, 0.3F);
++ this.world.getServer().getPluginManager().callEvent(event);
++ cancelled = event.isCancelled();
++ bukkitBlocks = event.blockList();
++ yield = event.getYield();
++ }
+
+ this.blocks.clear();
+
-+ for (org.bukkit.block.Block bblock : event.blockList()) {
++ for (org.bukkit.block.Block bblock : bukkitBlocks) {
+ BlockPosition coords = new BlockPosition(bblock.getX(), bblock.getY(), bblock.getZ());
+ blocks.add(coords);
+ }
+
-+ if (event.isCancelled()) {
++ if (cancelled) {
+ this.wasCanceled = true;
+ return;
+ }
@@ -105,17 +121,17 @@
iterator = this.blocks.iterator();
while (iterator.hasNext()) {
-@@ -170,7 +218,8 @@
+@@ -170,7 +234,8 @@
if (block.getMaterial() != Material.AIR) {
if (block.a(this)) {
- block.dropNaturally(this.world, blockposition, this.world.getType(blockposition), 1.0F / this.size, 0);
+ // CraftBukkit - add yield
-+ block.dropNaturally(this.world, blockposition, this.world.getType(blockposition), event.getYield(), 0);
++ block.dropNaturally(this.world, blockposition, this.world.getType(blockposition), yield, 0);
}
this.world.setTypeAndData(blockposition, Blocks.AIR.getBlockData(), 3);
-@@ -185,7 +234,11 @@
+@@ -185,7 +250,11 @@
while (iterator.hasNext()) {
blockposition = (BlockPosition) iterator.next();
if (this.world.getType(blockposition).getBlock().getMaterial() == Material.AIR && this.world.getType(blockposition.down()).getBlock().o() && this.c.nextInt(3) == 0) {