2019-03-24 00:24:52 -04:00
--- a/net/minecraft/world/entity/OminousItemSpawner.java
+++ b/net/minecraft/world/entity/OminousItemSpawner.java
2024-12-14 12:36:08 +01:00
@@ -76,7 +_,7 @@
entity = this.spawnProjectile(serverLevel, projectileItem, item);
2019-03-24 00:24:52 -04:00
} else {
2024-12-14 12:36:08 +01:00
entity = new ItemEntity(serverLevel, this.getX(), this.getY(), this.getZ(), item);
2019-03-24 00:24:52 -04:00
- serverLevel.addFreshEntity(entity);
+ serverLevel.addFreshEntity(entity, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.OMINOUS_ITEM_SPAWNER); // Paper - fixes and addition to spawn reason API
}
serverLevel.levelEvent(3021, this.blockPosition(), 1);
2024-12-14 12:36:08 +01:00
@@ -90,7 +_,7 @@
ProjectileItem.DispenseConfig dispenseConfig = projectileItem.createDispenseConfig();
dispenseConfig.overrideDispenseEvent().ifPresent(i -> level.levelEvent(i, this.blockPosition(), 0));
2019-03-24 00:24:52 -04:00
Direction direction = Direction.DOWN;
- Projectile projectile = Projectile.spawnProjectileUsingShoot(
+ Projectile projectile = Projectile.spawnProjectileUsingShootDelayed( // Paper - fixes and addition to spawn reason API
2024-12-14 12:36:08 +01:00
projectileItem.asProjectile(level, this.position(), stack, direction),
level,
2019-03-24 00:24:52 -04:00
stack,
2024-12-14 12:36:08 +01:00
@@ -99,7 +_,7 @@
direction.getStepZ(),
2019-03-24 00:24:52 -04:00
dispenseConfig.power(),
dispenseConfig.uncertainty()
- );
+ ).spawn(org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.OMINOUS_ITEM_SPAWNER); // Paper - fixes and addition to spawn reason API
projectile.setOwner(this);
return projectile;
}