2020-01-22 08:00:00 +11:00
|
|
|
From f1957f08b95f5c6a7555fd1bdfaec34b5c034adb Mon Sep 17 00:00:00 2001
|
2016-03-03 19:46:15 +11:00
|
|
|
From: md_5 <git@md-5.net>
|
|
|
|
Date: Thu, 3 Mar 2016 19:45:46 +1100
|
|
|
|
Subject: [PATCH] Implement SpawnerSpawnEvent.
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java
|
2019-12-22 10:00:03 +11:00
|
|
|
index e0b2a1b8e..813de2a6d 100644
|
2016-03-03 19:46:15 +11:00
|
|
|
--- a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java
|
2019-12-11 09:00:00 +11:00
|
|
|
@@ -134,6 +134,16 @@ public abstract class MobSpawnerAbstract {
|
2017-06-11 08:37:33 +10:00
|
|
|
{
|
|
|
|
entity.fromMobSpawner = true;
|
2017-05-18 21:20:15 +10:00
|
|
|
}
|
2016-03-03 19:46:15 +11:00
|
|
|
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callSpawnerSpawnEvent(entity, blockposition).isCancelled()) {
|
2018-09-15 15:22:20 +10:00
|
|
|
+ Entity vehicle = entity.getVehicle();
|
|
|
|
+ if (vehicle != null) {
|
|
|
|
+ vehicle.dead = true;
|
|
|
|
+ }
|
2018-10-23 06:00:00 +11:00
|
|
|
+ for (Entity passenger : entity.getAllPassengers()) {
|
2018-09-15 15:22:20 +10:00
|
|
|
+ passenger.dead = true;
|
|
|
|
+ }
|
2016-03-03 19:46:15 +11:00
|
|
|
+ continue;
|
|
|
|
+ }
|
2017-05-18 21:20:15 +10:00
|
|
|
// Spigot End
|
2019-04-23 12:00:00 +10:00
|
|
|
this.a(entity);
|
2017-06-11 08:37:33 +10:00
|
|
|
world.triggerEffect(2004, blockposition, 0);
|
2016-03-03 19:46:15 +11:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
|
2020-01-22 08:00:00 +11:00
|
|
|
index c289d5325..72b8677f2 100644
|
2016-03-03 19:46:15 +11:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
|
2020-01-22 08:00:00 +11:00
|
|
|
@@ -203,6 +203,8 @@ import org.bukkit.inventory.InventoryView;
|
2019-04-23 15:12:43 +10:00
|
|
|
import org.bukkit.inventory.meta.BookMeta;
|
|
|
|
import org.bukkit.potion.PotionEffect;
|
|
|
|
|
|
|
|
+import org.bukkit.event.entity.SpawnerSpawnEvent; // Spigot
|
|
|
|
+
|
|
|
|
public class CraftEventFactory {
|
|
|
|
public static final DamageSource MELTING = CraftDamageSource.copyOf(DamageSource.BURN);
|
|
|
|
public static final DamageSource POISON = CraftDamageSource.copyOf(DamageSource.MAGIC);
|
2020-01-22 08:00:00 +11:00
|
|
|
@@ -1376,6 +1378,21 @@ public class CraftEventFactory {
|
2016-03-03 19:46:15 +11:00
|
|
|
return event;
|
|
|
|
}
|
2016-03-12 20:59:15 +11:00
|
|
|
|
2016-03-03 19:46:15 +11:00
|
|
|
+ /**
|
|
|
|
+ * Mob spawner event.
|
|
|
|
+ */
|
|
|
|
+ public static SpawnerSpawnEvent callSpawnerSpawnEvent(Entity spawnee, BlockPosition pos) {
|
|
|
|
+ org.bukkit.craftbukkit.entity.CraftEntity entity = spawnee.getBukkitEntity();
|
|
|
|
+ BlockState state = entity.getWorld().getBlockAt(pos.getX(), pos.getY(), pos.getZ()).getState();
|
|
|
|
+ if (!(state instanceof org.bukkit.block.CreatureSpawner)) {
|
|
|
|
+ state = null;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ SpawnerSpawnEvent event = new SpawnerSpawnEvent(entity, (org.bukkit.block.CreatureSpawner) state);
|
|
|
|
+ entity.getServer().getPluginManager().callEvent(event);
|
|
|
|
+ return event;
|
|
|
|
+ }
|
2016-03-12 20:59:15 +11:00
|
|
|
+
|
|
|
|
public static EntityToggleGlideEvent callToggleGlideEvent(EntityLiving entity, boolean gliding) {
|
|
|
|
EntityToggleGlideEvent event = new EntityToggleGlideEvent((LivingEntity) entity.getBukkitEntity(), gliding);
|
|
|
|
entity.world.getServer().getPluginManager().callEvent(event);
|
2016-03-03 19:46:15 +11:00
|
|
|
--
|
2019-04-23 09:33:25 +10:00
|
|
|
2.20.1
|
2016-03-03 19:46:15 +11:00
|
|
|
|