Update patches to latest 1.21.4 #1

Merged
Chaoscaot merged 242 commits from update/1.21.4 into main 2025-04-23 22:27:11 +02:00
151 changed files with 2108 additions and 766 deletions
Showing only changes of commit ad74b673fa - Show all commits

View File

@ -1,10 +1,18 @@
--- a/net/minecraft/world/item/ServerItemCooldowns.java --- a/net/minecraft/world/item/ServerItemCooldowns.java
+++ b/net/minecraft/world/item/ServerItemCooldowns.java +++ b/net/minecraft/world/item/ServerItemCooldowns.java
@@ -11,6 +_,39 @@ @@ -11,6 +_,50 @@
this.player = player; this.player = player;
} }
+ // Paper start - Add PlayerItemCooldownEvent + // Paper start - Add PlayerItemCooldownEvent
+ private int getCurrentCooldown(final ResourceLocation groupId) {
+ final net.minecraft.world.item.ItemCooldowns.CooldownInstance cooldownInstance = this.cooldowns.get(groupId);
+ if (cooldownInstance == null) {
+ return 0;
+ }
+ return Math.max(0, cooldownInstance.endTime() - this.tickCount);
+ }
+
+ @Override + @Override
+ public void addCooldown(ItemStack item, int duration) { + public void addCooldown(ItemStack item, int duration) {
+ final ResourceLocation cooldownGroup = this.getCooldownGroup(item); + final ResourceLocation cooldownGroup = this.getCooldownGroup(item);
@ -15,7 +23,9 @@
+ duration + duration
+ ); + );
+ if (event.callEvent()) { + if (event.callEvent()) {
+ super.addCooldown(cooldownGroup, event.getCooldown(), false); + this.addCooldown(cooldownGroup, event.getCooldown(), false);
+ } else {
+ this.player.connection.send(new ClientboundCooldownPacket(cooldownGroup, this.getCurrentCooldown(cooldownGroup)));
+ } + }
+ } + }
+ +
@ -28,6 +38,7 @@
+ duration + duration
+ ); + );
+ if (!event.callEvent()) { + if (!event.callEvent()) {
+ this.player.connection.send(new ClientboundCooldownPacket(groupId, this.getCurrentCooldown(groupId)));
+ return; + return;
+ } + }
+ +