Paper/Spigot-Server-Patches/0321-Turtle-API.patch

158 lines
6.9 KiB
Diff
Raw Normal View History

2019-07-20 12:01:24 +08:00
From de12d9eb27172c21844363f2e66700833e43290f Mon Sep 17 00:00:00 2001
2018-10-11 11:40:49 +08:00
From: BillyGalbreath <Blake.Galbreath@GMail.com>
Date: Sat, 29 Sep 2018 16:08:23 -0500
Subject: [PATCH] Turtle API
diff --git a/src/main/java/net/minecraft/server/EntityTurtle.java b/src/main/java/net/minecraft/server/EntityTurtle.java
2019-07-20 12:01:24 +08:00
index 594cc70def..0bd80e5623 100644
2018-10-11 11:40:49 +08:00
--- a/src/main/java/net/minecraft/server/EntityTurtle.java
+++ b/src/main/java/net/minecraft/server/EntityTurtle.java
@@ -26,51 +26,63 @@ public class EntityTurtle extends EntityAnimal {
2019-05-05 16:33:44 +08:00
this.K = 1.0F;
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final void setHome(BlockPosition pos) { g(pos); } // Paper - OBFHELPER
2018-10-11 11:40:49 +08:00
public void g(BlockPosition blockposition) {
2019-05-05 16:33:44 +08:00
this.datawatcher.set(EntityTurtle.bA, blockposition);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final BlockPosition getHome() { return this.dX(); } // Paper - OBFHELPER
private BlockPosition dX() {
2019-05-05 16:33:44 +08:00
return (BlockPosition) this.datawatcher.get(EntityTurtle.bA);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final void setTravelPos(BlockPosition pos) { this.h(pos); } // Paper - OBFHELPER
2018-10-11 11:40:49 +08:00
private void h(BlockPosition blockposition) {
this.datawatcher.set(EntityTurtle.bD, blockposition);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final BlockPosition getTravelPos() { return this.dY(); } // Paper - OBFHELPER
private BlockPosition dY() {
return (BlockPosition) this.datawatcher.get(EntityTurtle.bD);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final boolean hasEgg() { return this.dV(); } // Paper - OBFHELPER
public boolean dV() {
2019-05-05 16:33:44 +08:00
return (Boolean) this.datawatcher.get(EntityTurtle.bB);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final void setHasEgg(boolean hasEgg) { this.r(hasEgg); } // Paper - OBFHELPER
2019-05-05 16:33:44 +08:00
private void r(boolean flag) {
this.datawatcher.set(EntityTurtle.bB, flag);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final boolean isDigging() { return this.dW(); } // Paper - OBFHELPER
public boolean dW() {
return (Boolean) this.datawatcher.get(EntityTurtle.bC);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final void setDigging(boolean digging) { this.s(digging); } // Paper - OBFHELPER
2019-05-05 16:33:44 +08:00
private void s(boolean flag) {
this.bG = flag ? 1 : 0;
this.datawatcher.set(EntityTurtle.bC, flag);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final boolean isGoingHome() { return this.dZ(); } // Paper - OBFHELPER
private boolean dZ() {
return (Boolean) this.datawatcher.get(EntityTurtle.bE);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final void setGoingHome(boolean goingHome) { this.t(goingHome); } // Paper - OBFHELPER
2019-05-05 16:33:44 +08:00
private void t(boolean flag) {
this.datawatcher.set(EntityTurtle.bE, flag);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final boolean isTravelling() { return this.ee(); } // Paper - OBFHELPER
private boolean ee() {
return (Boolean) this.datawatcher.get(EntityTurtle.bF);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
+ public final void setTravelling(boolean travelling) { this.u(travelling); } // Paper - OBFHELPER
2019-05-05 16:33:44 +08:00
private void u(boolean flag) {
this.datawatcher.set(EntityTurtle.bF, flag);
2018-10-11 11:40:49 +08:00
}
2019-07-20 12:01:24 +08:00
@@ -441,14 +453,17 @@ public class EntityTurtle extends EntityAnimal {
2018-10-11 11:40:49 +08:00
2019-05-05 16:33:44 +08:00
if (!this.g.isInWater() && this.k()) {
if (this.g.bG < 1) {
2019-05-05 16:33:44 +08:00
- this.g.s(true);
+ this.g.setDigging(new com.destroystokyo.paper.event.entity.TurtleStartDiggingEvent((org.bukkit.entity.Turtle) this.g.getBukkitEntity(), MCUtil.toLocation(this.g.world, this.e)).callEvent()); // Paper
} else if (this.g.bG > 200) {
2019-05-05 16:33:44 +08:00
World world = this.g.world;
2018-10-11 11:40:49 +08:00
// CraftBukkit start
2019-05-05 16:33:44 +08:00
- if (!org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(this.g, this.e.up(), (IBlockData) Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, this.g.random.nextInt(4) + 1)).isCancelled()) {
2018-10-11 11:40:49 +08:00
+ // Paper start
2019-05-05 16:33:44 +08:00
+ int eggCount = this.g.random.nextInt(4) + 1;
+ com.destroystokyo.paper.event.entity.TurtleLayEggEvent layEggEvent = new com.destroystokyo.paper.event.entity.TurtleLayEggEvent((org.bukkit.entity.Turtle) this.g.getBukkitEntity(), MCUtil.toLocation(this.g.world, this.e.up()), eggCount);
+ if (layEggEvent.callEvent() && !org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(this.g, this.e.up(), Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, layEggEvent.getEggCount())).isCancelled()) {
2019-07-20 12:01:24 +08:00
world.playSound((EntityHuman) null, blockposition, SoundEffects.ENTITY_TURTLE_LAY_EGG, SoundCategory.BLOCKS, 0.3F, 0.9F + world.random.nextFloat() * 0.2F);
2019-05-05 16:33:44 +08:00
- world.setTypeAndData(this.e.up(), (IBlockData) Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, this.g.random.nextInt(4) + 1), 3);
+ world.setTypeAndData(this.e.up(), (IBlockData) Blocks.TURTLE_EGG.getBlockData().set(BlockTurtleEgg.b, layEggEvent.getEggCount()), 3);
2018-10-11 11:40:49 +08:00
}
// CraftBukkit end
2019-05-05 16:33:44 +08:00
this.g.r(false);
2019-07-20 12:01:24 +08:00
@@ -583,7 +598,7 @@ public class EntityTurtle extends EntityAnimal {
2018-10-11 11:40:49 +08:00
2019-05-05 16:33:44 +08:00
@Override
2018-10-11 11:40:49 +08:00
public boolean a() {
2019-07-20 12:01:24 +08:00
- return this.a.isBaby() ? false : (this.a.dV() ? true : (this.a.getRandom().nextInt(700) != 0 ? false : !this.a.dX().a((IPosition) this.a.getPositionVector(), 64.0D)));
+ return this.a.isBaby() ? false : (this.a.dW() ? true : (this.a.getRandom().nextInt(700) != 0 ? false : !this.a.dY().a((IPosition) this.a.getPositionVector(), 64.0D))) && new com.destroystokyo.paper.event.entity.TurtleGoHomeEvent((org.bukkit.entity.Turtle) this.a.getBukkitEntity()).callEvent(); // Paper
2018-10-11 11:40:49 +08:00
}
2019-05-05 16:33:44 +08:00
@Override
2018-10-11 11:40:49 +08:00
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftTurtle.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftTurtle.java
2019-07-20 12:01:24 +08:00
index 123a2c75ca..8edcf7af65 100644
2018-10-11 11:40:49 +08:00
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftTurtle.java
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftTurtle.java
@@ -1,6 +1,8 @@
package org.bukkit.craftbukkit.entity;
import net.minecraft.server.EntityTurtle;
+import net.minecraft.server.MCUtil;
+import org.bukkit.Location;
import org.bukkit.craftbukkit.CraftServer;
import org.bukkit.entity.EntityType;
import org.bukkit.entity.Turtle;
@@ -25,4 +27,36 @@ public class CraftTurtle extends CraftAnimals implements Turtle {
public EntityType getType() {
return EntityType.TURTLE;
}
+
+ // Paper start
+ @Override
+ public Location getHome() {
+ return MCUtil.toLocation(getHandle().world, getHandle().getHome());
+ }
+
+ @Override
+ public void setHome(Location location) {
+ getHandle().setHome(MCUtil.toBlockPosition(location));
+ }
+
+ @Override
+ public boolean isGoingHome() {
+ return getHandle().isGoingHome();
+ }
+
+ @Override
+ public boolean isDigging() {
+ return getHandle().isDigging();
+ }
+
+ @Override
+ public boolean hasEgg() {
+ return getHandle().hasEgg();
+ }
+
+ @Override
+ public void setHasEgg(boolean hasEgg) {
+ getHandle().setHasEgg(hasEgg);
+ }
+ // Paper end
}
--
2.22.0
2018-10-11 11:40:49 +08:00