2021-06-11 20:02:28 +08: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/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
index c611b5a63498f5ad1f50a75ccd5d7299e27df7e3..9d1cddc6038f0fd0286e4a32013ae98ff0b00dd1 100644
|
|
|
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
@@ -330,4 +330,10 @@ public class PaperWorldConfig {
|
|
|
|
maxCollisionsPerEntity = getInt( "max-entity-collisions", this.spigotConfig.getInt("max-entity-collisions", 8) );
|
|
|
|
log( "Max Entity Collisions: " + maxCollisionsPerEntity );
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+ public boolean parrotsHangOnBetter;
|
|
|
|
+ private void parrotsHangOnBetter() {
|
|
|
|
+ parrotsHangOnBetter = getBoolean("parrots-are-unaffected-by-player-movement", false);
|
|
|
|
+ log("Parrots are unaffected by player movement: " + parrotsHangOnBetter);
|
|
|
|
+ }
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2021-06-12 17:17:20 +08:00
|
|
|
index 624776a85a3e3268665571635f0b837cb810a62e..acee61af1b01c7e66c3b5c7e164ddd9a88e53606 100644
|
2021-06-11 20:02:28 +08:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2021-06-12 17:17:20 +08:00
|
|
|
@@ -2056,6 +2056,13 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser
|
2021-06-11 20:02:28 +08:00
|
|
|
switch (packet.getAction()) {
|
|
|
|
case PRESS_SHIFT_KEY:
|
|
|
|
this.player.setShiftKeyDown(true);
|
|
|
|
+
|
2021-06-12 17:17:20 +08:00
|
|
|
+ // Paper start - Hang on!
|
|
|
|
+ if (this.player.level.paperConfig.parrotsHangOnBetter) {
|
|
|
|
+ this.player.removeEntitiesOnShoulder();
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2021-06-11 20:02:28 +08: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
|
2021-06-12 17:17:20 +08:00
|
|
|
index e8768625e55f849cd31784cb46e67293bcd93abf..73277b04a45444edce02cce3e033741ebaf2ad0c 100644
|
2021-06-11 20:02:28 +08:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/player/Player.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/player/Player.java
|
2021-06-12 17:17:20 +08:00
|
|
|
@@ -579,7 +579,7 @@ public abstract class Player extends LivingEntity {
|
2021-06-11 20:02:28 +08:00
|
|
|
this.playShoulderEntityAmbientSound(this.getShoulderEntityLeft());
|
|
|
|
this.playShoulderEntityAmbientSound(this.getShoulderEntityRight());
|
2021-06-12 17:17:20 +08:00
|
|
|
if (!this.level.isClientSide && (this.fallDistance > 0.5F || this.isInWater()) || this.abilities.flying || this.isSleeping() || this.isInPowderSnow) {
|
2021-06-11 20:02:28 +08:00
|
|
|
- this.removeEntitiesOnShoulder();
|
|
|
|
+ if (!this.level.paperConfig.parrotsHangOnBetter) this.removeEntitiesOnShoulder(); // Paper - Hang on!
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2021-06-12 17:17:20 +08:00
|
|
|
@@ -1939,7 +1939,7 @@ public abstract class Player extends LivingEntity {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
- protected void removeEntitiesOnShoulder() {
|
|
|
|
+ public void removeEntitiesOnShoulder() { // Paper - protected -> public
|
|
|
|
if (this.timeEntitySatOnShoulder + 20L < this.level.getGameTime()) {
|
|
|
|
// CraftBukkit start
|
|
|
|
if (this.spawnEntityFromShoulder(this.getShoulderEntityLeft())) {
|