mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 17:01:56 +01:00
Shoulder Entities Release API
This commit is contained in:
parent
551d6ee71e
commit
aab7ec1655
2 changed files with 56 additions and 8 deletions
|
@ -428,14 +428,11 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1798,26 +1939,31 @@
|
@@ -1798,26 +1939,55 @@
|
||||||
|
|
||||||
public void removeEntitiesOnShoulder() {
|
public void removeEntitiesOnShoulder() {
|
||||||
if (this.timeEntitySatOnShoulder + 20L < this.level().getGameTime()) {
|
if (this.timeEntitySatOnShoulder + 20L < this.level().getGameTime()) {
|
||||||
- this.respawnEntityOnShoulder(this.getShoulderEntityLeft());
|
- this.respawnEntityOnShoulder(this.getShoulderEntityLeft());
|
||||||
- this.setShoulderEntityLeft(new CompoundTag());
|
|
||||||
- this.respawnEntityOnShoulder(this.getShoulderEntityRight());
|
|
||||||
- this.setShoulderEntityRight(new CompoundTag());
|
|
||||||
+ // CraftBukkit start
|
+ // CraftBukkit start
|
||||||
+ if (this.respawnEntityOnShoulder(this.getShoulderEntityLeft())) {
|
+ if (this.respawnEntityOnShoulder(this.getShoulderEntityLeft())) {
|
||||||
+ this.setShoulderEntityLeft(new CompoundTag());
|
+ this.setShoulderEntityLeft(new CompoundTag());
|
||||||
|
@ -444,14 +441,39 @@
|
||||||
+ this.setShoulderEntityRight(new CompoundTag());
|
+ this.setShoulderEntityRight(new CompoundTag());
|
||||||
+ }
|
+ }
|
||||||
+ // CraftBukkit end
|
+ // CraftBukkit end
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ // Paper start - release entity api
|
||||||
|
+ public Entity releaseLeftShoulderEntity() {
|
||||||
|
+ Entity entity = this.respawnEntityOnShoulder0(this.getShoulderEntityLeft());
|
||||||
|
+ if (entity != null) {
|
||||||
|
this.setShoulderEntityLeft(new CompoundTag());
|
||||||
|
- this.respawnEntityOnShoulder(this.getShoulderEntityRight());
|
||||||
|
+ }
|
||||||
|
+ return entity;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public Entity releaseRightShoulderEntity() {
|
||||||
|
+ Entity entity = this.respawnEntityOnShoulder0(this.getShoulderEntityRight());
|
||||||
|
+ if (entity != null) {
|
||||||
|
this.setShoulderEntityRight(new CompoundTag());
|
||||||
}
|
}
|
||||||
|
+ return entity;
|
||||||
|
+ }
|
||||||
|
+ // Paper end - release entity api
|
||||||
|
|
||||||
|
+ private boolean respawnEntityOnShoulder(CompoundTag nbttagcompound) { // CraftBukkit void->boolean
|
||||||
|
+ // Paper start - release entity api - return entity - overload
|
||||||
|
+ return this.respawnEntityOnShoulder0(nbttagcompound) != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
- private void respawnEntityOnShoulder(CompoundTag entityNbt) {
|
- private void respawnEntityOnShoulder(CompoundTag entityNbt) {
|
||||||
- if (!this.level().isClientSide && !entityNbt.isEmpty()) {
|
- if (!this.level().isClientSide && !entityNbt.isEmpty()) {
|
||||||
- EntityType.create(entityNbt, this.level(), EntitySpawnReason.LOAD).ifPresent((entity) -> {
|
- EntityType.create(entityNbt, this.level(), EntitySpawnReason.LOAD).ifPresent((entity) -> {
|
||||||
+ private boolean respawnEntityOnShoulder(CompoundTag nbttagcompound) { // CraftBukkit void->boolean
|
+ private Entity respawnEntityOnShoulder0(CompoundTag nbttagcompound) { // CraftBukkit void->boolean
|
||||||
|
+ // Paper end - release entity api - return entity - overload
|
||||||
+ if (!this.level().isClientSide && !nbttagcompound.isEmpty()) {
|
+ if (!this.level().isClientSide && !nbttagcompound.isEmpty()) {
|
||||||
+ return EntityType.create(nbttagcompound, this.level(), EntitySpawnReason.LOAD).map((entity) -> { // CraftBukkit
|
+ return EntityType.create(nbttagcompound, this.level(), EntitySpawnReason.LOAD).map((entity) -> { // CraftBukkit
|
||||||
if (entity instanceof TamableAnimal) {
|
if (entity instanceof TamableAnimal) {
|
||||||
|
@ -461,11 +483,11 @@
|
||||||
entity.setPos(this.getX(), this.getY() + 0.699999988079071D, this.getZ());
|
entity.setPos(this.getX(), this.getY() + 0.699999988079071D, this.getZ());
|
||||||
- ((ServerLevel) this.level()).addWithUUID(entity);
|
- ((ServerLevel) this.level()).addWithUUID(entity);
|
||||||
- });
|
- });
|
||||||
+ return ((ServerLevel) this.level()).addWithUUID(entity, CreatureSpawnEvent.SpawnReason.SHOULDER_ENTITY); // CraftBukkit
|
+ return ((ServerLevel) this.level()).addWithUUID(entity, CreatureSpawnEvent.SpawnReason.SHOULDER_ENTITY) ? entity : null; // CraftBukkit // Paper start - release entity api - return entity
|
||||||
+ }).orElse(true); // CraftBukkit
|
+ }).orElse(null); // CraftBukkit // Paper end - release entity api - return entity
|
||||||
}
|
}
|
||||||
|
|
||||||
+ return true; // CraftBukkit
|
+ return null; // Paper - return null
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -544,6 +544,32 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity {
|
||||||
this.getHandle().getCooldowns().addCooldown(CraftItemStack.asNMSCopy(item), ticks);
|
this.getHandle().getCooldowns().addCooldown(CraftItemStack.asNMSCopy(item), ticks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Paper start
|
||||||
|
@Override
|
||||||
|
public org.bukkit.entity.Entity releaseLeftShoulderEntity() {
|
||||||
|
if (!getHandle().getShoulderEntityLeft().isEmpty()) {
|
||||||
|
Entity entity = getHandle().releaseLeftShoulderEntity();
|
||||||
|
if (entity != null) {
|
||||||
|
return entity.getBukkitEntity();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public org.bukkit.entity.Entity releaseRightShoulderEntity() {
|
||||||
|
if (!getHandle().getShoulderEntityRight().isEmpty()) {
|
||||||
|
Entity entity = getHandle().releaseRightShoulderEntity();
|
||||||
|
if (entity != null) {
|
||||||
|
return entity.getBukkitEntity();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
// Paper end
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean discoverRecipe(NamespacedKey recipe) {
|
public boolean discoverRecipe(NamespacedKey recipe) {
|
||||||
return this.discoverRecipes(Arrays.asList(recipe)) != 0;
|
return this.discoverRecipes(Arrays.asList(recipe)) != 0;
|
||||||
|
|
Loading…
Reference in a new issue