2024-08-17 23:17:18 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Lulu13022002 <41980282+Lulu13022002@users.noreply.github.com>
|
|
|
|
Date: Sat, 22 Jun 2024 21:17:54 +0200
|
|
|
|
Subject: [PATCH] Leashable API
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/io/papermc/paper/entity/PaperLeashable.java b/src/main/java/io/papermc/paper/entity/PaperLeashable.java
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000000000000000000000000000000000000..a9ddf9a4a07cd29833f38d7e5f42b2b14ec98f78
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/io/papermc/paper/entity/PaperLeashable.java
|
|
|
|
@@ -0,0 +1,50 @@
|
|
|
|
+package io.papermc.paper.entity;
|
|
|
|
+
|
|
|
|
+import com.google.common.base.Preconditions;
|
|
|
|
+import net.minecraft.world.entity.Leashable;
|
|
|
|
+import org.bukkit.craftbukkit.entity.CraftEntity;
|
|
|
|
+import org.bukkit.entity.Entity;
|
|
|
|
+
|
|
|
|
+public interface PaperLeashable extends io.papermc.paper.entity.Leashable {
|
|
|
|
+
|
|
|
|
+ Leashable getHandle();
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ default boolean isLeashed() {
|
|
|
|
+ return this.getHandle().getLeashHolder() != null;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ default Entity getLeashHolder() throws IllegalStateException {
|
|
|
|
+ Preconditions.checkState(this.isLeashed(), "Entity not leashed");
|
|
|
|
+ return this.getHandle().getLeashHolder().getBukkitEntity();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ private boolean unleash() {
|
|
|
|
+ if (!this.isLeashed()) {
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ this.getHandle().dropLeash(true, false);
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ default boolean setLeashHolder(Entity holder) {
|
|
|
|
+ if (this.getHandle() instanceof net.minecraft.world.entity.Entity entity && entity.generation) {
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (holder == null) {
|
|
|
|
+ return this.unleash();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (holder.isDead()) {
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ this.unleash();
|
|
|
|
+ this.getHandle().setLeashedTo(((CraftEntity) holder).getHandle(), true);
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java
|
2024-10-25 17:08:48 +02:00
|
|
|
index ff82dc98478a8ac564bdbf4ec58da612e5f6c2ce..2a2839c31989d127739d829159a8b6e5b9a5210b 100644
|
2024-08-17 23:17:18 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftBoat.java
|
2024-10-25 00:08:35 +02:00
|
|
|
@@ -8,7 +8,7 @@ import org.bukkit.craftbukkit.CraftServer;
|
2024-08-17 23:17:18 +02:00
|
|
|
import org.bukkit.entity.Boat;
|
|
|
|
import org.bukkit.entity.Entity;
|
|
|
|
|
2024-10-25 00:08:35 +02:00
|
|
|
-public abstract class CraftBoat extends CraftVehicle implements Boat {
|
|
|
|
+public abstract class CraftBoat extends CraftVehicle implements Boat, io.papermc.paper.entity.PaperLeashable { // Paper - Leashable API
|
2024-08-17 23:17:18 +02:00
|
|
|
|
2024-10-25 00:08:35 +02:00
|
|
|
public CraftBoat(CraftServer server, AbstractBoat entity) {
|
2024-08-17 23:17:18 +02:00
|
|
|
super(server, entity);
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
2024-10-25 00:08:35 +02:00
|
|
|
index f16067b674118a47735ad22797988d50b4415040..d0c409f4efad289e3e325f44b500fc72589d89d4 100644
|
2024-08-17 23:17:18 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
2024-10-25 00:08:35 +02:00
|
|
|
@@ -784,43 +784,17 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity {
|
2024-08-17 23:17:18 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isLeashed() {
|
|
|
|
- if (!(this.getHandle() instanceof Mob)) {
|
|
|
|
- return false;
|
|
|
|
- }
|
|
|
|
- return ((Mob) this.getHandle()).getLeashHolder() != null;
|
|
|
|
+ return false; // Paper - implement in CraftMob & PaperLeashable
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Entity getLeashHolder() throws IllegalStateException {
|
|
|
|
- Preconditions.checkState(this.isLeashed(), "Entity not leashed");
|
|
|
|
- return ((Mob) this.getHandle()).getLeashHolder().getBukkitEntity();
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- private boolean unleash() {
|
|
|
|
- if (!this.isLeashed()) {
|
|
|
|
- return false;
|
|
|
|
- }
|
|
|
|
- ((Mob) this.getHandle()).dropLeash(true, false);
|
|
|
|
- return true;
|
|
|
|
+ throw new IllegalStateException("Entity not leashed"); // Paper - implement in CraftMob & PaperLeashable
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean setLeashHolder(Entity holder) {
|
|
|
|
- if (this.getHandle().generation || (this.getHandle() instanceof WitherBoss) || !(this.getHandle() instanceof Mob)) {
|
|
|
|
- return false;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if (holder == null) {
|
|
|
|
- return this.unleash();
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if (holder.isDead()) {
|
|
|
|
- return false;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- this.unleash();
|
|
|
|
- ((Mob) this.getHandle()).setLeashedTo(((CraftEntity) holder).getHandle(), true);
|
|
|
|
- return true;
|
|
|
|
+ return false; // Paper - implement in CraftMob & PaperLeashable
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java
|
2024-10-25 00:08:35 +02:00
|
|
|
index 95d7015a61098d1d22a501124d6bb8fba1516fe3..778a9d3f8bfe5dba59e1e655e4eeb8822678b8cf 100644
|
2024-08-17 23:17:18 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java
|
|
|
|
@@ -11,7 +11,7 @@ import org.bukkit.entity.LivingEntity;
|
|
|
|
import org.bukkit.entity.Mob;
|
|
|
|
import org.bukkit.loot.LootTable;
|
|
|
|
|
|
|
|
-public abstract class CraftMob extends CraftLivingEntity implements Mob {
|
|
|
|
+public abstract class CraftMob extends CraftLivingEntity implements Mob, io.papermc.paper.entity.PaperLeashable { // Paper - Leashable API
|
|
|
|
public CraftMob(CraftServer server, net.minecraft.world.entity.Mob entity) {
|
|
|
|
super(server, entity);
|
|
|
|
paperPathfinder = new com.destroystokyo.paper.entity.PaperPathfinder(entity); // Paper - Mob Pathfinding API
|
|
|
|
@@ -175,4 +175,21 @@ public abstract class CraftMob extends CraftLivingEntity implements Mob {
|
2024-10-25 00:08:35 +02:00
|
|
|
return getHandle().getExperienceReward((net.minecraft.server.level.ServerLevel) this.getHandle().level(), null);
|
2024-08-17 23:17:18 +02:00
|
|
|
}
|
|
|
|
// Paper end
|
|
|
|
+
|
|
|
|
+ // Paper start - Leashable API
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isLeashed() {
|
|
|
|
+ return io.papermc.paper.entity.PaperLeashable.super.isLeashed();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public org.bukkit.entity.Entity getLeashHolder() throws IllegalStateException {
|
|
|
|
+ return io.papermc.paper.entity.PaperLeashable.super.getLeashHolder();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean setLeashHolder(final org.bukkit.entity.Entity holder) {
|
|
|
|
+ return io.papermc.paper.entity.PaperLeashable.super.setLeashHolder(holder);
|
|
|
|
+ }
|
|
|
|
+ // Paper end - Leashable API
|
|
|
|
}
|