2016-03-06 06:46:57 +08:00
|
|
|
--- a/net/minecraft/server/ItemChorusFruit.java
|
|
|
|
+++ b/net/minecraft/server/ItemChorusFruit.java
|
2016-11-17 09:41:03 +08:00
|
|
|
@@ -1,5 +1,11 @@
|
2016-03-06 06:46:57 +08:00
|
|
|
package net.minecraft.server;
|
|
|
|
|
|
|
|
+// CraftBukkit start
|
|
|
|
+import org.bukkit.Location;
|
|
|
|
+import org.bukkit.entity.Player;
|
|
|
|
+import org.bukkit.event.player.PlayerTeleportEvent;
|
|
|
|
+// CraftBukkit end
|
2016-11-17 09:41:03 +08:00
|
|
|
+
|
2016-03-06 06:46:57 +08:00
|
|
|
public class ItemChorusFruit extends ItemFood {
|
|
|
|
|
2018-07-15 08:00:00 +08:00
|
|
|
public ItemChorusFruit(int i, float f, Item.Info item_info) {
|
2016-11-17 09:41:03 +08:00
|
|
|
@@ -19,6 +25,20 @@
|
2018-07-15 08:00:00 +08:00
|
|
|
double d4 = MathHelper.a(entityliving.locY + (double) (entityliving.getRandom().nextInt(16) - 8), 0.0D, (double) (world.aa() - 1));
|
2016-03-06 06:46:57 +08:00
|
|
|
double d5 = entityliving.locZ + (entityliving.getRandom().nextDouble() - 0.5D) * 16.0D;
|
|
|
|
|
|
|
|
+ // CraftBukkit start
|
|
|
|
+ if (entityliving instanceof EntityPlayer) {
|
|
|
|
+ Player player = ((EntityPlayer) entityliving).getBukkitEntity();
|
|
|
|
+ PlayerTeleportEvent teleEvent = new PlayerTeleportEvent(player, player.getLocation(), new Location(player.getWorld(), d3, d4, d5), PlayerTeleportEvent.TeleportCause.CHORUS_FRUIT);
|
|
|
|
+ world.getServer().getPluginManager().callEvent(teleEvent);
|
|
|
|
+ if (teleEvent.isCancelled()) {
|
|
|
|
+ break;
|
|
|
|
+ }
|
2016-03-06 06:57:59 +08:00
|
|
|
+ d3 = teleEvent.getTo().getX();
|
|
|
|
+ d4 = teleEvent.getTo().getY();
|
|
|
|
+ d5 = teleEvent.getTo().getZ();
|
2016-03-06 06:46:57 +08:00
|
|
|
+ }
|
2016-06-09 09:43:49 +08:00
|
|
|
+ // CraftBukkit end
|
2016-03-06 06:46:57 +08:00
|
|
|
+
|
2016-06-09 09:43:49 +08:00
|
|
|
if (entityliving.isPassenger()) {
|
|
|
|
entityliving.stopRiding();
|
|
|
|
}
|