mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-15 22:21:01 +01:00
#642: Add a DragonBattle API to manipulate respawn phases etc
This commit is contained in:
parent
796eb15a5b
commit
fc318cc10e
4 changed files with 164 additions and 7 deletions
52
nms-patches/EnderDragonBattle.patch
Normal file
52
nms-patches/EnderDragonBattle.patch
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
--- a/net/minecraft/server/EnderDragonBattle.java
|
||||||
|
+++ b/net/minecraft/server/EnderDragonBattle.java
|
||||||
|
@@ -21,7 +21,7 @@
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
private static final Predicate<Entity> b = IEntitySelector.a.and(IEntitySelector.a(0.0D, 128.0D, 0.0D, 192.0D));
|
||||||
|
public final BossBattleServer bossBattle;
|
||||||
|
- private final WorldServer d;
|
||||||
|
+ public final WorldServer d; // CraftBukkit PAIL private -> public, rename world
|
||||||
|
private final List<Integer> e;
|
||||||
|
private final ShapeDetector f;
|
||||||
|
private int g;
|
||||||
|
@@ -30,10 +30,10 @@
|
||||||
|
private int j;
|
||||||
|
private boolean k;
|
||||||
|
private boolean l;
|
||||||
|
- private UUID m;
|
||||||
|
+ public UUID m; // CraftBukkit PAIL private -> public, rename dragonUUID
|
||||||
|
private boolean n;
|
||||||
|
- private BlockPosition o;
|
||||||
|
- private EnumDragonRespawn p;
|
||||||
|
+ public BlockPosition o; // CraftBukkit PAIL private -> public, rename portalLocation
|
||||||
|
+ public EnumDragonRespawn p; // CraftBukkit PAIL private -> public, rename respawnPhase
|
||||||
|
private int q;
|
||||||
|
private List<EntityEnderCrystal> r;
|
||||||
|
|
||||||
|
@@ -194,7 +194,7 @@
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
- protected void a(EnumDragonRespawn enumdragonrespawn) {
|
||||||
|
+ public void a(EnumDragonRespawn enumdragonrespawn) { // CraftBukkit PAIL protected -> public, rename setRespawnPhase
|
||||||
|
if (this.p == null) {
|
||||||
|
throw new IllegalStateException("Dragon respawn isn't in progress, can't skip ahead in the animation.");
|
||||||
|
} else {
|
||||||
|
@@ -376,7 +376,7 @@
|
||||||
|
|
||||||
|
private void a(BlockPosition blockposition) {
|
||||||
|
this.d.triggerEffect(3000, blockposition, 0);
|
||||||
|
- WorldGenerator.END_GATEWAY.b((WorldGenFeatureConfiguration) WorldGenEndGatewayConfiguration.a()).a(this.d, this.d.getChunkProvider().getChunkGenerator(), new Random(), blockposition);
|
||||||
|
+ WorldGenerator.END_GATEWAY.b(WorldGenEndGatewayConfiguration.a()).a(this.d, this.d.getChunkProvider().getChunkGenerator(), new Random(), blockposition); // CraftBukkit - decompile error
|
||||||
|
}
|
||||||
|
|
||||||
|
private void a(boolean flag) {
|
||||||
|
@@ -388,7 +388,7 @@
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- worldgenendtrophy.b((WorldGenFeatureConfiguration) WorldGenFeatureConfiguration.e).a(this.d, this.d.getChunkProvider().getChunkGenerator(), new Random(), this.o);
|
||||||
|
+ worldgenendtrophy.b(WorldGenFeatureConfiguration.e).a(this.d, this.d.getChunkProvider().getChunkGenerator(), new Random(), this.o); // CraftBukkit - decompile error
|
||||||
|
}
|
||||||
|
|
||||||
|
private EntityEnderDragon o() {
|
|
@ -88,6 +88,8 @@ import net.minecraft.server.TicketType;
|
||||||
import net.minecraft.server.Unit;
|
import net.minecraft.server.Unit;
|
||||||
import net.minecraft.server.Vec3D;
|
import net.minecraft.server.Vec3D;
|
||||||
import net.minecraft.server.WorldGenerator;
|
import net.minecraft.server.WorldGenerator;
|
||||||
|
import net.minecraft.server.WorldProvider;
|
||||||
|
import net.minecraft.server.WorldProviderTheEnd;
|
||||||
import net.minecraft.server.WorldServer;
|
import net.minecraft.server.WorldServer;
|
||||||
import org.apache.commons.lang.Validate;
|
import org.apache.commons.lang.Validate;
|
||||||
import org.bukkit.BlockChangeDelegate;
|
import org.bukkit.BlockChangeDelegate;
|
||||||
|
@ -111,9 +113,11 @@ import org.bukkit.block.Block;
|
||||||
import org.bukkit.block.BlockFace;
|
import org.bukkit.block.BlockFace;
|
||||||
import org.bukkit.block.BlockState;
|
import org.bukkit.block.BlockState;
|
||||||
import org.bukkit.block.data.BlockData;
|
import org.bukkit.block.data.BlockData;
|
||||||
|
import org.bukkit.boss.DragonBattle;
|
||||||
import org.bukkit.craftbukkit.block.CraftBlock;
|
import org.bukkit.craftbukkit.block.CraftBlock;
|
||||||
import org.bukkit.craftbukkit.block.CraftBlockState;
|
import org.bukkit.craftbukkit.block.CraftBlockState;
|
||||||
import org.bukkit.craftbukkit.block.data.CraftBlockData;
|
import org.bukkit.craftbukkit.block.data.CraftBlockData;
|
||||||
|
import org.bukkit.craftbukkit.boss.CraftDragonBattle;
|
||||||
import org.bukkit.craftbukkit.entity.CraftEntity;
|
import org.bukkit.craftbukkit.entity.CraftEntity;
|
||||||
import org.bukkit.craftbukkit.entity.CraftItem;
|
import org.bukkit.craftbukkit.entity.CraftItem;
|
||||||
import org.bukkit.craftbukkit.entity.CraftLightningStrike;
|
import org.bukkit.craftbukkit.entity.CraftLightningStrike;
|
||||||
|
@ -2270,4 +2274,14 @@ public class CraftWorld implements World {
|
||||||
PersistentRaid persistentRaid = world.getPersistentRaid();
|
PersistentRaid persistentRaid = world.getPersistentRaid();
|
||||||
return persistentRaid.raids.values().stream().map(CraftRaid::new).collect(Collectors.toList());
|
return persistentRaid.raids.values().stream().map(CraftRaid::new).collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DragonBattle getEnderDragonBattle() {
|
||||||
|
WorldProvider worldProvider = getHandle().worldProvider;
|
||||||
|
if (!(worldProvider instanceof WorldProviderTheEnd)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new CraftDragonBattle(((WorldProviderTheEnd) worldProvider).o()); // PAIL rename getDragonBattle
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,85 @@
|
||||||
|
package org.bukkit.craftbukkit.boss;
|
||||||
|
|
||||||
|
import com.google.common.base.Preconditions;
|
||||||
|
import net.minecraft.server.EnderDragonBattle;
|
||||||
|
import net.minecraft.server.Entity;
|
||||||
|
import net.minecraft.server.EnumDragonRespawn;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.boss.BossBar;
|
||||||
|
import org.bukkit.boss.DragonBattle;
|
||||||
|
import org.bukkit.entity.EnderDragon;
|
||||||
|
|
||||||
|
public class CraftDragonBattle implements DragonBattle {
|
||||||
|
|
||||||
|
private final EnderDragonBattle handle;
|
||||||
|
|
||||||
|
public CraftDragonBattle(EnderDragonBattle handle) {
|
||||||
|
this.handle = handle;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EnderDragon getEnderDragon() {
|
||||||
|
Entity entity = handle.d.getEntity(handle.m);
|
||||||
|
return (entity != null) ? (EnderDragon) entity.getBukkitEntity() : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BossBar getBossBar() {
|
||||||
|
return new CraftBossBar(handle.bossBattle);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getEndPortalLocation() {
|
||||||
|
return new Location(handle.d.getWorld(), handle.o.getX(), handle.o.getY(), handle.o.getZ());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean hasBeenPreviouslyKilled() {
|
||||||
|
return handle.d(); // PAIL rename hasBeenPreviouslyKilled
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void initiateRespawn() {
|
||||||
|
this.handle.e(); // PAIL rename initiateRespawn
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public RespawnPhase getRespawnPhase() {
|
||||||
|
return toBukkitRespawnPhase(handle.p);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean setRespawnPhase(RespawnPhase phase) {
|
||||||
|
Preconditions.checkArgument(phase != null && phase != RespawnPhase.NONE, "Invalid respawn phase provided: %s", phase);
|
||||||
|
|
||||||
|
if (handle.p == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.handle.a(toNMSRespawnPhase(phase));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void resetCrystals() {
|
||||||
|
this.handle.f(); // PAIL rename resetCrystals
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return handle.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof CraftDragonBattle && ((CraftDragonBattle) obj).handle == this.handle;
|
||||||
|
}
|
||||||
|
|
||||||
|
private RespawnPhase toBukkitRespawnPhase(EnumDragonRespawn phase) {
|
||||||
|
return (phase != null) ? RespawnPhase.values()[phase.ordinal()] : RespawnPhase.NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
private EnumDragonRespawn toNMSRespawnPhase(RespawnPhase phase) {
|
||||||
|
return (phase != RespawnPhase.NONE) ? EnumDragonRespawn.values()[phase.ordinal()] : null;
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,22 +7,18 @@ import net.minecraft.server.DragonControllerPhase;
|
||||||
import net.minecraft.server.EntityComplexPart;
|
import net.minecraft.server.EntityComplexPart;
|
||||||
import net.minecraft.server.EntityEnderDragon;
|
import net.minecraft.server.EntityEnderDragon;
|
||||||
import org.bukkit.boss.BossBar;
|
import org.bukkit.boss.BossBar;
|
||||||
|
import org.bukkit.boss.DragonBattle;
|
||||||
import org.bukkit.craftbukkit.CraftServer;
|
import org.bukkit.craftbukkit.CraftServer;
|
||||||
import org.bukkit.craftbukkit.boss.CraftBossBar;
|
import org.bukkit.craftbukkit.boss.CraftBossBar;
|
||||||
|
import org.bukkit.craftbukkit.boss.CraftDragonBattle;
|
||||||
import org.bukkit.entity.ComplexEntityPart;
|
import org.bukkit.entity.ComplexEntityPart;
|
||||||
import org.bukkit.entity.EnderDragon;
|
import org.bukkit.entity.EnderDragon;
|
||||||
import org.bukkit.entity.EntityType;
|
import org.bukkit.entity.EntityType;
|
||||||
|
|
||||||
public class CraftEnderDragon extends CraftComplexLivingEntity implements EnderDragon {
|
public class CraftEnderDragon extends CraftComplexLivingEntity implements EnderDragon {
|
||||||
|
|
||||||
private BossBar bossBar;
|
|
||||||
|
|
||||||
public CraftEnderDragon(CraftServer server, EntityEnderDragon entity) {
|
public CraftEnderDragon(CraftServer server, EntityEnderDragon entity) {
|
||||||
super(server, entity);
|
super(server, entity);
|
||||||
|
|
||||||
if (entity.getEnderDragonBattle() != null) {
|
|
||||||
this.bossBar = new CraftBossBar(entity.getEnderDragonBattle().bossBattle);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -71,6 +67,16 @@ public class CraftEnderDragon extends CraftComplexLivingEntity implements EnderD
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BossBar getBossBar() {
|
public BossBar getBossBar() {
|
||||||
return bossBar;
|
return getDragonBattle().getBossBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DragonBattle getDragonBattle() {
|
||||||
|
return new CraftDragonBattle(getHandle().getEnderDragonBattle());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getDeathAnimationTicks() {
|
||||||
|
return getHandle().bA; // PAIL rename deathAnimationTicks
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue