Skip to content
This repository was archived by the owner on Apr 13, 2025. It is now read-only.

Commit a14011f

Browse files
committed
Updated Upstream (Paper)
Upstream has released updates that appear to apply and compile correctly Paper Changes: PaperMC/Paper@3d13b115 fix: switch back to using a snapshot for velocity-natives PaperMC/Paper@7afae7f4 Add client tick end event (#12199) PaperMC/Paper@e5d988df Revert "Fix cancelling PlayerInteractEvent at (0, 0, 0) (#12215)" PaperMC/Paper@743346a5 Force update attributes PaperMC/Paper@1a7288aa Adjust unloaded chunk check for block digging
1 parent 4a3b139 commit a14011f

3 files changed

Lines changed: 20 additions & 20 deletions

File tree

gradle.properties

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ group = org.purpurmc.purpur
22
version = 1.21.4-R0.1-SNAPSHOT
33

44
mcVersion = 1.21.4
5-
paperCommit = 34c794dc51305e50c315e07e555a4ba10c208357
5+
paperCommit = 1a7288aa05cfb0a168850a7cc879f55235fe5934
66

77
org.gradle.configuration-cache = true
88
org.gradle.caching = true

purpur-server/minecraft-patches/features/0001-Ridables.patch

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,7 @@ index 121b57c7f5345f5d8884eaa1d36dac79fb7d42ef..9afbfe9bf493e09ca1963e8956ab7573
3030
/* Drop global time updates
3131
if (this.tickCount % 20 == 0) {
3232
diff --git a/net/minecraft/server/level/ServerLevel.java b/net/minecraft/server/level/ServerLevel.java
33-
index c9eef7221254f3661959a4898485c97b87ec1b8d..b801e2d595383e12120abe3b1b95cbc364515be9 100644
33+
index 63b1b2f920d5f2beb23433a373233aa2f1f95dbb..3c3e8e58cd2761ab2f0652e63f944a5c9a95dca8 100644
3434
--- a/net/minecraft/server/level/ServerLevel.java
3535
+++ b/net/minecraft/server/level/ServerLevel.java
3636
@@ -217,6 +217,7 @@ public class ServerLevel extends Level implements ServerEntityGetter, WorldGenLe
@@ -62,10 +62,10 @@ index a6f771cbee878eb383b67c61fa2469f2916413b5..d77381237f8a7d1b2f280a5032f5e1c8
6262

6363
private void updatePlayerAttributes() {
6464
diff --git a/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/net/minecraft/server/network/ServerGamePacketListenerImpl.java
65-
index 77e7665b56810762f58096e2482f019bbc3918cb..aa982f27e80f6023cadb2d2e5d0f84e472ee863c 100644
65+
index 82fb27ea7d3a21b4eb588c2b6c9f9da213db6a88..032d298dadb64ceb5f110a62402a08f78fc99c34 100644
6666
--- a/net/minecraft/server/network/ServerGamePacketListenerImpl.java
6767
+++ b/net/minecraft/server/network/ServerGamePacketListenerImpl.java
68-
@@ -2835,6 +2835,8 @@ public class ServerGamePacketListenerImpl
68+
@@ -2845,6 +2845,8 @@ public class ServerGamePacketListenerImpl
6969

7070
ServerGamePacketListenerImpl.this.cserver.getPluginManager().callEvent(event);
7171

purpur-server/minecraft-patches/sources/net/minecraft/server/network/ServerGamePacketListenerImpl.java.patch

Lines changed: 16 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
--- a/net/minecraft/server/network/ServerGamePacketListenerImpl.java
22
+++ b/net/minecraft/server/network/ServerGamePacketListenerImpl.java
3-
@@ -326,6 +_,20 @@
4-
this.chatMessageChain = new FutureChain(server.chatExecutor); // CraftBukkit - async chat
3+
@@ -328,6 +_,20 @@
4+
this.tickEndEvent = new io.papermc.paper.event.packet.ClientTickEndEvent(player.getBukkitEntity()); // Paper - add client tick end event
55
}
66

77
+ // Purpur start - AFK API
@@ -21,7 +21,7 @@
2121
@Override
2222
public void tick() {
2323
if (this.ackBlockChangesUpTo > -1) {
24-
@@ -384,6 +_,12 @@
24+
@@ -386,6 +_,12 @@
2525
if (this.player.getLastActionTime() > 0L
2626
&& this.server.getPlayerIdleTimeout() > 0
2727
&& Util.getMillis() - this.player.getLastActionTime() > this.server.getPlayerIdleTimeout() * 1000L * 60L && !this.player.wonGame) { // Paper - Prevent AFK kick while watching end credits
@@ -34,7 +34,7 @@
3434
this.player.resetLastActionTime(); // CraftBukkit - SPIGOT-854
3535
this.disconnect(Component.translatable("multiplayer.disconnect.idling"), org.bukkit.event.player.PlayerKickEvent.Cause.IDLING); // Paper - kick event cause
3636
}
37-
@@ -629,6 +_,8 @@
37+
@@ -631,6 +_,8 @@
3838
this.lastYaw = to.getYaw();
3939
this.lastPitch = to.getPitch();
4040

@@ -43,15 +43,15 @@
4343
Location oldTo = to.clone();
4444
PlayerMoveEvent event = new PlayerMoveEvent(player, from, to);
4545
this.cserver.getPluginManager().callEvent(event);
46-
@@ -709,6 +_,7 @@
46+
@@ -711,6 +_,7 @@
4747
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.serverLevel());
4848
if (packet.getId() == this.awaitingTeleport) {
4949
if (this.awaitingPositionFromClient == null) {
5050
+ ServerGamePacketListenerImpl.LOGGER.warn("Disconnected on accept teleport packet. Was not expecting position data from client at this time"); // Purpur - Add more logger output for invalid movement kicks
5151
this.disconnect(Component.translatable("multiplayer.disconnect.invalid_player_movement"), org.bukkit.event.player.PlayerKickEvent.Cause.INVALID_PLAYER_MOVEMENT); // Paper - kick event cause
5252
return;
5353
}
54-
@@ -1176,6 +_,10 @@
54+
@@ -1179,6 +_,10 @@
5555
final int maxBookPageSize = pageMax.intValue();
5656
final double multiplier = Math.clamp(io.papermc.paper.configuration.GlobalConfiguration.get().itemValidation.bookSize.totalMultiplier, 0.3D, 1D);
5757
long byteAllowed = maxBookPageSize;
@@ -62,7 +62,7 @@
6262
for (final String page : pageList) {
6363
final int byteLength = page.getBytes(java.nio.charset.StandardCharsets.UTF_8).length;
6464
byteTotal += byteLength;
65-
@@ -1200,7 +_,8 @@
65+
@@ -1203,7 +_,8 @@
6666
}
6767

6868
if (byteTotal > byteAllowed) {
@@ -72,7 +72,7 @@
7272
this.disconnectAsync(Component.literal("Book too large!"), org.bukkit.event.player.PlayerKickEvent.Cause.ILLEGAL_ACTION); // Paper - kick event cause // Paper - add proper async disconnect
7373
return;
7474
}
75-
@@ -1219,31 +_,45 @@
75+
@@ -1222,31 +_,45 @@
7676
Optional<String> optional = packet.title();
7777
optional.ifPresent(list::add);
7878
list.addAll(packet.pages());
@@ -122,7 +122,7 @@
122122
itemStack.set(
123123
DataComponents.WRITTEN_BOOK_CONTENT,
124124
new WrittenBookContent(this.filterableFromOutgoing(title), this.player.getName().getString(), 0, list, true)
125-
@@ -1257,6 +_,16 @@
125+
@@ -1260,6 +_,16 @@
126126
return this.player.isTextFilteringEnabled() ? Filterable.passThrough(filteredText.filteredOrEmpty()) : Filterable.from(filteredText);
127127
}
128128

@@ -139,7 +139,7 @@
139139
@Override
140140
public void handleEntityTagQuery(ServerboundEntityTagQueryPacket packet) {
141141
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.serverLevel());
142-
@@ -1292,7 +_,15 @@
142+
@@ -1295,7 +_,15 @@
143143
@Override
144144
public void handleMovePlayer(ServerboundMovePlayerPacket packet) {
145145
PacketUtils.ensureRunningOnSameThread(packet, this, this.player.serverLevel());
@@ -156,7 +156,7 @@
156156
this.disconnect(Component.translatable("multiplayer.disconnect.invalid_player_movement"), org.bukkit.event.player.PlayerKickEvent.Cause.INVALID_PLAYER_MOVEMENT); // Paper - kick event cause
157157
} else {
158158
ServerLevel serverLevel = this.player.serverLevel();
159-
@@ -1467,7 +_,7 @@
159+
@@ -1470,7 +_,7 @@
160160
movedWrongly = true;
161161
if (event.getLogWarning())
162162
// Paper end
@@ -165,7 +165,7 @@
165165
} // Paper
166166
}
167167

168-
@@ -1533,6 +_,8 @@
168+
@@ -1536,6 +_,8 @@
169169
this.lastYaw = to.getYaw();
170170
this.lastPitch = to.getPitch();
171171

@@ -174,7 +174,7 @@
174174
Location oldTo = to.clone();
175175
PlayerMoveEvent event = new PlayerMoveEvent(player, from, to);
176176
this.cserver.getPluginManager().callEvent(event);
177-
@@ -1589,6 +_,13 @@
177+
@@ -1592,6 +_,13 @@
178178
this.player.tryResetCurrentImpulseContext();
179179
}
180180

@@ -188,7 +188,7 @@
188188
this.player.checkMovementStatistics(this.player.getX() - x, this.player.getY() - y, this.player.getZ() - z);
189189
this.lastGoodX = this.player.getX();
190190
this.lastGoodY = this.player.getY();
191-
@@ -1637,6 +_,17 @@
191+
@@ -1640,6 +_,17 @@
192192
}
193193
}
194194

@@ -206,15 +206,15 @@
206206
// Paper start - optimise out extra getCubes
207207
private boolean hasNewCollision(final ServerLevel level, final Entity entity, final AABB oldBox, final AABB newBox) {
208208
final List<AABB> collisionsBB = new java.util.ArrayList<>();
209-
@@ -2001,6 +_,7 @@
209+
@@ -2010,6 +_,7 @@
210210

211211
boolean cancelled;
212212
if (hitResult == null || hitResult.getType() != HitResult.Type.BLOCK) {
213213
+ if (this.player.gameMode.shiftClickMended(itemInHand)) return; // Purpur - Shift right click to use exp for mending
214214
org.bukkit.event.player.PlayerInteractEvent event = CraftEventFactory.callPlayerInteractEvent(this.player, Action.RIGHT_CLICK_AIR, itemInHand, hand);
215215
cancelled = event.useItemInHand() == Event.Result.DENY;
216216
} else {
217-
@@ -2741,6 +_,7 @@
217+
@@ -2751,6 +_,7 @@
218218

219219
AABB boundingBox = target.getBoundingBox();
220220
if (this.player.canInteractWithEntity(boundingBox, io.papermc.paper.configuration.GlobalConfiguration.get().misc.clientInteractionLeniencyDistance.or(3.0))) { // Paper - configurable lenience value for interact range

0 commit comments

Comments
 (0)