Use itemstack in LivingEntityUseItemEvent.Finish before it was used (#5015)

This commit is contained in:
MrRiegel 2018-07-14 23:29:32 +02:00 committed by LexManos
parent 603f4bd7a3
commit cfebf27393
2 changed files with 7 additions and 4 deletions

View file

@ -367,18 +367,19 @@
if (!this.field_70170_p.field_72995_K) if (!this.field_70170_p.field_72995_K)
{ {
@@ -2700,7 +2775,9 @@ @@ -2700,7 +2775,10 @@
if (!this.field_184627_bm.func_190926_b() && this.func_184587_cr()) if (!this.field_184627_bm.func_190926_b() && this.func_184587_cr())
{ {
this.func_184584_a(this.field_184627_bm, 16); this.func_184584_a(this.field_184627_bm, 16);
- this.func_184611_a(this.func_184600_cs(), this.field_184627_bm.func_77950_b(this.field_70170_p, this)); - this.func_184611_a(this.func_184600_cs(), this.field_184627_bm.func_77950_b(this.field_70170_p, this));
+ ItemStack activeItemStackCopy = this.field_184627_bm.func_77946_l();
+ ItemStack itemstack = this.field_184627_bm.func_77950_b(this.field_70170_p, this); + ItemStack itemstack = this.field_184627_bm.func_77950_b(this.field_70170_p, this);
+ itemstack = net.minecraftforge.event.ForgeEventFactory.onItemUseFinish(this, field_184627_bm, func_184605_cv(), itemstack); + itemstack = net.minecraftforge.event.ForgeEventFactory.onItemUseFinish(this, activeItemStackCopy, func_184605_cv(), itemstack);
+ this.func_184611_a(this.func_184600_cs(), itemstack); + this.func_184611_a(this.func_184600_cs(), itemstack);
this.func_184602_cy(); this.func_184602_cy();
} }
} }
@@ -2724,7 +2801,8 @@ @@ -2724,7 +2802,8 @@
{ {
if (!this.field_184627_bm.func_190926_b()) if (!this.field_184627_bm.func_190926_b())
{ {
@ -388,7 +389,7 @@
} }
this.func_184602_cy(); this.func_184602_cy();
@@ -2852,6 +2930,31 @@ @@ -2852,6 +2931,31 @@
return true; return true;
} }

View file

@ -114,6 +114,8 @@ public class LivingEntityUseItemEvent extends LivingEvent
* The item has been notified that it was used, and the item/result stacks reflect after that state. * The item has been notified that it was used, and the item/result stacks reflect after that state.
* This means that when this is fired for a Potion, the potion effect has already been applied. * This means that when this is fired for a Potion, the potion effect has already been applied.
* *
* {@link LivingEntityUseItemEvent#item} is a copy of the item BEFORE it was used.
*
* If you wish to cancel those effects, you should cancel one of the above events. * If you wish to cancel those effects, you should cancel one of the above events.
* *
* The result item stack is the stack that is placed in the player's inventory in replacement of the stack that is currently being used. * The result item stack is the stack that is placed in the player's inventory in replacement of the stack that is currently being used.