mirror of
https://github.com/PurpurMC/Purpur.git
synced 2026-02-20 09:57:43 +01:00
Fix better mending to use damage percent instead of damage amount
This commit is contained in:
@@ -1,19 +1,20 @@
|
|||||||
From e02078a503427b52f6ec569ae026bd2706034d7e Mon Sep 17 00:00:00 2001
|
From 0d22bf42411b99685e372b4e4d661bbe15496da1 Mon Sep 17 00:00:00 2001
|
||||||
From: William Blake Galbreath <blake.galbreath@gmail.com>
|
From: William Blake Galbreath <blake.galbreath@gmail.com>
|
||||||
Date: Sun, 14 Jul 2019 19:52:47 -0500
|
Date: Sun, 14 Jul 2019 19:52:47 -0500
|
||||||
Subject: [PATCH] Mending mends most damages equipment first
|
Subject: [PATCH] Mending mends most damages equipment first
|
||||||
|
|
||||||
---
|
---
|
||||||
.../minecraft/server/EnchantmentManager.java | 22 ++++++++++++++++++-
|
.../minecraft/server/EnchantmentManager.java | 25 ++++++++++++++++++-
|
||||||
.../minecraft/server/EntityExperienceOrb.java | 2 +-
|
.../minecraft/server/EntityExperienceOrb.java | 2 +-
|
||||||
.../java/net/pl3x/purpur/PurpurConfig.java | 5 +++++
|
.../java/net/minecraft/server/ItemStack.java | 9 +++++++
|
||||||
3 files changed, 27 insertions(+), 2 deletions(-)
|
.../java/net/pl3x/purpur/PurpurConfig.java | 5 ++++
|
||||||
|
4 files changed, 39 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/EnchantmentManager.java b/src/main/java/net/minecraft/server/EnchantmentManager.java
|
diff --git a/src/main/java/net/minecraft/server/EnchantmentManager.java b/src/main/java/net/minecraft/server/EnchantmentManager.java
|
||||||
index 1d16919e6..e3bc32a77 100644
|
index 1d16919e..69746fd1 100644
|
||||||
--- a/src/main/java/net/minecraft/server/EnchantmentManager.java
|
--- a/src/main/java/net/minecraft/server/EnchantmentManager.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EnchantmentManager.java
|
+++ b/src/main/java/net/minecraft/server/EnchantmentManager.java
|
||||||
@@ -241,9 +241,29 @@ public class EnchantmentManager {
|
@@ -241,9 +241,32 @@ public class EnchantmentManager {
|
||||||
return getEnchantmentLevel(Enchantments.CHANNELING, itemstack) > 0;
|
return getEnchantmentLevel(Enchantments.CHANNELING, itemstack) > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -25,11 +26,14 @@ index 1d16919e6..e3bc32a77 100644
|
|||||||
+ return null;
|
+ return null;
|
||||||
+ }
|
+ }
|
||||||
+ Entry<EnumItemSlot, ItemStack> item = null;
|
+ Entry<EnumItemSlot, ItemStack> item = null;
|
||||||
|
+ float maxPercent = 0F;
|
||||||
+ for (Entry<EnumItemSlot, ItemStack> entry : map.entrySet()) {
|
+ for (Entry<EnumItemSlot, ItemStack> entry : map.entrySet()) {
|
||||||
+ ItemStack itemstack = entry.getValue();
|
+ ItemStack itemstack = entry.getValue();
|
||||||
+ if (!itemstack.isEmpty() && getEnchantmentLevel(enchantment, itemstack) > 0) {
|
+ if (!itemstack.isEmpty() && itemstack.isDamaged() && getEnchantmentLevel(enchantment, itemstack) > 0) {
|
||||||
+ if (item == null || itemstack.getDamage() > item.getValue().getDamage()) {
|
+ float percent = itemstack.getDamagePercent();
|
||||||
|
+ if (item == null || percent > maxPercent) {
|
||||||
+ item = entry;
|
+ item = entry;
|
||||||
|
+ maxPercent = percent;
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
@@ -45,7 +49,7 @@ index 1d16919e6..e3bc32a77 100644
|
|||||||
}
|
}
|
||||||
@Nullable
|
@Nullable
|
||||||
diff --git a/src/main/java/net/minecraft/server/EntityExperienceOrb.java b/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
diff --git a/src/main/java/net/minecraft/server/EntityExperienceOrb.java b/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
||||||
index 1a98442e0..8a4eedb74 100644
|
index 1a98442e..8a4eedb7 100644
|
||||||
--- a/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
--- a/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
+++ b/src/main/java/net/minecraft/server/EntityExperienceOrb.java
|
||||||
@@ -222,7 +222,7 @@ public class EntityExperienceOrb extends Entity {
|
@@ -222,7 +222,7 @@ public class EntityExperienceOrb extends Entity {
|
||||||
@@ -57,8 +61,32 @@ index 1a98442e0..8a4eedb74 100644
|
|||||||
|
|
||||||
if (entry != null) {
|
if (entry != null) {
|
||||||
ItemStack itemstack = (ItemStack) entry.getValue();
|
ItemStack itemstack = (ItemStack) entry.getValue();
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
|
index 0e164840..41e88916 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
|
@@ -364,10 +364,19 @@ public final class ItemStack {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+ public boolean isDamaged() { return f(); } // Purpur - OBFHELPER
|
||||||
|
public boolean f() {
|
||||||
|
return this.e() && this.getDamage() > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ public float getDamagePercent() {
|
||||||
|
+ if (isDamaged()) {
|
||||||
|
+ return (float) getDamage() / (float) getItem().getMaxDurability();
|
||||||
|
+ } else {
|
||||||
|
+ return 0F;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
public int getDamage() {
|
||||||
|
return this.tag == null ? 0 : this.tag.getInt("Damage");
|
||||||
|
}
|
||||||
diff --git a/src/main/java/net/pl3x/purpur/PurpurConfig.java b/src/main/java/net/pl3x/purpur/PurpurConfig.java
|
diff --git a/src/main/java/net/pl3x/purpur/PurpurConfig.java b/src/main/java/net/pl3x/purpur/PurpurConfig.java
|
||||||
index c4afafc59..400b7d212 100644
|
index 253e0b31..f8a35064 100644
|
||||||
--- a/src/main/java/net/pl3x/purpur/PurpurConfig.java
|
--- a/src/main/java/net/pl3x/purpur/PurpurConfig.java
|
||||||
+++ b/src/main/java/net/pl3x/purpur/PurpurConfig.java
|
+++ b/src/main/java/net/pl3x/purpur/PurpurConfig.java
|
||||||
@@ -151,6 +151,11 @@ public class PurpurConfig {
|
@@ -151,6 +151,11 @@ public class PurpurConfig {
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
From 65faec0d7231fcc6398d09453e4ce4cf4632014b Mon Sep 17 00:00:00 2001
|
From 94c7706024d3ed24336b9985ceedcf34b8a96620 Mon Sep 17 00:00:00 2001
|
||||||
From: William Blake Galbreath <blake.galbreath@gmail.com>
|
From: William Blake Galbreath <blake.galbreath@gmail.com>
|
||||||
Date: Thu, 25 Jul 2019 18:07:37 -0500
|
Date: Thu, 25 Jul 2019 18:07:37 -0500
|
||||||
Subject: [PATCH] Implement elytra settings
|
Subject: [PATCH] Implement elytra settings
|
||||||
@@ -64,10 +64,10 @@ index 9e86ef4c..832cea63 100644
|
|||||||
itemstack.subtract(1);
|
itemstack.subtract(1);
|
||||||
} else ((EntityPlayer) entityhuman).getBukkitEntity().updateInventory();
|
} else ((EntityPlayer) entityhuman).getBukkitEntity().updateInventory();
|
||||||
diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java
|
diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
index 0e164840..d9b63547 100644
|
index 41e88916..43e89b99 100644
|
||||||
--- a/src/main/java/net/minecraft/server/ItemStack.java
|
--- a/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
+++ b/src/main/java/net/minecraft/server/ItemStack.java
|
+++ b/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
@@ -393,7 +393,7 @@ public final class ItemStack {
|
@@ -402,7 +402,7 @@ public final class ItemStack {
|
||||||
int j;
|
int j;
|
||||||
|
|
||||||
if (i > 0) {
|
if (i > 0) {
|
||||||
@@ -76,7 +76,7 @@ index 0e164840..d9b63547 100644
|
|||||||
int k = 0;
|
int k = 0;
|
||||||
|
|
||||||
for (int l = 0; j > 0 && l < i; ++l) {
|
for (int l = 0; j > 0 && l < i; ++l) {
|
||||||
@@ -439,6 +439,12 @@ public final class ItemStack {
|
@@ -448,6 +448,12 @@ public final class ItemStack {
|
||||||
if (this.isDamaged(i, t0.getRandom(), t0 instanceof EntityPlayer ? (EntityPlayer) t0 : null)) {
|
if (this.isDamaged(i, t0.getRandom(), t0 instanceof EntityPlayer ? (EntityPlayer) t0 : null)) {
|
||||||
consumer.accept(t0);
|
consumer.accept(t0);
|
||||||
Item item = this.getItem();
|
Item item = this.getItem();
|
||||||
|
|||||||
Reference in New Issue
Block a user