2020-05-06 09:48:49 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2017-12-20 22:50:26 +00:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Wed, 20 Dec 2017 17:36:49 -0500
|
|
|
|
Subject: [PATCH] Ability to apply mending to XP API
|
|
|
|
|
|
|
|
This allows plugins that give players the ability to apply the experience
|
|
|
|
points to the Item Mending formula, which will repair an item instead
|
|
|
|
of giving the player experience points.
|
|
|
|
|
|
|
|
Both an API To standalone mend, and apply mending logic to .giveExp has been added.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/EnchantmentManager.java b/src/main/java/net/minecraft/server/EnchantmentManager.java
|
2020-08-25 02:22:08 +00:00
|
|
|
index 42d6aa4bedb1978eb6e6f94e2a73520c879ab71a..b6b0460de9d7c25fafec37f4e02c2d82dd7ef986 100644
|
2017-12-20 22:50:26 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/EnchantmentManager.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EnchantmentManager.java
|
2020-08-02 05:39:36 +00:00
|
|
|
@@ -251,8 +251,8 @@ public class EnchantmentManager {
|
2018-12-17 05:18:06 +00:00
|
|
|
return getEnchantmentLevel(Enchantments.CHANNELING, itemstack) > 0;
|
2017-12-20 22:50:26 +00:00
|
|
|
}
|
|
|
|
|
2020-08-02 05:39:36 +00:00
|
|
|
- @Nullable
|
|
|
|
- public static Entry<EnumItemSlot, ItemStack> b(Enchantment enchantment, EntityLiving entityliving) {
|
|
|
|
+ public static @javax.annotation.Nonnull ItemStack getRandomEquippedItemWithEnchant(Enchantment enchantment, EntityLiving entityliving) { Entry<EnumItemSlot, ItemStack> entry = b(enchantment, entityliving); return entry != null ? entry.getValue() : ItemStack.NULL_ITEM; } // Paper - OBFHELPER
|
|
|
|
+ @Nullable public static Entry<EnumItemSlot, ItemStack> b(Enchantment enchantment, EntityLiving entityliving) {
|
2020-06-25 13:11:48 +00:00
|
|
|
return a(enchantment, entityliving, (itemstack) -> {
|
2020-08-02 05:39:36 +00:00
|
|
|
return true;
|
|
|
|
});
|
2017-12-20 22:50:26 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/EntityExperienceOrb.java b/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
2020-08-25 02:22:08 +00:00
|
|
|
index e2370b8cf76d6f06cbdaba009feaf5df98b36da4..a2eaea4bd847ebe0b3dc35c95c4c29d6c73f4797 100644
|
2017-12-20 22:50:26 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
2020-06-25 13:11:48 +00:00
|
|
|
@@ -249,10 +249,12 @@ public class EntityExperienceOrb extends Entity {
|
2017-12-20 22:50:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-02 05:39:36 +00:00
|
|
|
+ public final int durToXp(int i) { return b(i); } // Paper OBFHELPER
|
2018-07-18 04:52:33 +00:00
|
|
|
private int b(int i) {
|
2017-12-20 22:50:26 +00:00
|
|
|
return i / 2;
|
|
|
|
}
|
|
|
|
|
2020-08-02 05:39:36 +00:00
|
|
|
+ public final int xpToDur(int i) { return c(i); } // Paper OBFHELPER
|
2018-07-18 04:52:33 +00:00
|
|
|
private int c(int i) {
|
2017-12-20 22:50:26 +00:00
|
|
|
return i * 2;
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2020-10-17 10:39:45 +00:00
|
|
|
index abc0466a2d6a059a401f57d93cd4e9465de14461..0ab5915d447b7a23deccb54763f54d09e83cf88e 100644
|
2017-12-20 22:50:26 +00:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2020-10-17 10:39:45 +00:00
|
|
|
@@ -1098,8 +1098,37 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2017-12-20 22:50:26 +00:00
|
|
|
return GameMode.getByValue(getHandle().playerInteractManager.getGameMode().getId());
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
@Override
|
|
|
|
- public void giveExp(int exp) {
|
|
|
|
+ public int applyMending(int amount) {
|
|
|
|
+ EntityPlayer handle = getHandle();
|
|
|
|
+ // Logic copied from EntityExperienceOrb and remapped to unobfuscated methods/properties
|
2018-07-19 04:42:43 +00:00
|
|
|
+ net.minecraft.server.ItemStack itemstack = net.minecraft.server.EnchantmentManager.getRandomEquippedItemWithEnchant(net.minecraft.server.Enchantments.MENDING, handle);
|
|
|
|
+ if (!itemstack.isEmpty() && itemstack.getItem().usesDurability()) {
|
2017-12-20 22:50:26 +00:00
|
|
|
+
|
2019-05-06 00:57:14 +00:00
|
|
|
+ net.minecraft.server.EntityExperienceOrb orb = net.minecraft.server.EntityTypes.EXPERIENCE_ORB.create(handle.world);
|
2017-12-20 22:50:26 +00:00
|
|
|
+ orb.value = amount;
|
|
|
|
+ orb.spawnReason = org.bukkit.entity.ExperienceOrb.SpawnReason.CUSTOM;
|
2019-12-12 18:45:00 +00:00
|
|
|
+ orb.setPositionRaw(handle.locX(), handle.locY(), handle.locZ());
|
2017-12-20 22:50:26 +00:00
|
|
|
+
|
|
|
|
+ int i = Math.min(orb.xpToDur(amount), itemstack.getDamage());
|
|
|
|
+ org.bukkit.event.player.PlayerItemMendEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerItemMendEvent(handle, orb, itemstack, i);
|
|
|
|
+ i = event.getRepairAmount();
|
|
|
|
+ orb.dead = true;
|
|
|
|
+ if (!event.isCancelled()) {
|
|
|
|
+ amount -= orb.durToXp(i);
|
|
|
|
+ itemstack.setDamage(itemstack.getDamage() - i);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return amount;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void giveExp(int exp, boolean applyMending) {
|
|
|
|
+ if (applyMending) {
|
|
|
|
+ exp = this.applyMending(exp);
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
getHandle().giveExp(exp);
|
|
|
|
}
|
|
|
|
|