summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorsk89q <the.sk89q@gmail.com>2011-04-22 01:18:24 -0700
committersk89q <the.sk89q@gmail.com>2011-04-22 01:18:24 -0700
commit628fec752ba816f3ff8e3170cbcb21e35d8e66a1 (patch)
tree852d1d60f1de944b29a67186824f127275ebda21 /src
parent4ecbf5f5909b685326ced934ac6dd77f1caed04a (diff)
downloadcraftbukkit-628fec752ba816f3ff8e3170cbcb21e35d8e66a1.tar
craftbukkit-628fec752ba816f3ff8e3170cbcb21e35d8e66a1.tar.gz
craftbukkit-628fec752ba816f3ff8e3170cbcb21e35d8e66a1.tar.lz
craftbukkit-628fec752ba816f3ff8e3170cbcb21e35d8e66a1.tar.xz
craftbukkit-628fec752ba816f3ff8e3170cbcb21e35d8e66a1.zip
Added events for fires caused by lightning. (Not 100% sure that they get called though.)
Diffstat (limited to 'src')
-rw-r--r--src/main/java/net/minecraft/server/EntityWeatherStorm.java121
1 files changed, 121 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/EntityWeatherStorm.java b/src/main/java/net/minecraft/server/EntityWeatherStorm.java
new file mode 100644
index 00000000..643e5489
--- /dev/null
+++ b/src/main/java/net/minecraft/server/EntityWeatherStorm.java
@@ -0,0 +1,121 @@
+package net.minecraft.server;
+
+import java.util.List;
+import org.bukkit.craftbukkit.CraftServer;
+import org.bukkit.craftbukkit.CraftWorld;
+import org.bukkit.event.block.BlockIgniteEvent;
+import org.bukkit.event.block.BlockIgniteEvent.IgniteCause;
+
+public class EntityWeatherStorm extends EntityWeather {
+
+ private int b;
+ public long a = 0L;
+ private int c;
+
+ // CraftBukkit start
+ private CraftWorld cworld;
+ private CraftServer server;
+ // CraftBukkit end
+
+ public EntityWeatherStorm(World world, double d0, double d1, double d2) {
+
+ super(world);
+
+ // CraftBukkit start
+ CraftWorld cworld = ((WorldServer) world).getWorld();
+ CraftServer server = ((WorldServer) world).getServer();
+ // CraftBukkit end
+
+ this.setPositionRotation(d0, d1, d2, 0.0F, 0.0F);
+ this.b = 2;
+ this.a = this.random.nextLong();
+ this.c = this.random.nextInt(3) + 1;
+ if (world.spawnMonsters >= 2 && world.a(MathHelper.floor(d0), MathHelper.floor(d1), MathHelper.floor(d2), 10)) {
+ int i = MathHelper.floor(d0);
+ int j = MathHelper.floor(d1);
+ int k = MathHelper.floor(d2);
+
+ if (world.getTypeId(i, j, k) == 0 && Block.FIRE.canPlace(world, i, j, k)) {
+ // CraftBukkit start
+ org.bukkit.block.Block theBlock = cworld.getBlockAt(i, j, k);
+ BlockIgniteEvent event = new BlockIgniteEvent(theBlock, IgniteCause.LIGHTNING, null);
+ ((WorldServer) world).getServer().getPluginManager().callEvent(event);
+ if (!event.isCancelled()) {
+ world.setTypeId(i, j, k, Block.FIRE.id);
+ }
+ // CraftBukkit end
+ }
+
+ for (i = 0; i < 4; ++i) {
+ j = MathHelper.floor(d0) + this.random.nextInt(3) - 1;
+ k = MathHelper.floor(d1) + this.random.nextInt(3) - 1;
+ int l = MathHelper.floor(d2) + this.random.nextInt(3) - 1;
+
+ if (world.getTypeId(j, k, l) == 0 && Block.FIRE.canPlace(world, j, k, l)) {
+ // CraftBukkit start
+ org.bukkit.block.Block theBlock = cworld.getBlockAt(j, k, l);
+ BlockIgniteEvent event = new BlockIgniteEvent(theBlock, IgniteCause.LIGHTNING, null);
+ ((WorldServer) world).getServer().getPluginManager().callEvent(event);
+ if (!event.isCancelled()) {
+ world.setTypeId(j, k, l, Block.FIRE.id);
+ }
+ // CraftBukkit end
+ }
+ }
+ }
+ }
+
+ public void p_() {
+ super.p_();
+ if (this.b == 2) {
+ this.world.makeSound(this.locX, this.locY, this.locZ, "ambient.weather.thunder", 10000.0F, 0.8F + this.random.nextFloat() * 0.2F);
+ this.world.makeSound(this.locX, this.locY, this.locZ, "random.explode", 2.0F, 0.5F + this.random.nextFloat() * 0.2F);
+ }
+
+ --this.b;
+ if (this.b < 0) {
+ if (this.c == 0) {
+ this.die();
+ } else if (this.b < -this.random.nextInt(10)) {
+ --this.c;
+ this.b = 1;
+ this.a = this.random.nextLong();
+ if (this.world.a(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ), 10)) {
+ int i = MathHelper.floor(this.locX);
+ int j = MathHelper.floor(this.locY);
+ int k = MathHelper.floor(this.locZ);
+
+ if (this.world.getTypeId(i, j, k) == 0 && Block.FIRE.canPlace(this.world, i, j, k)) {
+ // CraftBukkit start
+ org.bukkit.block.Block theBlock = cworld.getBlockAt(i, j, k);
+ BlockIgniteEvent event = new BlockIgniteEvent(theBlock, IgniteCause.LIGHTNING, null);
+ ((WorldServer) world).getServer().getPluginManager().callEvent(event);
+ if (!event.isCancelled()) {
+ this.world.setTypeId(i, j, k, Block.FIRE.id);
+ }
+ // CraftBukkit end
+ }
+ }
+ }
+ }
+
+ if (this.b >= 0) {
+ double d0 = 3.0D;
+ List list = this.world.b((Entity) this, AxisAlignedBB.b(this.locX - d0, this.locY - d0, this.locZ - d0, this.locX + d0, this.locY + 6.0D + d0, this.locZ + d0));
+
+ for (int l = 0; l < list.size(); ++l) {
+ Entity entity = (Entity) list.get(l);
+
+ entity.a(this);
+ }
+
+ this.world.i = 2;
+ }
+ }
+
+ protected void b() {}
+
+ protected void a(NBTTagCompound nbttagcompound) {}
+
+ protected void b(NBTTagCompound nbttagcompound) {}
+}