--- a/net/minecraft/server/EntityThrownExpBottle.java
+++ b/net/minecraft/server/EntityThrownExpBottle.java
@@ -20,9 +20,18 @@
 
     protected void a(MovingObjectPosition movingobjectposition) {
         if (!this.world.isClientSide) {
-            this.world.triggerEffect(2002, new BlockPosition(this), PotionUtil.a(Potions.b));
+            // CraftBukkit - moved to after event
+            // this.world.triggerEffect(2002, new BlockPosition(this), PotionUtil.a(Potions.b));
             int i = 3 + this.world.random.nextInt(5) + this.world.random.nextInt(5);
 
+            // CraftBukkit start
+            org.bukkit.event.entity.ExpBottleEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callExpBottleEvent(this, i);
+            i = event.getExperience();
+            if (event.getShowEffect()) {
+                this.world.triggerEffect(2002, new BlockPosition(this), PotionUtil.a(Potions.b));
+            }
+            // CraftBukkit end
+
             while (i > 0) {
                 int j = EntityExperienceOrb.getOrbValue(i);