2021-06-11 12:02:28 +00: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-09-09 18:54:00 +00:00
|
|
|
index 846ca6e4437cc827584459511c3e119b35f9ba72..db2db8156338eae296f085a60a91a29fe02ab050 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2022-09-09 18:54:00 +00:00
|
|
|
@@ -2456,6 +2456,13 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
|
2021-06-11 12:02:28 +00:00
|
|
|
switch (packet.getAction()) {
|
|
|
|
case PRESS_SHIFT_KEY:
|
|
|
|
this.player.setShiftKeyDown(true);
|
|
|
|
+
|
2021-06-12 09:17:20 +00:00
|
|
|
+ // Paper start - Hang on!
|
2022-06-09 08:51:45 +00:00
|
|
|
+ if (this.player.level.paperConfig().entities.behavior.parrotsAreUnaffectedByPlayerMovement) {
|
2021-06-12 09:17:20 +00:00
|
|
|
+ this.player.removeEntitiesOnShoulder();
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2021-06-11 12:02:28 +00: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-07-27 19:49:24 +00:00
|
|
|
index 1e3ac1d2cb5adf4c0fa3b703f2ecdc32cd8ce240..07a8abb714a9dfd470ab0486c336e3b58ea927a1 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/player/Player.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/player/Player.java
|
2022-07-27 19:49:24 +00:00
|
|
|
@@ -588,7 +588,7 @@ public abstract class Player extends LivingEntity {
|
2021-06-11 12:02:28 +00:00
|
|
|
this.playShoulderEntityAmbientSound(this.getShoulderEntityLeft());
|
|
|
|
this.playShoulderEntityAmbientSound(this.getShoulderEntityRight());
|
2021-06-12 09:17:20 +00:00
|
|
|
if (!this.level.isClientSide && (this.fallDistance > 0.5F || this.isInWater()) || this.abilities.flying || this.isSleeping() || this.isInPowderSnow) {
|
2021-06-11 12:02:28 +00:00
|
|
|
- this.removeEntitiesOnShoulder();
|
2022-06-09 08:51:45 +00:00
|
|
|
+ if (!this.level.paperConfig().entities.behavior.parrotsAreUnaffectedByPlayerMovement) this.removeEntitiesOnShoulder(); // Paper - Hang on!
|
2021-06-11 12:02:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|