aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0595-Goat-ram-API.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0595-Goat-ram-API.patch')
-rw-r--r--patches/server/0595-Goat-ram-API.patch42
1 files changed, 42 insertions, 0 deletions
diff --git a/patches/server/0595-Goat-ram-API.patch b/patches/server/0595-Goat-ram-API.patch
new file mode 100644
index 0000000000..2f5ccdfed4
--- /dev/null
+++ b/patches/server/0595-Goat-ram-API.patch
@@ -0,0 +1,42 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Seggan <[email protected]>
+Date: Thu, 5 Aug 2021 13:10:27 -0400
+Subject: [PATCH] Goat ram API
+
+
+diff --git a/src/main/java/net/minecraft/world/entity/animal/goat/Goat.java b/src/main/java/net/minecraft/world/entity/animal/goat/Goat.java
+index fa380dcfa16f5d872c9d29d6fab9f9cf095f3791..3b2cf9ca8447321d64ffdb4fdb9569d736d63dbb 100644
+--- a/src/main/java/net/minecraft/world/entity/animal/goat/Goat.java
++++ b/src/main/java/net/minecraft/world/entity/animal/goat/Goat.java
+@@ -391,4 +391,15 @@ public class Goat extends Animal {
+ public static boolean checkGoatSpawnRules(EntityType<? extends Animal> entityType, LevelAccessor world, MobSpawnType spawnReason, BlockPos pos, RandomSource random) {
+ return world.getBlockState(pos.below()).is(BlockTags.GOATS_SPAWNABLE_ON) && isBrightEnoughToSpawn(world, pos);
+ }
++
++ // Paper start - Goat ram API
++ public void ram(net.minecraft.world.entity.LivingEntity entity) {
++ Brain<Goat> brain = this.getBrain();
++ brain.setMemory(MemoryModuleType.RAM_TARGET, entity.position());
++ brain.eraseMemory(MemoryModuleType.RAM_COOLDOWN_TICKS);
++ brain.eraseMemory(MemoryModuleType.BREED_TARGET);
++ brain.eraseMemory(MemoryModuleType.TEMPTING_PLAYER);
++ brain.setActiveActivityIfPossible(net.minecraft.world.entity.schedule.Activity.RAM);
++ }
++ // Paper end - Goat ram API
+ }
+diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftGoat.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftGoat.java
+index 65fcb36e849da6949c123a6f3672b485036f368e..2c21de478bff9cdf13ba46cd041831d54c11e924 100644
+--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftGoat.java
++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftGoat.java
+@@ -48,4 +48,11 @@ public class CraftGoat extends CraftAnimals implements Goat {
+ public void setScreaming(boolean screaming) {
+ this.getHandle().setScreamingGoat(screaming);
+ }
++
++ // Paper start - Goat ram API
++ @Override
++ public void ram(@org.jetbrains.annotations.NotNull org.bukkit.entity.LivingEntity entity) {
++ this.getHandle().ram(((CraftLivingEntity) entity).getHandle());
++ }
++ // Paper end
+ }