Revert "Made EntityEquipEvent cancellable"

This reverts commit d72fb72e
This commit is contained in:
Arne Dalhuisen 2021-05-11 20:11:56 +02:00
parent d72fb72e74
commit 00278881ee
5 changed files with 28 additions and 82 deletions

View File

@ -1,5 +1,6 @@
package net.minestom.server.entity; package net.minestom.server.entity;
import net.minestom.server.event.item.EntityEquipEvent;
import net.minestom.server.item.attribute.AttributeSlot; import net.minestom.server.item.attribute.AttributeSlot;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;

View File

@ -127,12 +127,9 @@ public class LivingEntity extends Entity implements EquipmentHandler {
@Override @Override
public void setItemInMainHand(@NotNull ItemStack itemStack) { public void setItemInMainHand(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.MAIN_HAND); this.mainHandItem = getEquipmentItem(itemStack, EquipmentSlot.MAIN_HAND);
if (itemStack != null) {
this.mainHandItem = itemStack;
syncEquipment(EquipmentSlot.MAIN_HAND); syncEquipment(EquipmentSlot.MAIN_HAND);
} }
}
@NotNull @NotNull
@Override @Override
@ -142,12 +139,9 @@ public class LivingEntity extends Entity implements EquipmentHandler {
@Override @Override
public void setItemInOffHand(@NotNull ItemStack itemStack) { public void setItemInOffHand(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.OFF_HAND); this.offHandItem = getEquipmentItem(itemStack, EquipmentSlot.OFF_HAND);
if (itemStack != null) {
this.offHandItem = itemStack;
syncEquipment(EquipmentSlot.OFF_HAND); syncEquipment(EquipmentSlot.OFF_HAND);
} }
}
@NotNull @NotNull
@Override @Override
@ -157,12 +151,9 @@ public class LivingEntity extends Entity implements EquipmentHandler {
@Override @Override
public void setHelmet(@NotNull ItemStack itemStack) { public void setHelmet(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.HELMET); this.helmet = getEquipmentItem(itemStack, EquipmentSlot.HELMET);
if (itemStack != null) {
this.helmet = itemStack;
syncEquipment(EquipmentSlot.HELMET); syncEquipment(EquipmentSlot.HELMET);
} }
}
@NotNull @NotNull
@Override @Override
@ -172,12 +163,9 @@ public class LivingEntity extends Entity implements EquipmentHandler {
@Override @Override
public void setChestplate(@NotNull ItemStack itemStack) { public void setChestplate(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.CHESTPLATE); this.chestplate = getEquipmentItem(itemStack, EquipmentSlot.CHESTPLATE);
if (itemStack != null) {
this.chestplate = itemStack;
syncEquipment(EquipmentSlot.CHESTPLATE); syncEquipment(EquipmentSlot.CHESTPLATE);
} }
}
@NotNull @NotNull
@Override @Override
@ -187,12 +175,9 @@ public class LivingEntity extends Entity implements EquipmentHandler {
@Override @Override
public void setLeggings(@NotNull ItemStack itemStack) { public void setLeggings(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.LEGGINGS); this.leggings = getEquipmentItem(itemStack, EquipmentSlot.LEGGINGS);
if (itemStack != null) {
this.leggings = itemStack;
syncEquipment(EquipmentSlot.LEGGINGS); syncEquipment(EquipmentSlot.LEGGINGS);
} }
}
@NotNull @NotNull
@Override @Override
@ -202,17 +187,14 @@ public class LivingEntity extends Entity implements EquipmentHandler {
@Override @Override
public void setBoots(@NotNull ItemStack itemStack) { public void setBoots(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.BOOTS); this.boots = getEquipmentItem(itemStack, EquipmentSlot.BOOTS);
if (itemStack != null) {
this.boots = itemStack;
syncEquipment(EquipmentSlot.BOOTS); syncEquipment(EquipmentSlot.BOOTS);
} }
}
private ItemStack getEquipmentItem(@NotNull ItemStack itemStack, @NotNull EquipmentSlot slot) { private ItemStack getEquipmentItem(@NotNull ItemStack itemStack, @NotNull EquipmentSlot slot) {
EntityEquipEvent entityEquipEvent = new EntityEquipEvent(this, itemStack, slot); EntityEquipEvent entityEquipEvent = new EntityEquipEvent(this, itemStack, slot);
callEvent(EntityEquipEvent.class, entityEquipEvent); callEvent(EntityEquipEvent.class, entityEquipEvent);
return entityEquipEvent.isCancelled() ? null : entityEquipEvent.getEquippedItem(); return entityEquipEvent.getEquippedItem();
} }
@Override @Override

View File

@ -69,12 +69,9 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
@Override @Override
public void setItemInMainHand(@NotNull ItemStack itemStack) { public void setItemInMainHand(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.MAIN_HAND); this.mainHandItem = getEquipmentItem(itemStack, EquipmentSlot.MAIN_HAND);
if (itemStack != null) {
this.mainHandItem = itemStack;
syncEquipment(EquipmentSlot.MAIN_HAND); syncEquipment(EquipmentSlot.MAIN_HAND);
} }
}
@NotNull @NotNull
@Override @Override
@ -84,12 +81,9 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
@Override @Override
public void setItemInOffHand(@NotNull ItemStack itemStack) { public void setItemInOffHand(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.OFF_HAND); this.offHandItem = getEquipmentItem(itemStack, EquipmentSlot.OFF_HAND);
if (itemStack != null) {
this.offHandItem = itemStack;
syncEquipment(EquipmentSlot.OFF_HAND); syncEquipment(EquipmentSlot.OFF_HAND);
} }
}
@NotNull @NotNull
@Override @Override
@ -99,12 +93,9 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
@Override @Override
public void setHelmet(@NotNull ItemStack itemStack) { public void setHelmet(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.HELMET); this.helmet = getEquipmentItem(itemStack, EquipmentSlot.HELMET);
if (itemStack != null) {
this.helmet = itemStack;
syncEquipment(EquipmentSlot.HELMET); syncEquipment(EquipmentSlot.HELMET);
} }
}
@NotNull @NotNull
@Override @Override
@ -114,12 +105,9 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
@Override @Override
public void setChestplate(@NotNull ItemStack itemStack) { public void setChestplate(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.CHESTPLATE); this.chestplate = getEquipmentItem(itemStack, EquipmentSlot.CHESTPLATE);
if (itemStack != null) {
this.chestplate = itemStack;
syncEquipment(EquipmentSlot.CHESTPLATE); syncEquipment(EquipmentSlot.CHESTPLATE);
} }
}
@NotNull @NotNull
@Override @Override
@ -129,12 +117,9 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
@Override @Override
public void setLeggings(@NotNull ItemStack itemStack) { public void setLeggings(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.LEGGINGS); this.leggings = getEquipmentItem(itemStack, EquipmentSlot.LEGGINGS);
if (itemStack != null) {
this.leggings = itemStack;
syncEquipment(EquipmentSlot.LEGGINGS); syncEquipment(EquipmentSlot.LEGGINGS);
} }
}
@NotNull @NotNull
@Override @Override
@ -144,12 +129,9 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
@Override @Override
public void setBoots(@NotNull ItemStack itemStack) { public void setBoots(@NotNull ItemStack itemStack) {
itemStack = getEquipmentItem(itemStack, EquipmentSlot.BOOTS); this.boots = getEquipmentItem(itemStack, EquipmentSlot.BOOTS);
if (itemStack != null) {
this.boots = itemStack;
syncEquipment(EquipmentSlot.BOOTS); syncEquipment(EquipmentSlot.BOOTS);
} }
}
public boolean isSmall() { public boolean isSmall() {
return (getStateMeta() & 0x01) != 0; return (getStateMeta() & 0x01) != 0;
@ -256,6 +238,6 @@ public class EntityArmorStand extends ObjectEntity implements EquipmentHandler {
private ItemStack getEquipmentItem(@NotNull ItemStack itemStack, @NotNull EquipmentSlot slot) { private ItemStack getEquipmentItem(@NotNull ItemStack itemStack, @NotNull EquipmentSlot slot) {
EntityEquipEvent entityEquipEvent = new EntityEquipEvent(this, itemStack, slot); EntityEquipEvent entityEquipEvent = new EntityEquipEvent(this, itemStack, slot);
callEvent(EntityEquipEvent.class, entityEquipEvent); callEvent(EntityEquipEvent.class, entityEquipEvent);
return entityEquipEvent.isCancelled() ? null : entityEquipEvent.getEquippedItem(); return entityEquipEvent.getEquippedItem();
} }
} }

View File

@ -2,19 +2,16 @@ package net.minestom.server.event.item;
import net.minestom.server.entity.Entity; import net.minestom.server.entity.Entity;
import net.minestom.server.entity.EquipmentSlot; import net.minestom.server.entity.EquipmentSlot;
import net.minestom.server.event.CancellableEvent;
import net.minestom.server.event.Event; import net.minestom.server.event.Event;
import net.minestom.server.item.ItemStack; import net.minestom.server.item.ItemStack;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
public class EntityEquipEvent extends Event implements CancellableEvent { public class EntityEquipEvent extends Event {
private final Entity entity; private final Entity entity;
private ItemStack equippedItem; private ItemStack equippedItem;
private final EquipmentSlot slot; private final EquipmentSlot slot;
private boolean cancelled;
public EntityEquipEvent(@NotNull Entity entity, @NotNull ItemStack equippedItem, @NotNull EquipmentSlot slot) { public EntityEquipEvent(@NotNull Entity entity, @NotNull ItemStack equippedItem, @NotNull EquipmentSlot slot) {
this.entity = entity; this.entity = entity;
this.equippedItem = equippedItem; this.equippedItem = equippedItem;
@ -39,14 +36,4 @@ public class EntityEquipEvent extends Event implements CancellableEvent {
public EquipmentSlot getSlot() { public EquipmentSlot getSlot() {
return slot; return slot;
} }
@Override
public boolean isCancelled() {
return cancelled;
}
@Override
public void setCancelled(boolean cancel) {
this.cancelled = cancel;
}
} }

View File

@ -186,17 +186,11 @@ public class PlayerInventory extends AbstractInventory implements EquipmentHandl
equipmentSlot = EquipmentSlot.BOOTS; equipmentSlot = EquipmentSlot.BOOTS;
} }
boolean cancel = false;
if (equipmentSlot != null) { if (equipmentSlot != null) {
EntityEquipEvent entityEquipEvent = new EntityEquipEvent(player, itemStack, equipmentSlot); EntityEquipEvent entityEquipEvent = new EntityEquipEvent(player, itemStack, equipmentSlot);
player.callEvent(EntityEquipEvent.class, entityEquipEvent); player.callEvent(EntityEquipEvent.class, entityEquipEvent);
itemStack = entityEquipEvent.getEquippedItem(); itemStack = entityEquipEvent.getEquippedItem();
cancel = entityEquipEvent.isCancelled();
}
if (cancel) {
return;
} }
this.itemStacks[slot] = itemStack; this.itemStacks[slot] = itemStack;