From 20fc9ddcd798168124bbb0efb50264d45a0b86af Mon Sep 17 00:00:00 2001
From: Jedediah Smith <jedediah@silencegreys.com>
Date: Fri, 4 Mar 2016 03:16:11 -0500
Subject: [PATCH] Arrow pickup rule API


diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftArrow.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftArrow.java
index 2a3482c..fbf289f 100644
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftArrow.java
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftArrow.java
@@ -72,6 +72,44 @@ public class CraftArrow extends AbstractProjectile implements Arrow {
         getHandle().shooter = ((CraftLivingEntity) shooter).getHandle();
     }
 
+    // Paper start
+    @Override
+    public PickupRule getPickupRule() {
+        return convertPickupRule(this.getHandle().fromPlayer);
+    }
+
+    @Override
+    public void setPickupRule(PickupRule rule) {
+        this.getHandle().fromPlayer = convertPickupRule(rule);
+    }
+
+    public static PickupRule convertPickupRule(EntityArrow.PickupStatus nms) {
+        switch (nms) {
+            case DISALLOWED:
+                return PickupRule.DISALLOWED;
+            case ALLOWED:
+                return PickupRule.ALLOWED;
+            case CREATIVE_ONLY:
+                return PickupRule.CREATIVE_ONLY;
+            default:
+                throw new IllegalStateException();
+        }
+    }
+
+    public static EntityArrow.PickupStatus convertPickupRule(PickupRule bukkit) {
+        switch (bukkit) {
+            case DISALLOWED:
+                return EntityArrow.PickupStatus.DISALLOWED;
+            case ALLOWED:
+                return EntityArrow.PickupStatus.ALLOWED;
+            case CREATIVE_ONLY:
+                return EntityArrow.PickupStatus.CREATIVE_ONLY;
+            default:
+                throw new IllegalStateException();
+        }
+    }
+    // Paper end
+
     // Spigot start
     private final Arrow.Spigot spigot = new Arrow.Spigot()
     {
-- 
2.10.2