--- a/net/minecraft/world/entity/projectile/EntityTippedArrow.java +++ b/net/minecraft/world/entity/projectile/EntityTippedArrow.java @@ -142,6 +142,25 @@ } } + // CraftBukkit start accessor methods + public void refreshEffects() { + this.getEntityData().set(EntityTippedArrow.ID_EFFECT_COLOR, PotionUtil.getColor((Collection) PotionUtil.getAllEffects(this.potion, (Collection) this.effects))); + } + + public String getPotionType() { + return BuiltInRegistries.POTION.getKey(this.potion).toString(); + } + + public void setPotionType(String string) { + this.potion = BuiltInRegistries.POTION.get(new net.minecraft.resources.MinecraftKey(string)); + this.getEntityData().set(EntityTippedArrow.ID_EFFECT_COLOR, PotionUtil.getColor((Collection) PotionUtil.getAllEffects(this.potion, (Collection) this.effects))); + } + + public boolean isTipped() { + return !(this.effects.isEmpty() && this.potion == Potions.EMPTY); + } + // CraftBukkit end + public int getColor() { return (Integer) this.entityData.get(EntityTippedArrow.ID_EFFECT_COLOR); } @@ -212,7 +231,7 @@ mobeffect = (MobEffect) iterator.next(); entityliving.addEffect(new MobEffect(mobeffect.getEffect(), Math.max(mobeffect.mapDuration((i) -> { return i / 8; - }), 1), mobeffect.getAmplifier(), mobeffect.isAmbient(), mobeffect.isVisible()), entity); + }), 1), mobeffect.getAmplifier(), mobeffect.isAmbient(), mobeffect.isVisible()), entity, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ARROW); // CraftBukkit } if (!this.effects.isEmpty()) { @@ -220,7 +239,7 @@ while (iterator.hasNext()) { mobeffect = (MobEffect) iterator.next(); - entityliving.addEffect(mobeffect, entity); + entityliving.addEffect(mobeffect, entity, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ARROW); // CraftBukkit } }