2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Zach Brown <zach.brown@destroystokyo.com>
|
|
|
|
Date: Tue, 16 May 2017 21:29:08 -0500
|
|
|
|
Subject: [PATCH] Add option to make parrots stay on shoulders despite movement
|
|
|
|
|
|
|
|
Makes parrots not fall off whenever the player changes height, or touches water, or gets hit by a passing leaf.
|
|
|
|
Instead, switches the behavior so that players have to sneak to make the birds leave.
|
|
|
|
|
|
|
|
I suspect Mojang may switch to this behavior before full release.
|
|
|
|
|
|
|
|
To be converted into a Paper-API event at some point in the future?
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2022-06-09 13:55:33 +02:00
|
|
|
index 34f58fb835abaad145e2f1fa71cce193386a28fb..8481e16454fbee019f0c8f3c9371576cbfc48d07 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2022-06-09 13:55:33 +02:00
|
|
|
@@ -2259,6 +2259,13 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser
|
2021-06-11 14:02:28 +02:00
|
|
|
switch (packet.getAction()) {
|
|
|
|
case PRESS_SHIFT_KEY:
|
|
|
|
this.player.setShiftKeyDown(true);
|
|
|
|
+
|
2021-06-12 11:17:20 +02:00
|
|
|
+ // Paper start - Hang on!
|
2022-06-09 10:51:45 +02:00
|
|
|
+ if (this.player.level.paperConfig().entities.behavior.parrotsAreUnaffectedByPlayerMovement) {
|
2021-06-12 11:17:20 +02:00
|
|
|
+ this.player.removeEntitiesOnShoulder();
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2021-06-11 14:02:28 +02:00
|
|
|
+
|
|
|
|
break;
|
|
|
|
case RELEASE_SHIFT_KEY:
|
|
|
|
this.player.setShiftKeyDown(false);
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/player/Player.java b/src/main/java/net/minecraft/world/entity/player/Player.java
|
2022-06-09 10:51:45 +02:00
|
|
|
index fdda98cb38ec96d0189931c41257cc01966373d5..9aa134e56d661d033bb7229e6ab662534bf9cba9 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/player/Player.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/player/Player.java
|
2022-06-08 15:38:56 +02:00
|
|
|
@@ -587,7 +587,7 @@ public abstract class Player extends LivingEntity {
|
2021-06-11 14:02:28 +02:00
|
|
|
this.playShoulderEntityAmbientSound(this.getShoulderEntityLeft());
|
|
|
|
this.playShoulderEntityAmbientSound(this.getShoulderEntityRight());
|
2021-06-12 11:17:20 +02:00
|
|
|
if (!this.level.isClientSide && (this.fallDistance > 0.5F || this.isInWater()) || this.abilities.flying || this.isSleeping() || this.isInPowderSnow) {
|
2021-06-11 14:02:28 +02:00
|
|
|
- this.removeEntitiesOnShoulder();
|
2022-06-09 10:51:45 +02:00
|
|
|
+ if (!this.level.paperConfig().entities.behavior.parrotsAreUnaffectedByPlayerMovement) this.removeEntitiesOnShoulder(); // Paper - Hang on!
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|