diff --git a/Spigot-API-Patches/0004-Player-affects-spawning-API.patch b/Spigot-API-Patches/0004-Player-affects-spawning-API.patch new file mode 100644 index 000000000..12abc6874 --- /dev/null +++ b/Spigot-API-Patches/0004-Player-affects-spawning-API.patch @@ -0,0 +1,41 @@ +From 759908be8944103e051eefd95710f9dfe39b532e Mon Sep 17 00:00:00 2001 +From: Jedediah Smith +Date: Fri, 8 Aug 2014 22:51:26 -0500 +Subject: [PATCH] Player affects spawning API + + +diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java +index b2ad5b7..b2a8e2e 100644 +--- a/src/main/java/org/bukkit/entity/Player.java ++++ b/src/main/java/org/bukkit/entity/Player.java +@@ -1102,6 +1102,28 @@ public interface Player extends HumanEntity, Conversable, CommandSender, Offline + { + throw new UnsupportedOperationException( "Not supported yet." ); + } ++ ++ /** ++ * Get whether the player affects mob spawning ++ * ++ * @return whether or not the player affects ++ * mob spawning. ++ */ ++ public boolean getAffectsSpawning() ++ { ++ throw new UnsupportedOperationException( "Not supported yet." ); ++ } ++ ++ /** ++ * Set whether or not the player affects mob spawning ++ * ++ * @param affects whether or not the player should affect ++ * spawning or not. ++ */ ++ public void setAffectsSpawning(boolean affects) ++ { ++ throw new UnsupportedOperationException( "Not supported yet" ); ++ } + } + + Spigot spigot(); +-- +1.9.1 diff --git a/Spigot-Server-Patches/0032-Player-affects-spawning-API.patch b/Spigot-Server-Patches/0032-Player-affects-spawning-API.patch new file mode 100644 index 000000000..12385f2d1 --- /dev/null +++ b/Spigot-Server-Patches/0032-Player-affects-spawning-API.patch @@ -0,0 +1,130 @@ +From 3648075534d8e6fd4bff464c7481557ed7256fae Mon Sep 17 00:00:00 2001 +From: Jedediah Smith +Date: Fri, 8 Aug 2014 22:51:26 -0500 +Subject: [PATCH] Player affects spawning API + + +diff --git a/src/main/java/net/minecraft/server/EntityHuman.java b/src/main/java/net/minecraft/server/EntityHuman.java +index 08987f2..649e0d3 100644 +--- a/src/main/java/net/minecraft/server/EntityHuman.java ++++ b/src/main/java/net/minecraft/server/EntityHuman.java +@@ -41,6 +41,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen + public boolean sleeping; // protected -> public + public boolean fauxSleeping; + public String spawnWorld = ""; ++ public boolean affectsSpawning = true; // PaperSpigot + + @Override + public CraftHumanEntity getBukkitEntity() { +diff --git a/src/main/java/net/minecraft/server/EntityInsentient.java b/src/main/java/net/minecraft/server/EntityInsentient.java +index d0f7033..99664db 100644 +--- a/src/main/java/net/minecraft/server/EntityInsentient.java ++++ b/src/main/java/net/minecraft/server/EntityInsentient.java +@@ -374,7 +374,7 @@ public abstract class EntityInsentient extends EntityLiving { + if (this.persistent) { + this.aU = 0; + } else { +- EntityHuman entityhuman = this.world.findNearbyPlayer(this, -1.0D); ++ EntityHuman entityhuman = this.world.findNearbyPlayerWhoAffectsSpawning(this, -1.0D); // PaperSpigot + + if (entityhuman != null) { + double d0 = entityhuman.locX - this.locX; +diff --git a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java +index 2276905..26fa93e 100644 +--- a/src/main/java/net/minecraft/server/MobSpawnerAbstract.java ++++ b/src/main/java/net/minecraft/server/MobSpawnerAbstract.java +@@ -46,7 +46,7 @@ public abstract class MobSpawnerAbstract { + } + + public boolean f() { +- return this.a().findNearbyPlayer((double) this.b() + 0.5D, (double) this.c() + 0.5D, (double) this.d() + 0.5D, (double) this.requiredPlayerRange) != null; ++ return this.a().findNearbyPlayerWhoAffectsSpawning((double) this.b() + 0.5D, (double) this.c() + 0.5D, (double) this.d() + 0.5D, (double) this.requiredPlayerRange) != null; // PaperSpigot + } + + public void g() { +diff --git a/src/main/java/net/minecraft/server/SpawnerCreature.java b/src/main/java/net/minecraft/server/SpawnerCreature.java +index 75427b5..7b30362 100644 +--- a/src/main/java/net/minecraft/server/SpawnerCreature.java ++++ b/src/main/java/net/minecraft/server/SpawnerCreature.java +@@ -55,6 +55,10 @@ public final class SpawnerCreature { + + for (i = 0; i < worldserver.players.size(); ++i) { + EntityHuman entityhuman = (EntityHuman) worldserver.players.get(i); ++ // PaperSpigot start - Affects spawning API ++ if (!entityhuman.affectsSpawning) ++ continue; ++ // PaperSpigot end + int k = MathHelper.floor(entityhuman.locX / 16.0D); + + j = MathHelper.floor(entityhuman.locZ / 16.0D); +@@ -154,7 +158,7 @@ public final class SpawnerCreature { + float f1 = (float) i3; + float f2 = (float) j3 + 0.5F; + +- if (worldserver.findNearbyPlayer((double) f, (double) f1, (double) f2, 24.0D) == null) { ++ if (worldserver.findNearbyPlayerWhoAffectsSpawning((double) f, (double) f1, (double) f2, 24.0D) == null) { // PaperSpigot + float f3 = f - (float) chunkcoordinates.x; + float f4 = f1 - (float) chunkcoordinates.y; + float f5 = f2 - (float) chunkcoordinates.z; +diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java +index 717be3b..33c228b 100644 +--- a/src/main/java/net/minecraft/server/World.java ++++ b/src/main/java/net/minecraft/server/World.java +@@ -2847,6 +2847,34 @@ public abstract class World implements IBlockAccess { + return entityhuman; + } + ++ // PaperSpigot start - Find players with the spawning flag ++ public EntityHuman findNearbyPlayerWhoAffectsSpawning(Entity entity, double radius) { ++ return this.findNearbyPlayerWhoAffectsSpawning(entity.locX, entity.locY, entity.locZ, radius); ++ } ++ ++ public EntityHuman findNearbyPlayerWhoAffectsSpawning(double x, double y, double z, double radius) { ++ double nearestRadius = - 1.0D; ++ EntityHuman entityHuman = null; ++ ++ for (int i = 0; i < this.players.size(); ++i) { ++ EntityHuman nearestPlayer = (EntityHuman) this.players.get(i); ++ ++ if (nearestPlayer == null || nearestPlayer.dead || !nearestPlayer.affectsSpawning) { ++ continue; ++ } ++ ++ double distance = nearestPlayer.e(x, y, z); ++ ++ if ((radius < 0.0D || distance < radius * radius) && (nearestRadius == -1.0D || distance < nearestRadius)) { ++ nearestRadius = distance; ++ entityHuman = nearestPlayer; ++ } ++ } ++ ++ return entityHuman; ++ } ++ // PaperSpigot end ++ + public EntityHuman a(String s) { + for (int i = 0; i < this.players.size(); ++i) { + EntityHuman entityhuman = (EntityHuman) this.players.get(i); +diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +index 849b971..ddda795 100644 +--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java ++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +@@ -1425,6 +1425,16 @@ public class CraftPlayer extends CraftHumanEntity implements Player { + + return java.util.Collections.unmodifiableSet( ret ); + } ++ ++ // PaperSpigot start - Add affects spawning API ++ public void setAffectsSpawning(boolean affects) { ++ getHandle().affectsSpawning = affects; ++ } ++ ++ public boolean getAffectsSpawning() { ++ return getHandle().affectsSpawning; ++ } ++ // PaperSpigot end + }; + + public Player.Spigot spigot() +-- +1.9.1