2018-06-18 01:13:16 -04:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
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
2019-01-01 03:15:55 +00:00
index 1eadc4371..80f112d99 100644
2018-06-18 01:13:16 -04:00
--- a/src/main/java/net/minecraft/server/ItemBow.java
+++ b/src/main/java/net/minecraft/server/ItemBow.java
@@ -0,0 +0,0 @@
package net.minecraft.server;
+import org.bukkit.craftbukkit.inventory.CraftItemStack;
import org.bukkit.event.entity.EntityCombustEvent; // CraftBukkit
public class ItemBow extends Item {
@@ -0,0 +0,0 @@ public class ItemBow extends Item {
2018-07-19 00:16:19 +01:00
// CraftBukkit end
2018-06-18 01:13:16 -04:00
}
- private ItemStack a(EntityHuman entityhuman) {
2018-07-19 00:16:19 +01:00
- if (this.e_(entityhuman.b(EnumHand.OFF_HAND))) {
2018-06-18 01:13:16 -04:00
+ private ItemStack a(EntityHuman entityhuman, ItemStack bow) { // Paper
2018-07-19 00:16:19 +01:00
+ if (this.e_(entityhuman, bow, entityhuman.b(EnumHand.OFF_HAND))) { // Paper
2018-06-18 01:13:16 -04:00
return entityhuman.b(EnumHand.OFF_HAND);
2018-07-19 00:16:19 +01:00
- } else if (this.e_(entityhuman.b(EnumHand.MAIN_HAND))) {
+ } else if (this.e_(entityhuman, bow, entityhuman.b(EnumHand.MAIN_HAND))) {
2018-06-18 01:13:16 -04: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 00:16:19 +01:00
- if (this.e_(itemstack)) {
+ if (this.e_(entityhuman, bow, itemstack)) {
2018-06-18 01:13:16 -04:00
return itemstack;
}
}
@@ -0,0 +0,0 @@ public class ItemBow extends Item {
}
}
2018-07-19 00:16:19 +01:00
- protected boolean e_(ItemStack itemstack) {
2018-06-18 01:13:16 -04:00
- return itemstack.getItem() instanceof ItemArrow;
+ // Paper start
2018-07-19 00:16:19 +01:00
+ protected boolean e_(EntityHuman player, ItemStack bow, ItemStack itemstack) {
2018-06-18 01:13:16 -04: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()) {
@@ -0,0 +0,0 @@ public class ItemBow extends Item {
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) {
2019-01-01 03:15:55 +00:00
return flag ? new InteractionResultWrapper<>(EnumInteractionResult.PASS, itemstack) : new InteractionResultWrapper<>(EnumInteractionResult.FAIL, itemstack);
2018-06-18 01:13:16 -04:00
--