2018-07-23 16:39:55 +08:00
From 637bff64eeaaf0fc7af097f126863f0b81da9240 Mon Sep 17 00:00:00 2001
2018-06-18 13:13:16 +08:00
From: Aikar <aikar@aikar.co>
Date: Mon, 18 Jun 2018 01:12:53 -0400
Subject: [PATCH] PlayerReadyArrowEvent
Called when a player is firing a bow and the server is choosing an arrow to use.
Plugins can skip selection of certain arrows and control which is used.
diff --git a/src/main/java/net/minecraft/server/ItemBow.java b/src/main/java/net/minecraft/server/ItemBow.java
2018-07-23 16:39:55 +08:00
index 379a7f84a5..c0caeda362 100644
2018-06-18 13:13:16 +08:00
--- a/src/main/java/net/minecraft/server/ItemBow.java
+++ b/src/main/java/net/minecraft/server/ItemBow.java
@@ -1,5 +1,6 @@
package net.minecraft.server;
+import org.bukkit.craftbukkit.inventory.CraftItemStack;
import org.bukkit.event.entity.EntityCombustEvent; // CraftBukkit
public class ItemBow extends Item {
2018-07-19 07:16:19 +08:00
@@ -18,16 +19,16 @@ public class ItemBow extends Item {
// CraftBukkit end
2018-06-18 13:13:16 +08:00
}
- private ItemStack a(EntityHuman entityhuman) {
2018-07-19 07:16:19 +08:00
- if (this.e_(entityhuman.b(EnumHand.OFF_HAND))) {
2018-06-18 13:13:16 +08:00
+ private ItemStack a(EntityHuman entityhuman, ItemStack bow) { // Paper
2018-07-19 07:16:19 +08:00
+ if (this.e_(entityhuman, bow, entityhuman.b(EnumHand.OFF_HAND))) { // Paper
2018-06-18 13:13:16 +08:00
return entityhuman.b(EnumHand.OFF_HAND);
2018-07-19 07:16:19 +08:00
- } else if (this.e_(entityhuman.b(EnumHand.MAIN_HAND))) {
+ } else if (this.e_(entityhuman, bow, entityhuman.b(EnumHand.MAIN_HAND))) {
2018-06-18 13:13:16 +08:00
return entityhuman.b(EnumHand.MAIN_HAND);
} else {
for (int i = 0; i < entityhuman.inventory.getSize(); ++i) {
ItemStack itemstack = entityhuman.inventory.getItem(i);
2018-07-19 07:16:19 +08:00
- if (this.e_(itemstack)) {
+ if (this.e_(entityhuman, bow, itemstack)) {
2018-06-18 13:13:16 +08:00
return itemstack;
}
}
2018-07-19 07:16:19 +08:00
@@ -36,15 +37,23 @@ public class ItemBow extends Item {
2018-06-18 13:13:16 +08:00
}
}
2018-07-19 07:16:19 +08:00
- protected boolean e_(ItemStack itemstack) {
2018-06-18 13:13:16 +08:00
- return itemstack.getItem() instanceof ItemArrow;
+ // Paper start
2018-07-19 07:16:19 +08:00
+ protected boolean e_(EntityHuman player, ItemStack bow, ItemStack itemstack) {
2018-06-18 13:13:16 +08:00
+ return itemstack.getItem() instanceof ItemArrow && (
+ !(player instanceof EntityPlayer) ||
+ new com.destroystokyo.paper.event.player.PlayerReadyArrowEvent(
+ ((EntityPlayer) player).getBukkitEntity(),
+ CraftItemStack.asCraftMirror(bow),
+ CraftItemStack.asCraftMirror(itemstack)
+ ).callEvent());
+ // Paper end
}
public void a(ItemStack itemstack, World world, EntityLiving entityliving, int i) {
if (entityliving instanceof EntityHuman) {
EntityHuman entityhuman = (EntityHuman) entityliving;
boolean flag = entityhuman.abilities.canInstantlyBuild || EnchantmentManager.getEnchantmentLevel(Enchantments.ARROW_INFINITE, itemstack) > 0;
- ItemStack itemstack1 = this.a(entityhuman);
+ ItemStack itemstack1 = this.a(entityhuman, itemstack); // Paper
if (!itemstack1.isEmpty() || flag) {
if (itemstack1.isEmpty()) {
2018-07-19 07:16:19 +08:00
@@ -148,7 +157,7 @@ public class ItemBow extends Item {
2018-06-18 13:13:16 +08:00
public InteractionResultWrapper<ItemStack> a(World world, EntityHuman entityhuman, EnumHand enumhand) {
ItemStack itemstack = entityhuman.b(enumhand);
- boolean flag = !this.a(entityhuman).isEmpty();
+ boolean flag = !this.a(entityhuman, itemstack).isEmpty(); // Paper
if (!entityhuman.abilities.canInstantlyBuild && !flag) {
return flag ? new InteractionResultWrapper(EnumInteractionResult.PASS, itemstack) : new InteractionResultWrapper(EnumInteractionResult.FAIL, itemstack);
--
2018-06-30 13:40:52 +08:00
2.18.0
2018-06-18 13:13:16 +08:00