From 63821bf96b6dee5543b4866f7fc3d106853d5ef4 Mon Sep 17 00:00:00 2001 From: Phoenix616 Date: Tue, 18 Sep 2018 23:50:10 +0100 Subject: [PATCH] PreSpawnerSpawnEvent This adds a separate event before an entity is spawned by a spawner which contains the location of the spawner too similarly to how the SpawnerSpawnEvent gets called instead of the CreatureSpawnEvent for spawners. Dropped as it does not apply due to the earlier PreCreatureSpawnEvent patch not being applied --- .../event/entity/PreSpawnerSpawnEvent.java | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 paper-api/src/main/java/com/destroystokyo/paper/event/entity/PreSpawnerSpawnEvent.java diff --git a/paper-api/src/main/java/com/destroystokyo/paper/event/entity/PreSpawnerSpawnEvent.java b/paper-api/src/main/java/com/destroystokyo/paper/event/entity/PreSpawnerSpawnEvent.java new file mode 100644 index 0000000000..679b37056b --- /dev/null +++ b/paper-api/src/main/java/com/destroystokyo/paper/event/entity/PreSpawnerSpawnEvent.java @@ -0,0 +1,29 @@ +package com.destroystokyo.paper.event.entity; + +import org.bukkit.Location; +import org.bukkit.entity.EntityType; +import org.bukkit.event.entity.CreatureSpawnEvent; +import org.jetbrains.annotations.ApiStatus; +import org.jspecify.annotations.NullMarked; + +/** + * Called before an entity is spawned into a world by a spawner. + *

+ * This only includes the spawner's location and not the full BlockState snapshot for performance reasons. + * If you really need it you have to get the spawner yourself. + */ +@NullMarked +public class PreSpawnerSpawnEvent extends PreCreatureSpawnEvent { + + private final Location spawnerLocation; + + @ApiStatus.Internal + public PreSpawnerSpawnEvent(final Location location, final EntityType type, final Location spawnerLocation) { + super(location, type, CreatureSpawnEvent.SpawnReason.SPAWNER); + this.spawnerLocation = spawnerLocation; + } + + public Location getSpawnerLocation() { + return this.spawnerLocation.clone(); + } +}