Indestructible trait repairs items fully instead of preserving how damaged item is
vovannn012347 opened this issue ยท 1 comments
Versions:
Minecraft 1.18.2
- Silent Gear: 2.10.17
- Silent Lib: 6.2.0
- Forge: 40.2.9
- Optifine Installed: No
Expected Behavior
Indestructible items retain their durability between save and reload and on using any abilities that drain durability
indestructible trait removes all damage from item it is applied on - some items have abilities that depend on item being damaged or drain durability - item gets repaired totally instead, it is totally wrong behavior and not how indestructible is described to work
Actual Behavior
gear damage was fully reset upon using item-damaging abilities on indestructible item, gear stats did not recalculate upon this happening
gear damage was reset on indestructible item upon re-logging, gear stats were recalculated upon this happening
Links/Images
images not required, test it out - set damage functions in gear helper were not changed and that is probably where bug lies
Steps to Reproduce the Problem
1.apply indestructible to already damaged item
2.use ability that decreases durability on said item
3.observe durability fully restored, stats not recalculated
1.apply indestructible to already damaged item
2.exit world and load back in
3.observe durability fully restored, stats not recalculated
P.S. this bug is stricltly localized to few lines of code, though i do not have enough time to either install an another ide, dwelve into minecraft modding to fix it and make a merge or to fiddle with code and tell what is wrong, only localized where bug is and filing bug report instead
P.S.S. Okay, i do have the time.
How to fix it:
change this:
line 315 in src/main/java/net/silentchaos512/gear/util/GearHelper.java
public static int calcDamageClamped(ItemStack stack, int damage) {
if (isUnbreakable(stack)) return 0;
if (!canBreakPermanently(stack)) {
if (damage > stack.getDamageValue()) damage = Math.min(stack.getMaxDamage(), damage);
else damage = Math.max(0, damage);
}
return damage;
}
to this
public static int calcDamageClamped(ItemStack stack, int damage) {
if (isUnbreakable(stack)) return stack.getDamageValue();
if (!canBreakPermanently(stack)) {
if (damage > stack.getDamageValue()) damage = Math.min(stack.getMaxDamage(), damage);
else damage = Math.max(0, damage);
}
return damage;
}
and it is fixed, unbreakable does nto repair item suddenly and fully