aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0547-Add-Mob-lookAt-API.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0547-Add-Mob-lookAt-API.patch')
-rw-r--r--patches/server/0547-Add-Mob-lookAt-API.patch64
1 files changed, 64 insertions, 0 deletions
diff --git a/patches/server/0547-Add-Mob-lookAt-API.patch b/patches/server/0547-Add-Mob-lookAt-API.patch
new file mode 100644
index 0000000000..3139490a61
--- /dev/null
+++ b/patches/server/0547-Add-Mob-lookAt-API.patch
@@ -0,0 +1,64 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: BillyGalbreath <[email protected]>
+Date: Fri, 14 May 2021 13:42:17 -0500
+Subject: [PATCH] Add Mob#lookAt API
+
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java
+index 2a8596e4f9d7be966c18e867c2c7b5bfbea9742c..60d09655c5b8b9ff289291ee6badfb5aadf8533e 100644
+--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java
++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMob.java
+@@ -96,5 +96,53 @@ public abstract class CraftMob extends CraftLivingEntity implements Mob {
+ public boolean isInDaylight() {
+ return getHandle().isSunBurnTick();
+ }
++
++ @Override
++ public void lookAt(@org.jetbrains.annotations.NotNull org.bukkit.Location location) {
++ com.google.common.base.Preconditions.checkNotNull(location, "location cannot be null");
++ com.google.common.base.Preconditions.checkArgument(location.getWorld().equals(getWorld()), "location in a different world");
++ getHandle().getLookControl().setLookAt(location.getX(), location.getY(), location.getZ());
++ }
++
++ @Override
++ public void lookAt(@org.jetbrains.annotations.NotNull org.bukkit.Location location, float headRotationSpeed, float maxHeadPitch) {
++ com.google.common.base.Preconditions.checkNotNull(location, "location cannot be null");
++ com.google.common.base.Preconditions.checkArgument(location.getWorld().equals(getWorld()), "location in a different world");
++ getHandle().getLookControl().setLookAt(location.getX(), location.getY(), location.getZ(), headRotationSpeed, maxHeadPitch);
++ }
++
++ @Override
++ public void lookAt(@org.jetbrains.annotations.NotNull org.bukkit.entity.Entity entity) {
++ com.google.common.base.Preconditions.checkNotNull(entity, "entity cannot be null");
++ com.google.common.base.Preconditions.checkArgument(entity.getWorld().equals(getWorld()), "entity in a different world");
++ getHandle().getLookControl().setLookAt(((CraftEntity) entity).getHandle());
++ }
++
++ @Override
++ public void lookAt(@org.jetbrains.annotations.NotNull org.bukkit.entity.Entity entity, float headRotationSpeed, float maxHeadPitch) {
++ com.google.common.base.Preconditions.checkNotNull(entity, "entity cannot be null");
++ com.google.common.base.Preconditions.checkArgument(entity.getWorld().equals(getWorld()), "entity in a different world");
++ getHandle().getLookControl().setLookAt(((CraftEntity) entity).getHandle(), headRotationSpeed, maxHeadPitch);
++ }
++
++ @Override
++ public void lookAt(double x, double y, double z) {
++ getHandle().getLookControl().setLookAt(x, y, z);
++ }
++
++ @Override
++ public void lookAt(double x, double y, double z, float headRotationSpeed, float maxHeadPitch) {
++ getHandle().getLookControl().setLookAt(x, y, z, headRotationSpeed, maxHeadPitch);
++ }
++
++ @Override
++ public int getHeadRotationSpeed() {
++ return getHandle().getHeadRotSpeed();
++ }
++
++ @Override
++ public int getMaxHeadPitch() {
++ return getHandle().getMaxHeadXRot();
++ }
+ // Paper end
+ }