mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
Update to Minecraft 1.10
This commit is contained in:
parent
f53bec077b
commit
9b192b2708
75 changed files with 210 additions and 422 deletions
|
@ -24,7 +24,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- <artifactId>spigot-api</artifactId>
|
- <artifactId>spigot-api</artifactId>
|
||||||
+ <groupId>com.destroystokyo.paper</groupId>
|
+ <groupId>com.destroystokyo.paper</groupId>
|
||||||
+ <artifactId>paper-api</artifactId>
|
+ <artifactId>paper-api</artifactId>
|
||||||
<version>1.9.4-R0.1-SNAPSHOT</version>
|
<version>1.10-R0.1-SNAPSHOT</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
- <name>Spigot-API</name>
|
- <name>Spigot-API</name>
|
||||||
|
|
|
@ -284,7 +284,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
@@ -0,0 +0,0 @@ public class VillageSiege {
|
@@ -0,0 +0,0 @@ public class VillageSiege {
|
||||||
entityzombie.clearVillagerType();
|
entityzombie.setVillagerType(EnumZombieType.NORMAL);
|
||||||
} catch (Exception exception) {
|
} catch (Exception exception) {
|
||||||
exception.printStackTrace();
|
exception.printStackTrace();
|
||||||
+ ServerInternalException.reportInternalException(exception); // Paper
|
+ ServerInternalException.reportInternalException(exception); // Paper
|
||||||
|
|
|
@ -12,13 +12,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return (float) this.getAttributeInstance(GenericAttributes.maxHealth).getValue();
|
return (float) this.getAttributeInstance(GenericAttributes.maxHealth).getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
+ public final int getStuckArrows() { return this.bY(); } // Paper // OBFHELPER
|
+ public final int getStuckArrows() { return this.cb(); } // Paper - OBFHELPER
|
||||||
public final int bY() {
|
public final int cb() {
|
||||||
return ((Integer) this.datawatcher.get(EntityLiving.h)).intValue();
|
return ((Integer) this.datawatcher.get(EntityLiving.h)).intValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
+ public final void setStuckArrows(int arrows) { this.k(arrows); } // Paper - deobfuscation helper
|
+ public final void setStuckArrows(int arrows) { this.f(arrows); } // Paper - OBFHELPER
|
||||||
public final void k(int i) {
|
public final void f(int i) {
|
||||||
this.datawatcher.set(EntityLiving.h, Integer.valueOf(i));
|
this.datawatcher.set(EntityLiving.h, Integer.valueOf(i));
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
|
|
@ -23,13 +23,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntitySlime.java
|
--- a/src/main/java/net/minecraft/server/EntitySlime.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntitySlime.java
|
+++ b/src/main/java/net/minecraft/server/EntitySlime.java
|
||||||
@@ -0,0 +0,0 @@ public class EntitySlime extends EntityInsentient implements IMonster {
|
@@ -0,0 +0,0 @@ public class EntitySlime extends EntityInsentient implements IMonster {
|
||||||
return super.cG();
|
return super.cK();
|
||||||
}
|
}
|
||||||
|
|
||||||
- if (this.random.nextInt(10) == 0 && chunk.a(987234911L).nextInt(10) == 0 && this.locY < 40.0D) {
|
- if (this.random.nextInt(10) == 0 && chunk.a(987234911L).nextInt(10) == 0 && this.locY < 40.0D) {
|
||||||
+ boolean isSlimeChunk = world.paperConfig.allChunksAreSlimeChunks || chunk.a(987234911L).nextInt(10) == 0; // Paper
|
+ boolean isSlimeChunk = world.paperConfig.allChunksAreSlimeChunks || chunk.a(987234911L).nextInt(10) == 0; // Paper
|
||||||
+ if (this.random.nextInt(10) == 0 && isSlimeChunk && this.locY < 40.0D) { // Paper
|
+ if (this.random.nextInt(10) == 0 && isSlimeChunk && this.locY < 40.0D) {
|
||||||
return super.cG();
|
return super.cK();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
--
|
--
|
|
@ -23,9 +23,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityInsentient.java
|
--- a/src/main/java/net/minecraft/server/EntityInsentient.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityInsentient.java
|
+++ b/src/main/java/net/minecraft/server/EntityInsentient.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityInsentient extends EntityLiving {
|
@@ -0,0 +0,0 @@ public abstract class EntityInsentient extends EntityLiving {
|
||||||
private boolean bD;
|
private boolean bE;
|
||||||
private Entity leashHolder;
|
private Entity leashHolder;
|
||||||
private NBTTagCompound bF;
|
private NBTTagCompound bG;
|
||||||
+ public PathfinderGoalFloat goalFloat; // Paper
|
+ public PathfinderGoalFloat goalFloat; // Paper
|
||||||
|
|
||||||
public EntityInsentient(World world) {
|
public EntityInsentient(World world) {
|
||||||
|
|
|
@ -54,5 +54,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private final Arrow.Spigot spigot = new Arrow.Spigot()
|
private final Arrow.Spigot spigot = new Arrow.Spigot()
|
||||||
{
|
{
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -45,5 +45,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if ( org.spigotmc.SpigotConfig.playerShuffle > 0 && MinecraftServer.currentTick % org.spigotmc.SpigotConfig.playerShuffle == 0 )
|
if ( org.spigotmc.SpigotConfig.playerShuffle > 0 && MinecraftServer.currentTick % org.spigotmc.SpigotConfig.playerShuffle == 0 )
|
||||||
{
|
{
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -32,8 +32,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private int neighbors = 0x1 << 12;
|
private int neighbors = 0x1 << 12;
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class Chunk {
|
@@ -0,0 +0,0 @@ public class Chunk {
|
||||||
entity.ac = k;
|
entity.ad = k;
|
||||||
entity.ad = this.locZ;
|
entity.ae = this.locZ;
|
||||||
this.entitySlices[k].add(entity);
|
this.entitySlices[k].add(entity);
|
||||||
+ // Paper start - update count
|
+ // Paper start - update count
|
||||||
+ if (entity instanceof EntityItem) {
|
+ if (entity instanceof EntityItem) {
|
||||||
|
|
|
@ -11,14 +11,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
private static final DataWatcherObject<Boolean> aB = DataWatcher.a(Entity.class, DataWatcherRegistry.h);
|
private static final DataWatcherObject<Boolean> aB = DataWatcher.a(Entity.class, DataWatcherRegistry.h);
|
||||||
private static final DataWatcherObject<Boolean> aC = DataWatcher.a(Entity.class, DataWatcherRegistry.h);
|
private static final DataWatcherObject<Boolean> aC = DataWatcher.a(Entity.class, DataWatcherRegistry.h);
|
||||||
public boolean aa;
|
private static final DataWatcherObject<Boolean> aD = DataWatcher.a(Entity.class, DataWatcherRegistry.h);
|
||||||
- public int ab;
|
- public boolean ab;
|
||||||
- public int ac;
|
- public int ac;
|
||||||
- public int ad;
|
- public int ad;
|
||||||
+ public int ab;public int getChunkX() { return ab; } // Paper
|
- public int ae;
|
||||||
+ public int ac;public int getChunkY() { return ac; } // Paper
|
+ public boolean ab; public boolean isAddedToChunk() { return ab; } // Paper - OBFHELPER
|
||||||
+ public int ad;public int getChunkZ() { return ad; } // Paper
|
+ public int ac; public int getChunkX() { return ac; } // Paper - OBFHELPER
|
||||||
public boolean ah;
|
+ public int ad; public int getChunkY() { return ad; } // Paper - OBFHELPER
|
||||||
|
+ public int ae; public int getChunkZ() { return ae; } // Paper - OBFHELPER
|
||||||
|
public boolean ai;
|
||||||
public boolean impulse;
|
public boolean impulse;
|
||||||
public int portalCooldown;
|
public int portalCooldown;
|
||||||
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
||||||
|
@ -52,22 +54,23 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public final List<Entity> j = Lists.newArrayList();
|
public final List<Entity> j = Lists.newArrayList();
|
||||||
protected final IntHashMap<Entity> entitiesById = new IntHashMap();
|
protected final IntHashMap<Entity> entitiesById = new IntHashMap();
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
||||||
|
this.entityList.removeAll(this.f);
|
||||||
|
|
||||||
int j;
|
int j;
|
||||||
|
+ // Paper start - Set based removal lists
|
||||||
|
+ for (Entity e : this.f) {
|
||||||
|
+ j = e.getChunkZ();
|
||||||
|
+ int k = e.getChunkX();
|
||||||
|
|
||||||
- for (i = 0; i < this.f.size(); ++i) {
|
- for (i = 0; i < this.f.size(); ++i) {
|
||||||
- entity = (Entity) this.f.get(i);
|
- entity = (Entity) this.f.get(i);
|
||||||
- int k = entity.ab;
|
- int k = entity.ac;
|
||||||
+ // Paper start - Set based removal lists
|
-
|
||||||
+ for (Entity e : this.f) {
|
- j = entity.ae;
|
||||||
+ j = e.getChunkX();
|
- if (entity.ab && this.isChunkLoaded(k, j, true)) {
|
||||||
+ int k = e.getChunkZ();
|
|
||||||
|
|
||||||
- j = entity.ad;
|
|
||||||
- if (entity.aa && this.isChunkLoaded(k, j, true)) {
|
|
||||||
- this.getChunkAt(k, j).b(entity);
|
- this.getChunkAt(k, j).b(entity);
|
||||||
+ if (e.aa && this.isChunkLoaded(j, k, true)) {
|
+ if (e.isAddedToChunk() && this.isChunkLoaded(k, j, true)) {
|
||||||
+ this.getChunkAt(j, k).b(e);
|
+ this.getChunkAt(k, j).b(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,71 +0,0 @@
|
||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Zach Brown <1254957+zachbr@users.noreply.github.com>
|
|
||||||
Date: Fri, 22 Apr 2016 20:34:21 -0500
|
|
||||||
Subject: [PATCH] Check entity count additions and mark entities removed
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/Chunk.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
|
||||||
@@ -0,0 +0,0 @@ public class Chunk {
|
|
||||||
k = this.entitySlices.length - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ // Paper start - Try to catch plugins doing indecent things
|
|
||||||
+ boolean ignoreAdd = false;
|
|
||||||
+ if (entity.aa && entity.getChunkX() == this.locX && entity.getChunkY() == k && entity.getChunkZ() == this.locZ) {
|
|
||||||
+ String chunkName = entity.getWorld().getWorld().getName() + ":" + entity.getChunkX() + "," + entity.getChunkY() + "," + entity.getChunkZ();
|
|
||||||
+ if (this.entitySlices[k].contains(entity)) {
|
|
||||||
+ new Throwable("Double Chunk Add to: " + chunkName).printStackTrace();
|
|
||||||
+ ignoreAdd = true;
|
|
||||||
+ } else {
|
|
||||||
+ boolean found = false;
|
|
||||||
+ for (int i1 = 0; i1 < this.entitySlices.length; i1++) {
|
|
||||||
+ if (this.entitySlices[i1].contains(entity)) {
|
|
||||||
+ new Throwable("Entity was found in another slice of this chunk, tried: " + k + ", was in: " + chunkName).printStackTrace();
|
|
||||||
+ found = true;
|
|
||||||
+ ignoreAdd = true;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ if (!found) {
|
|
||||||
+ new Throwable("Improperly detected double chunk add. Was not actually in this chunk.").printStackTrace();
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
+
|
|
||||||
entity.aa = true;
|
|
||||||
entity.ab = this.locX;
|
|
||||||
entity.ac = k;
|
|
||||||
entity.ad = this.locZ;
|
|
||||||
this.entitySlices[k].add(entity);
|
|
||||||
// Paper start - update count
|
|
||||||
+ if (ignoreAdd) return;
|
|
||||||
if (entity instanceof EntityItem) {
|
|
||||||
itemCounts[k]++;
|
|
||||||
} else if (entity instanceof IInventory) {
|
|
||||||
@@ -0,0 +0,0 @@ public class Chunk {
|
|
||||||
} else if (entity instanceof IInventory) {
|
|
||||||
inventoryEntityCounts[i]--;
|
|
||||||
}
|
|
||||||
+ entity.aa = false; // You aren't added to chunk anymore
|
|
||||||
// Paper end
|
|
||||||
// Spigot start - decrement creature type count
|
|
||||||
// Keep this synced up with World.a(Class)
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/World.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/World.java
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
|
||||||
}
|
|
||||||
|
|
||||||
int k = MathHelper.floor(entity.locX / 16.0D);
|
|
||||||
- int l = MathHelper.floor(entity.locY / 16.0D);
|
|
||||||
+ int l = Math.min(15, Math.max(0, MathHelper.floor(entity.locY / 16.0D))); // Paper - stay consistent with chunk add/remove behavior
|
|
||||||
int i1 = MathHelper.floor(entity.locZ / 16.0D);
|
|
||||||
|
|
||||||
if (!entity.aa || entity.ab != k || entity.ac != l || entity.ad != i1) {
|
|
||||||
--
|
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/WorldNBTStorage.java
|
--- a/src/main/java/net/minecraft/server/WorldNBTStorage.java
|
||||||
+++ b/src/main/java/net/minecraft/server/WorldNBTStorage.java
|
+++ b/src/main/java/net/minecraft/server/WorldNBTStorage.java
|
||||||
@@ -0,0 +0,0 @@ public class WorldNBTStorage implements IDataManager, IPlayerFileData {
|
@@ -0,0 +0,0 @@ public class WorldNBTStorage implements IDataManager, IPlayerFileData {
|
||||||
File file = new File(this.playerDir, entityhuman.bd() + ".dat");
|
File file = new File(this.playerDir, entityhuman.bf() + ".dat");
|
||||||
// Spigot Start
|
// Spigot Start
|
||||||
boolean usingWrongFile = false;
|
boolean usingWrongFile = false;
|
||||||
- if ( !file.exists() )
|
- if ( !file.exists() )
|
||||||
|
|
|
@ -57,12 +57,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ private ConcurrentLinkedQueue<QueuedChunk> queue = new ConcurrentLinkedQueue<>(); // Paper - Chunk queue improvements
|
+ private ConcurrentLinkedQueue<QueuedChunk> queue = new ConcurrentLinkedQueue<>(); // Paper - Chunk queue improvements
|
||||||
+ private final Object lock = new Object(); // Paper - Chunk queue improvements
|
+ private final Object lock = new Object(); // Paper - Chunk queue improvements
|
||||||
private static final Logger a = LogManager.getLogger();
|
private static final Logger a = LogManager.getLogger();
|
||||||
private Map<ChunkCoordIntPair, NBTTagCompound> b = new ConcurrentHashMap();
|
private final Map<ChunkCoordIntPair, NBTTagCompound> b = new ConcurrentHashMap();
|
||||||
- private Set<ChunkCoordIntPair> c = Collections.newSetFromMap(new ConcurrentHashMap());
|
- private final Set<ChunkCoordIntPair> c = Collections.newSetFromMap(new ConcurrentHashMap());
|
||||||
+ //private Set<ChunkCoordIntPair> c = Collections.newSetFromMap(new ConcurrentHashMap()); // Paper - Chunk queue improvements
|
+ //private final Set<ChunkCoordIntPair> c = Collections.newSetFromMap(new ConcurrentHashMap()); // Paper - Chunk queue improvements
|
||||||
private final File d;
|
private final File d;
|
||||||
private final DataConverterManager e;
|
private final DataConverterManager e;
|
||||||
private boolean f = false;
|
private boolean f;
|
||||||
@@ -0,0 +0,0 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver {
|
@@ -0,0 +0,0 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver {
|
||||||
public boolean chunkExists(World world, int i, int j) {
|
public boolean chunkExists(World world, int i, int j) {
|
||||||
ChunkCoordIntPair chunkcoordintpair = new ChunkCoordIntPair(i, j);
|
ChunkCoordIntPair chunkcoordintpair = new ChunkCoordIntPair(i, j);
|
||||||
|
|
|
@ -4,19 +4,6 @@ Date: Sat, 4 Apr 2015 23:17:52 -0400
|
||||||
Subject: [PATCH] Complete resource pack API
|
Subject: [PATCH] Complete resource pack API
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/PacketPlayInResourcePackStatus.java b/src/main/java/net/minecraft/server/PacketPlayInResourcePackStatus.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/PacketPlayInResourcePackStatus.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/PacketPlayInResourcePackStatus.java
|
|
||||||
@@ -0,0 +0,0 @@ import java.io.IOException;
|
|
||||||
|
|
||||||
public class PacketPlayInResourcePackStatus implements Packet<PacketListenerPlayIn> {
|
|
||||||
|
|
||||||
- private String a;
|
|
||||||
+ public String a; // Paper - make public
|
|
||||||
public PacketPlayInResourcePackStatus.EnumResourcePackStatus status;
|
|
||||||
|
|
||||||
public PacketPlayInResourcePackStatus() {}
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java
|
diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/PlayerConnection.java
|
--- a/src/main/java/net/minecraft/server/PlayerConnection.java
|
||||||
|
@ -30,8 +17,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ // Paper start
|
+ // Paper start
|
||||||
+ PlayerConnectionUtils.ensureMainThread(packetplayinresourcepackstatus, this, this.player.x());
|
+ PlayerConnectionUtils.ensureMainThread(packetplayinresourcepackstatus, this, this.player.x());
|
||||||
+ final PlayerResourcePackStatusEvent.Status status = PlayerResourcePackStatusEvent.Status.values()[packetplayinresourcepackstatus.status.ordinal()];
|
+ final PlayerResourcePackStatusEvent.Status status = PlayerResourcePackStatusEvent.Status.values()[packetplayinresourcepackstatus.status.ordinal()];
|
||||||
+ this.getPlayer().setResourcePackStatus(status, packetplayinresourcepackstatus.a);
|
+ this.getPlayer().setResourcePackStatus(status);
|
||||||
+ this.server.getPluginManager().callEvent(new PlayerResourcePackStatusEvent(getPlayer(), status, packetplayinresourcepackstatus.a));
|
+ this.server.getPluginManager().callEvent(new PlayerResourcePackStatusEvent(getPlayer(), status));
|
||||||
+ // paper end
|
+ // paper end
|
||||||
}
|
}
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
|
@ -77,9 +64,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ return this.resourcePackStatus == org.bukkit.event.player.PlayerResourcePackStatusEvent.Status.SUCCESSFULLY_LOADED;
|
+ return this.resourcePackStatus == org.bukkit.event.player.PlayerResourcePackStatusEvent.Status.SUCCESSFULLY_LOADED;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public void setResourcePackStatus(org.bukkit.event.player.PlayerResourcePackStatusEvent.Status status, String hash) {
|
+ public void setResourcePackStatus(org.bukkit.event.player.PlayerResourcePackStatusEvent.Status status) {
|
||||||
+ this.resourcePackStatus = status;
|
+ this.resourcePackStatus = status;
|
||||||
+ this.resourcePackHash = hash;
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
// Spigot start
|
// Spigot start
|
||||||
|
|
|
@ -41,14 +41,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/World.java
|
--- a/src/main/java/net/minecraft/server/World.java
|
||||||
+++ b/src/main/java/net/minecraft/server/World.java
|
+++ b/src/main/java/net/minecraft/server/World.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
||||||
BlockPosition blockposition = this.getSpawn();
|
|
||||||
int k = i * 16 + 8 - blockposition.getX();
|
int k = i * 16 + 8 - blockposition.getX();
|
||||||
int l = j * 16 + 8 - blockposition.getZ();
|
int l = j * 16 + 8 - blockposition.getZ();
|
||||||
- short short0 = 128;
|
boolean flag = true;
|
||||||
+ short short0 = paperConfig.keepLoadedRange; // Paper
|
+ short keepLoadedRange = paperConfig.keepLoadedRange; // Paper
|
||||||
|
|
||||||
return k >= -short0 && k <= short0 && l >= -short0 && l <= short0 && this.keepSpawnInMemory; // CraftBukkit - Added 'this.keepSpawnInMemory'
|
- return k >= -128 && k <= 128 && l >= -128 && l <= 128 && this.keepSpawnInMemory; // CraftBukkit - Added 'this.keepSpawnInMemory'
|
||||||
|
+ return k >= -keepLoadedRange && k <= keepLoadedRange && l >= -keepLoadedRange && l <= keepLoadedRange && this.keepSpawnInMemory; // CraftBukkit - Added 'this.keepSpawnInMemory' // Paper - Re-add range var
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void a(Packet<?> packet) {
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
|
|
|
@ -29,10 +29,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityArrow.java
|
+++ b/src/main/java/net/minecraft/server/EntityArrow.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityArrow extends Entity implements IProjectile {
|
@@ -0,0 +0,0 @@ public abstract class EntityArrow extends Entity implements IProjectile {
|
||||||
|
|
||||||
if (block == this.av && i == this.aw) {
|
if (block == this.aw && i == this.ax) {
|
||||||
++this.ax;
|
++this.ay;
|
||||||
- if (this.ax >= world.spigotConfig.arrowDespawnRate) { // Spigot - First int after shooter
|
- if (this.ay >= world.spigotConfig.arrowDespawnRate) { // Spigot - First int after shooter
|
||||||
+ if (this.ax >= (fromPlayer != PickupStatus.DISALLOWED ? world.spigotConfig.arrowDespawnRate : world.paperConfig.nonPlayerArrowDespawnRate)) { // Spigot - First int after shooter // Paper
|
+ if (this.ay >= (fromPlayer != PickupStatus.DISALLOWED ? world.spigotConfig.arrowDespawnRate : world.paperConfig.nonPlayerArrowDespawnRate)) { // Spigot - First int after shooter // Paper
|
||||||
this.die();
|
this.die();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -19,5 +19,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (0 == this.h) {
|
if (0 == this.h) {
|
||||||
this.h = this.i + 10;
|
this.h = this.i + 10;
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -29,9 +29,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private static final UUID b = UUID.fromString("B9766B59-9566-4402-BC1F-2EE2A276D836");
|
private static final UUID b = UUID.fromString("B9766B59-9566-4402-BC1F-2EE2A276D836");
|
||||||
- private static final AttributeModifier c = new AttributeModifier(EntityZombie.b, "Baby speed boost", 0.5D, 1);
|
- private static final AttributeModifier c = new AttributeModifier(EntityZombie.b, "Baby speed boost", 0.5D, 1);
|
||||||
+ private final AttributeModifier c = new AttributeModifier(EntityZombie.b, "Baby speed boost", world.paperConfig.babyZombieMovementSpeed, 1); // Paper - Remove static - Make baby speed configurable
|
+ private final AttributeModifier c = new AttributeModifier(EntityZombie.b, "Baby speed boost", world.paperConfig.babyZombieMovementSpeed, 1); // Paper - Remove static - Make baby speed configurable
|
||||||
private static final DataWatcherObject<Boolean> bw = DataWatcher.a(EntityZombie.class, DataWatcherRegistry.h);
|
private static final DataWatcherObject<Boolean> bx = DataWatcher.a(EntityZombie.class, DataWatcherRegistry.h);
|
||||||
private static final DataWatcherObject<Integer> bx = DataWatcher.a(EntityZombie.class, DataWatcherRegistry.b);
|
private static final DataWatcherObject<Integer> by = DataWatcher.a(EntityZombie.class, DataWatcherRegistry.b);
|
||||||
private static final DataWatcherObject<Boolean> by = DataWatcher.a(EntityZombie.class, DataWatcherRegistry.h);
|
private static final DataWatcherObject<Boolean> bz = DataWatcher.a(EntityZombie.class, DataWatcherRegistry.h);
|
||||||
@@ -0,0 +0,0 @@ public class EntityZombie extends EntityMonster {
|
@@ -0,0 +0,0 @@ public class EntityZombie extends EntityMonster {
|
||||||
if (this.world != null && !this.world.isClientSide) {
|
if (this.world != null && !this.world.isClientSide) {
|
||||||
AttributeInstance attributeinstance = this.getAttributeInstance(GenericAttributes.MOVEMENT_SPEED);
|
AttributeInstance attributeinstance = this.getAttributeInstance(GenericAttributes.MOVEMENT_SPEED);
|
||||||
|
|
|
@ -38,7 +38,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
@Nullable
|
@Nullable
|
||||||
public Entity c(int i) {
|
public Entity c(int i) {
|
||||||
//this.ck = true; // CraftBukkit - Moved down and into PlayerList#changeDimension
|
// this.worldChangeInvuln = true; // CraftBukkit - Moved down and into PlayerList#changeDimension
|
||||||
@@ -0,0 +0,0 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
|
@@ -0,0 +0,0 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
|
||||||
this.world.kill(this);
|
this.world.kill(this);
|
||||||
if (!this.viewingCredits) {
|
if (!this.viewingCredits) {
|
||||||
|
|
|
@ -26,12 +26,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityFishingHook.java
|
--- a/src/main/java/net/minecraft/server/EntityFishingHook.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityFishingHook.java
|
+++ b/src/main/java/net/minecraft/server/EntityFishingHook.java
|
||||||
@@ -0,0 +0,0 @@ public class EntityFishingHook extends Entity {
|
@@ -0,0 +0,0 @@ public class EntityFishingHook extends Entity {
|
||||||
this.ax = MathHelper.nextInt(this.random, 20, 80);
|
this.aw = MathHelper.nextInt(this.random, 20, 80);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
- this.aw = MathHelper.nextInt(this.random, 100, 900);
|
- this.av = MathHelper.nextInt(this.random, 100, 900);
|
||||||
+ this.aw = MathHelper.nextInt(this.random, world.paperConfig.fishingMinTicks, world.paperConfig.fishingMaxTicks); // Paper - Configurable fishing time range
|
+ this.av = MathHelper.nextInt(this.random, world.paperConfig.fishingMinTicks, world.paperConfig.fishingMaxTicks); // Paper - Configurable fishing time range
|
||||||
this.aw -= EnchantmentManager.g(this.owner) * 20 * 5;
|
this.av -= EnchantmentManager.g(this.owner) * 20 * 5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
--
|
--
|
|
@ -28,10 +28,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public class EntitySquid extends EntityWaterAnimal {
|
@@ -0,0 +0,0 @@ public class EntitySquid extends EntityWaterAnimal {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean cG() {
|
public boolean cK() {
|
||||||
- return this.locY > 45.0D && this.locY < (double) this.world.K() && super.cG();
|
- return this.locY > 45.0D && this.locY < (double) this.world.K() && super.cK();
|
||||||
+ // Paper - Configurable squid spawn height range
|
+ // Paper - Configurable squid spawn height range
|
||||||
+ return this.locY > world.paperConfig.squidMinSpawnHeight && this.locY < world.paperConfig.squidMaxSpawnHeight && super.cG();
|
+ return this.locY > world.paperConfig.squidMinSpawnHeight && this.locY < world.paperConfig.squidMaxSpawnHeight && super.cK();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void b(float f, float f1, float f2) {
|
public void b(float f, float f1, float f2) {
|
||||||
|
|
|
@ -36,7 +36,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
public void U() {
|
public void U() {
|
||||||
this.world.methodProfiler.a("entityBaseTick");
|
this.world.methodProfiler.a("entityBaseTick");
|
||||||
if (this.isPassenger() && this.bz().dead) {
|
if (this.isPassenger() && this.bB().dead) {
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
this.fallDistance *= 0.5F;
|
this.fallDistance *= 0.5F;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityLiving.java
|
--- a/src/main/java/net/minecraft/server/EntityLiving.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityLiving.java
|
+++ b/src/main/java/net/minecraft/server/EntityLiving.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
||||||
ItemStack itemstack = (craftItem.equals(event.getItem())) ? this.bn.a(this.world, this) : CraftItemStack.asNMSCopy(event.getItem()).a(world, this);
|
ItemStack itemstack = (craftItem.equals(event.getItem())) ? this.bo.a(this.world, this) : CraftItemStack.asNMSCopy(event.getItem()).a(world, this);
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
|
|
||||||
+ // Paper start - save the default replacement item and change it if necessary
|
+ // Paper start - save the default replacement item and change it if necessary
|
||||||
|
@ -23,14 +23,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
itemstack = null;
|
itemstack = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.a(this.cu(), itemstack);
|
this.a(this.cy(), itemstack);
|
||||||
this.cA();
|
this.cE();
|
||||||
+
|
+
|
||||||
+ // Paper start - if the replacement is anything but the default, update the client inventory
|
+ // Paper start - if the replacement is anything but the default, update the client inventory
|
||||||
+ if (this instanceof EntityPlayer && !com.google.common.base.Objects.equal(defaultReplacement, itemstack)) {
|
+ if (this instanceof EntityPlayer && !com.google.common.base.Objects.equal(defaultReplacement, itemstack)) {
|
||||||
+ ((EntityPlayer) this).getBukkitEntity().updateInventory();
|
+ ((EntityPlayer) this).getBukkitEntity().updateInventory();
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,7 +33,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Entity entity = (Entity) iterator.next();
|
Entity entity = (Entity) iterator.next();
|
||||||
+ if (!entity.world.paperConfig.nonPlayerEntitiesOnScoreboards && !(entity instanceof EntityHuman)) { continue; } // Paper
|
+ if (!entity.world.paperConfig.nonPlayerEntitiesOnScoreboards && !(entity instanceof EntityHuman)) { continue; } // Paper
|
||||||
String s2 = e(minecraftserver, icommandlistener, entity.bd());
|
String s2 = e(minecraftserver, icommandlistener, entity.bf());
|
||||||
|
|
||||||
if (scoreboard.addPlayerToTeam(s2, s)) {
|
if (scoreboard.addPlayerToTeam(s2, s)) {
|
||||||
diff --git a/src/main/java/net/minecraft/server/Entity.java b/src/main/java/net/minecraft/server/Entity.java
|
diff --git a/src/main/java/net/minecraft/server/Entity.java b/src/main/java/net/minecraft/server/Entity.java
|
||||||
|
@ -43,9 +43,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public ScoreboardTeamBase aO() {
|
public ScoreboardTeamBase aQ() {
|
||||||
+ if (!this.world.paperConfig.nonPlayerEntitiesOnScoreboards && !(this instanceof EntityHuman)) { return null; } // Paper
|
+ if (!this.world.paperConfig.nonPlayerEntitiesOnScoreboards && !(this instanceof EntityHuman)) { return null; } // Paper
|
||||||
return this.world.getScoreboard().getPlayerTeam(this.bd());
|
return this.world.getScoreboard().getPlayerTeam(this.bf());
|
||||||
}
|
}
|
||||||
|
|
||||||
--
|
--
|
|
@ -44,7 +44,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ if (knockbackCancelled) this.world.broadcastEntityEffect(this, (byte) 2); // Paper - Disable explosion knockback
|
+ if (knockbackCancelled) this.world.broadcastEntityEffect(this, (byte) 2); // Paper - Disable explosion knockback
|
||||||
+
|
+
|
||||||
if (this.getHealth() <= 0.0F) {
|
if (this.getHealth() <= 0.0F) {
|
||||||
SoundEffect soundeffect = this.bT();
|
SoundEffect soundeffect = this.bW();
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java
|
diff --git a/src/main/java/net/minecraft/server/Explosion.java b/src/main/java/net/minecraft/server/Explosion.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
@ -63,8 +63,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (entity instanceof EntityHuman) {
|
if (entity instanceof EntityHuman) {
|
||||||
EntityHuman entityhuman = (EntityHuman) entity;
|
EntityHuman entityhuman = (EntityHuman) entity;
|
||||||
|
|
||||||
- if (!entityhuman.isSpectator() && (!entityhuman.l_() || !entityhuman.abilities.isFlying)) {
|
- if (!entityhuman.isSpectator() && (!entityhuman.z() || !entityhuman.abilities.isFlying)) {
|
||||||
+ if (!entityhuman.isSpectator() && (!entityhuman.l_() && !world.paperConfig.disableExplosionKnockback|| !entityhuman.abilities.isFlying)) { // Paper - Disable explosion knockback
|
+ if (!entityhuman.isSpectator() && (!entityhuman.z() && !world.paperConfig.disableExplosionKnockback || !entityhuman.abilities.isFlying)) { // Paper - Disable explosion knockback
|
||||||
this.k.put(entityhuman, new Vec3D(d8 * d13, d9 * d13, d10 * d13));
|
this.k.put(entityhuman, new Vec3D(d8 * d13, d9 * d13, d10 * d13));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,5 +18,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -109,5 +109,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
neighbor.setNeighborLoaded(-x, -z);
|
neighbor.setNeighborLoaded(-x, -z);
|
||||||
chunk.setNeighborLoaded(x, z);
|
chunk.setNeighborLoaded(x, z);
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -31,5 +31,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
nbttagcompound.setString("Name", scoreboardteam.getName());
|
nbttagcompound.setString("Name", scoreboardteam.getName());
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -12,8 +12,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return this.N;
|
return this.N;
|
||||||
}
|
}
|
||||||
|
|
||||||
+ public boolean shouldStayLoaded(int i, int j) { return c(i, j); } // Paper - OBFHELPER
|
+ public boolean shouldStayLoaded(int i, int j) { return d(i, j); } // Paper - OBFHELPER
|
||||||
public boolean c(int i, int j) {
|
public boolean d(int i, int j) {
|
||||||
BlockPosition blockposition = this.getSpawn();
|
BlockPosition blockposition = this.getSpawn();
|
||||||
int k = i * 16 + 8 - blockposition.getX();
|
int k = i * 16 + 8 - blockposition.getX();
|
||||||
diff --git a/src/main/java/net/minecraft/server/WorldProvider.java b/src/main/java/net/minecraft/server/WorldProvider.java
|
diff --git a/src/main/java/net/minecraft/server/WorldProvider.java b/src/main/java/net/minecraft/server/WorldProvider.java
|
||||||
|
|
|
@ -16,5 +16,5 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+public class TileEntitySkull extends TileEntity /*implements ITickable*/ { // Paper - remove tickable
|
+public class TileEntitySkull extends TileEntity /*implements ITickable*/ { // Paper - remove tickable
|
||||||
|
|
||||||
private int a;
|
private int a;
|
||||||
private int rotation;
|
public int rotation;
|
||||||
--
|
--
|
|
@ -28,8 +28,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
--- a/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
+++ b/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
||||||
@@ -0,0 +0,0 @@ public class EntityFallingBlock extends Entity {
|
@@ -0,0 +0,0 @@ public class EntityFallingBlock extends Entity {
|
||||||
|
}
|
||||||
|
|
||||||
this.motY -= 0.03999999910593033D;
|
|
||||||
this.move(this.motX, this.motY, this.motZ);
|
this.move(this.motX, this.motY, this.motZ);
|
||||||
+
|
+
|
||||||
+ // Paper start - Configurable EntityFallingBlock height nerf
|
+ // Paper start - Configurable EntityFallingBlock height nerf
|
||||||
|
@ -50,8 +50,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityTNTPrimed.java
|
--- a/src/main/java/net/minecraft/server/EntityTNTPrimed.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityTNTPrimed.java
|
+++ b/src/main/java/net/minecraft/server/EntityTNTPrimed.java
|
||||||
@@ -0,0 +0,0 @@ public class EntityTNTPrimed extends Entity {
|
@@ -0,0 +0,0 @@ public class EntityTNTPrimed extends Entity {
|
||||||
this.lastZ = this.locZ;
|
}
|
||||||
this.motY -= 0.03999999910593033D;
|
|
||||||
this.move(this.motX, this.motY, this.motZ);
|
this.move(this.motX, this.motY, this.motZ);
|
||||||
+
|
+
|
||||||
+ // Paper start - Configurable TNT entity height nerf
|
+ // Paper start - Configurable TNT entity height nerf
|
||||||
|
|
|
@ -42,5 +42,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -44,9 +44,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being loaded");
|
CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being loaded");
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
|
|
||||||
public void at() {}
|
protected abstract void b(NBTTagCompound nbttagcompound);
|
||||||
|
|
||||||
+ protected NBTTagList createList(double... adouble) { return a(adouble); } // Paper // OBFHELPER
|
+ protected NBTTagList createList(double... adouble) { return a(adouble); } // Paper - OBFHELPER
|
||||||
protected NBTTagList a(double... adouble) {
|
protected NBTTagList a(double... adouble) {
|
||||||
NBTTagList nbttaglist = new NBTTagList();
|
NBTTagList nbttaglist = new NBTTagList();
|
||||||
double[] adouble1 = adouble;
|
double[] adouble1 = adouble;
|
||||||
|
|
|
@ -99,5 +99,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
}
|
}
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -10,28 +10,28 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
@@ -0,0 +0,0 @@ import javax.annotation.Nullable;
|
@@ -0,0 +0,0 @@ import javax.annotation.Nullable;
|
||||||
|
|
||||||
public abstract class NavigationAbstract {
|
public abstract class NavigationAbstract {
|
||||||
|
|
||||||
private static int f = 20;
|
|
||||||
- protected EntityInsentient a;
|
- protected EntityInsentient a;
|
||||||
+ protected EntityInsentient a;public Entity getEntity() { return a; } // Paper
|
+ protected EntityInsentient a; public Entity getEntity() { return a; } // Paper - OBFHELPER
|
||||||
protected World b;
|
protected World b;
|
||||||
@Nullable
|
@Nullable
|
||||||
protected PathEntity c;
|
protected PathEntity c;
|
||||||
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
||||||
} else if (this.c != null && !this.c.b() && blockposition.equals(this.r)) {
|
} else if (this.c != null && !this.c.b() && blockposition.equals(this.q)) {
|
||||||
return this.c;
|
return this.c;
|
||||||
} else {
|
} else {
|
||||||
+ if (!new com.destroystokyo.paper.event.entity.EntityPathfindEvent(getEntity().getBukkitEntity(), MCUtil.toLocation(getEntity().world, blockposition), null).callEvent()) { return null; } // Paper
|
+ if (!new com.destroystokyo.paper.event.entity.EntityPathfindEvent(getEntity().getBukkitEntity(), MCUtil.toLocation(getEntity().world, blockposition), null).callEvent()) { return null; } // Paper
|
||||||
this.r = blockposition;
|
this.q = blockposition;
|
||||||
float f = this.h();
|
float f = this.h();
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
||||||
if (this.c != null && !this.c.b() && blockposition.equals(this.r)) {
|
if (this.c != null && !this.c.b() && blockposition.equals(this.q)) {
|
||||||
return this.c;
|
return this.c;
|
||||||
} else {
|
} else {
|
||||||
+ if (!new com.destroystokyo.paper.event.entity.EntityPathfindEvent(getEntity().getBukkitEntity(), MCUtil.toLocation(entity.world, blockposition), entity.getBukkitEntity()).callEvent()) { return null; } // Paper
|
+ if (!new com.destroystokyo.paper.event.entity.EntityPathfindEvent(getEntity().getBukkitEntity(), MCUtil.toLocation(entity.world, blockposition), entity.getBukkitEntity()).callEvent()) { return null; } // Paper
|
||||||
this.r = blockposition;
|
this.q = blockposition;
|
||||||
float f = this.h();
|
float f = this.h();
|
||||||
|
|
||||||
--
|
--
|
|
@ -41,5 +41,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
this.foodTickTimer = 0;
|
this.foodTickTimer = 0;
|
||||||
}
|
}
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -39,5 +39,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public RedstoneUpdateInfo(BlockPosition blockposition, long i) {
|
public RedstoneUpdateInfo(BlockPosition blockposition, long i) {
|
||||||
this.a = blockposition;
|
this.a = blockposition;
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -1,33 +0,0 @@
|
||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: chickeneer <emcchickeneer@gmail.com>
|
|
||||||
Date: Wed, 8 Jun 2016 20:39:19 -0400
|
|
||||||
Subject: [PATCH] Fix Potion Equals Bug
|
|
||||||
|
|
||||||
Will be in Spigot 1.10, but getting it in for 1.9 users
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionUtil.java b/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionUtil.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionUtil.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionUtil.java
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftPotionUtil {
|
|
||||||
.build();
|
|
||||||
|
|
||||||
public static String fromBukkit(PotionData data) {
|
|
||||||
+ String type;
|
|
||||||
if (data.isUpgraded()) {
|
|
||||||
- return upgradeable.get(data.getType());
|
|
||||||
+ type = upgradeable.get(data.getType());
|
|
||||||
+ } else if (data.isExtended()) {
|
|
||||||
+ type = extendable.get(data.getType());
|
|
||||||
+ } else {
|
|
||||||
+ type = regular.get(data.getType());
|
|
||||||
}
|
|
||||||
- if (data.isExtended()) {
|
|
||||||
- return extendable.get(data.getType());
|
|
||||||
- }
|
|
||||||
- return regular.get(data.getType());
|
|
||||||
+ return "minecraft:" + type;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static PotionData toBukkit(String type) {
|
|
||||||
--
|
|
|
@ -55,14 +55,14 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/BiomeMesa.java
|
--- a/src/main/java/net/minecraft/server/BiomeMesa.java
|
||||||
+++ b/src/main/java/net/minecraft/server/BiomeMesa.java
|
+++ b/src/main/java/net/minecraft/server/BiomeMesa.java
|
||||||
@@ -0,0 +0,0 @@ public class BiomeMesa extends BiomeBase {
|
@@ -0,0 +0,0 @@ public class BiomeMesa extends BiomeBase {
|
||||||
chunksnapshot.a(l, l1, k, BiomeMesa.a);
|
chunksnapshot.a(l, i2, k, BiomeMesa.a);
|
||||||
}
|
}
|
||||||
|
|
||||||
- if (l1 <= random.nextInt(5)) {
|
- if (i2 <= random.nextInt(5)) {
|
||||||
+ if (l1 <= (world.paperConfig.generateFlatBedrock ? 0 : random.nextInt(5))) { // Paper - Configurable flat bedrock
|
+ if (i2 <= (world.paperConfig.generateFlatBedrock ? 0 : random.nextInt(5))) { // Paper - Configurable flat bedrock
|
||||||
chunksnapshot.a(l, l1, k, BiomeMesa.c);
|
chunksnapshot.a(l, i2, k, BiomeMesa.c);
|
||||||
} else {
|
} else if (l1 < 15) {
|
||||||
IBlockData iblockdata2 = chunksnapshot.a(l, l1, k);
|
IBlockData iblockdata2 = chunksnapshot.a(l, i2, k);
|
||||||
diff --git a/src/main/java/net/minecraft/server/ChunkProviderFlat.java b/src/main/java/net/minecraft/server/ChunkProviderFlat.java
|
diff --git a/src/main/java/net/minecraft/server/ChunkProviderFlat.java b/src/main/java/net/minecraft/server/ChunkProviderFlat.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/ChunkProviderFlat.java
|
--- a/src/main/java/net/minecraft/server/ChunkProviderFlat.java
|
||||||
|
@ -240,8 +240,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
public void recreateStructures(Chunk chunk, int i, int j) {
|
public void recreateStructures(Chunk chunk, int i, int j) {
|
||||||
- this.H.a(this.n, i, j, (ChunkSnapshot) null);
|
- this.I.a(this.n, i, j, (ChunkSnapshot) null);
|
||||||
+ if (this.n.paperConfig.generateFortress) this.H.a(this.n, i, j, (ChunkSnapshot) null); // Paper
|
+ if (this.n.paperConfig.generateFortress) this.I.a(this.n, i, j, (ChunkSnapshot) null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/net/minecraft/server/StructureGenerator.java b/src/main/java/net/minecraft/server/StructureGenerator.java
|
diff --git a/src/main/java/net/minecraft/server/StructureGenerator.java b/src/main/java/net/minecraft/server/StructureGenerator.java
|
||||||
|
|
|
@ -11,7 +11,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ import org.bukkit.inventory.MainHand;
|
@@ -0,0 +0,0 @@ import org.bukkit.inventory.MainHand;
|
||||||
public class EntityPlayer extends EntityHuman implements ICrafting {
|
public class EntityPlayer extends EntityHuman implements ICrafting {
|
||||||
|
|
||||||
private static final Logger bR = LogManager.getLogger();
|
private static final Logger bS = LogManager.getLogger();
|
||||||
- public String locale = "en_US"; // Spigot private -> public
|
- public String locale = "en_US"; // Spigot private -> public
|
||||||
+ public String locale = null; // Spigot private -> public // Paper - default to null
|
+ public String locale = null; // Spigot private -> public // Paper - default to null
|
||||||
public PlayerConnection playerConnection;
|
public PlayerConnection playerConnection;
|
||||||
|
@ -30,9 +30,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ new com.destroystokyo.paper.event.player.PlayerLocaleChangeEvent(this.getBukkitEntity(), oldLocale, this.locale).callEvent();
|
+ new com.destroystokyo.paper.event.player.PlayerLocaleChangeEvent(this.getBukkitEntity(), oldLocale, this.locale).callEvent();
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
this.cg = packetplayinsettings.c();
|
this.ch = packetplayinsettings.c();
|
||||||
this.ch = packetplayinsettings.d();
|
this.ci = packetplayinsettings.d();
|
||||||
this.getDataWatcher().set(EntityPlayer.bq, Byte.valueOf((byte) packetplayinsettings.e()));
|
this.getDataWatcher().set(EntityPlayer.br, Byte.valueOf((byte) packetplayinsettings.e()));
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
||||||
|
|
|
@ -65,7 +65,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+++ b/src/main/java/net/minecraft/server/WorldMap.java
|
+++ b/src/main/java/net/minecraft/server/WorldMap.java
|
||||||
@@ -0,0 +0,0 @@ public class WorldMap extends PersistentBase {
|
@@ -0,0 +0,0 @@ public class WorldMap extends PersistentBase {
|
||||||
public List<WorldMap.WorldMapHumanTracker> h = Lists.newArrayList();
|
public List<WorldMap.WorldMapHumanTracker> h = Lists.newArrayList();
|
||||||
public Map<EntityHuman, WorldMap.WorldMapHumanTracker> j = Maps.newHashMap(); // Spigot
|
public final Map<EntityHuman, WorldMap.WorldMapHumanTracker> j = Maps.newHashMap(); // Spigot
|
||||||
public Map<UUID, MapIcon> decorations = Maps.newLinkedHashMap(); // Spigot
|
public Map<UUID, MapIcon> decorations = Maps.newLinkedHashMap(); // Spigot
|
||||||
+ private org.bukkit.craftbukkit.map.RenderData vanillaRender = new org.bukkit.craftbukkit.map.RenderData(); // Paper
|
+ private org.bukkit.craftbukkit.map.RenderData vanillaRender = new org.bukkit.craftbukkit.map.RenderData(); // Paper
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ // Paper stop
|
+ // Paper stop
|
||||||
public final EntityHuman trackee;
|
public final EntityHuman trackee;
|
||||||
private boolean d = true;
|
private boolean d = true;
|
||||||
private int e = 0;
|
private int e;
|
||||||
@@ -0,0 +0,0 @@ public class WorldMap extends PersistentBase {
|
@@ -0,0 +0,0 @@ public class WorldMap extends PersistentBase {
|
||||||
|
|
||||||
public Packet<?> a(ItemStack itemstack) {
|
public Packet<?> a(ItemStack itemstack) {
|
||||||
|
@ -145,5 +145,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
public RenderData() {
|
public RenderData() {
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -562,7 +562,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
public TileEntityLootable() {}
|
public TileEntityLootable() {}
|
||||||
|
|
||||||
protected boolean d(NBTTagCompound nbttagcompound) {
|
protected boolean c(NBTTagCompound nbttagcompound) {
|
||||||
+ lootableData.loadNbt(nbttagcompound); // Paper
|
+ lootableData.loadNbt(nbttagcompound); // Paper
|
||||||
if (nbttagcompound.hasKeyOfType("LootTable", 8)) {
|
if (nbttagcompound.hasKeyOfType("LootTable", 8)) {
|
||||||
this.m = new MinecraftKey(nbttagcompound.getString("LootTable"));
|
this.m = new MinecraftKey(nbttagcompound.getString("LootTable"));
|
||||||
|
@ -574,7 +574,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean e(NBTTagCompound nbttagcompound) {
|
protected boolean d(NBTTagCompound nbttagcompound) {
|
||||||
+ lootableData.saveNbt(nbttagcompound); // Paper
|
+ lootableData.saveNbt(nbttagcompound); // Paper
|
||||||
if (this.m != null) {
|
if (this.m != null) {
|
||||||
nbttagcompound.setString("LootTable", this.m.toString());
|
nbttagcompound.setString("LootTable", this.m.toString());
|
||||||
|
|
|
@ -29,5 +29,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (System.console() == null && System.getProperty("jline.terminal") == null) {
|
if (System.console() == null && System.getProperty("jline.terminal") == null) {
|
||||||
System.setProperty("jline.terminal", "jline.UnsupportedTerminal");
|
System.setProperty("jline.terminal", "jline.UnsupportedTerminal");
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,6 @@ From: Aikar <aikar@aikar.co>
|
||||||
Date: Mon, 28 Mar 2016 20:55:47 -0400
|
Date: Mon, 28 Mar 2016 20:55:47 -0400
|
||||||
Subject: [PATCH] MC Utils
|
Subject: [PATCH] MC Utils
|
||||||
|
|
||||||
Collection of utils to help reduce NMS diff
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/MCUtil.java b/src/main/java/net/minecraft/server/MCUtil.java
|
diff --git a/src/main/java/net/minecraft/server/MCUtil.java b/src/main/java/net/minecraft/server/MCUtil.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
|
@ -204,8 +203,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
public class NBTTagCompound extends NBTBase {
|
public class NBTTagCompound extends NBTBase {
|
||||||
|
|
||||||
- private Map<String, NBTBase> map = Maps.newHashMap();
|
- private final Map<String, NBTBase> map = Maps.newHashMap();
|
||||||
+ public Map<String, NBTBase> map = Maps.newHashMap(); // Paper
|
+ public final Map<String, NBTBase> map = Maps.newHashMap(); // Paper
|
||||||
|
|
||||||
public NBTTagCompound() {}
|
public NBTTagCompound() {}
|
||||||
|
|
||||||
|
@ -237,5 +236,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
public NBTTagList() {}
|
public NBTTagList() {}
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityEnderDragon.java
|
--- a/src/main/java/net/minecraft/server/EntityEnderDragon.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityEnderDragon.java
|
+++ b/src/main/java/net/minecraft/server/EntityEnderDragon.java
|
||||||
@@ -0,0 +0,0 @@ public class EntityEnderDragon extends EntityInsentient implements IComplex, IMo
|
@@ -0,0 +0,0 @@ public class EntityEnderDragon extends EntityInsentient implements IComplex, IMo
|
||||||
if (this.bG == 1) {
|
if (this.bH == 1) {
|
||||||
// CraftBukkit start - Use relative location for far away sounds
|
// CraftBukkit start - Use relative location for far away sounds
|
||||||
// this.world.a(1028, new BlockPosition(this), 0);
|
// this.world.a(1028, new BlockPosition(this), 0);
|
||||||
- int viewDistance = ((WorldServer) this.world).getServer().getViewDistance() * 16;
|
- int viewDistance = ((WorldServer) this.world).getServer().getViewDistance() * 16;
|
||||||
|
|
|
@ -33,7 +33,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
||||||
+++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
+++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
||||||
@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider {
|
@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider {
|
||||||
public final Set<Long> unloadQueue = Sets.newHashSet(); // PAIL: private -> public
|
public final Set<Long> unloadQueue = Sets.newHashSet();
|
||||||
public final ChunkGenerator chunkGenerator;
|
public final ChunkGenerator chunkGenerator;
|
||||||
private final IChunkLoader chunkLoader;
|
private final IChunkLoader chunkLoader;
|
||||||
- public final Long2ObjectMap<Chunk> chunks = new Long2ObjectOpenHashMap(8192);
|
- public final Long2ObjectMap<Chunk> chunks = new Long2ObjectOpenHashMap(8192);
|
||||||
|
|
|
@ -65,5 +65,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
PathEntity pathentity = this.a(entity);
|
PathEntity pathentity = this.a(entity);
|
||||||
|
|
||||||
- return pathentity != null ? this.a(pathentity, d0) : false;
|
- return pathentity != null && this.a(pathentity, d0);
|
||||||
+ if (pathentity != null && this.a(pathentity, d0)) {
|
+ if (pathentity != null && this.a(pathentity, d0)) {
|
||||||
+ this.lastFailure = 0;
|
+ this.lastFailure = 0;
|
||||||
+ this.pathfindFailures = 0;
|
+ this.pathfindFailures = 0;
|
||||||
|
|
|
@ -36,7 +36,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public class TileEntityChest extends TileEntityLootable implements ITickable, II
|
@@ -0,0 +0,0 @@ public class TileEntityChest extends TileEntityLootable implements ITickable, II
|
||||||
}
|
}
|
||||||
|
|
||||||
public void c() {
|
public void E_() {
|
||||||
+ // Paper - Disable all of this, just in case this does get ticked
|
+ // Paper - Disable all of this, just in case this does get ticked
|
||||||
+ /*
|
+ /*
|
||||||
this.m();
|
this.m();
|
||||||
|
@ -135,7 +135,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
public TileEntityEnderChest() {}
|
public TileEntityEnderChest() {}
|
||||||
|
|
||||||
public void c() {
|
public void E_() {
|
||||||
+ // Paper start - Disable all of this, just in case this does get ticked
|
+ // Paper start - Disable all of this, just in case this does get ticked
|
||||||
+ /*
|
+ /*
|
||||||
if (++this.h % 20 * 4 == 0) {
|
if (++this.h % 20 * 4 == 0) {
|
||||||
|
@ -162,7 +162,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ double d1 = (double) this.getPosition().getX() + 0.5D;
|
+ double d1 = (double) this.getPosition().getX() + 0.5D;
|
||||||
+ double d0 = (double) this.getPosition().getZ() + 0.5D;
|
+ double d0 = (double) this.getPosition().getZ() + 0.5D;
|
||||||
+
|
+
|
||||||
+ this.world.a((EntityHuman) null, d1, (double) this.getPosition().getY() + 0.5D, d0, SoundEffects.aM, SoundCategory.BLOCKS, 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F);
|
+ this.world.a((EntityHuman) null, d1, (double) this.getPosition().getY() + 0.5D, d0, SoundEffects.aN, SoundCategory.BLOCKS, 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F);
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
+
|
+
|
||||||
|
@ -177,7 +177,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ double d0 = (double) this.getPosition().getX() + 0.5D;
|
+ double d0 = (double) this.getPosition().getX() + 0.5D;
|
||||||
+ double d2 = (double) this.getPosition().getZ() + 0.5D;
|
+ double d2 = (double) this.getPosition().getZ() + 0.5D;
|
||||||
+
|
+
|
||||||
+ this.world.a((EntityHuman) null, d0, (double) this.getPosition().getY() + 0.5D, d2, SoundEffects.aL, SoundCategory.BLOCKS, 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F);
|
+ this.world.a((EntityHuman) null, d0, (double) this.getPosition().getY() + 0.5D, d2, SoundEffects.aM, SoundCategory.BLOCKS, 0.5F, this.world.random.nextFloat() * 0.1F + 0.9F);
|
||||||
+ this.a = 0.0F;
|
+ this.a = 0.0F;
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
|
|
@ -96,5 +96,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ // Paper Start - (Meh) Support for vanilla world scoreboard name coloring
|
+ // Paper Start - (Meh) Support for vanilla world scoreboard name coloring
|
||||||
+ String displayName = event.getPlayer().getDisplayName();
|
+ String displayName = event.getPlayer().getDisplayName();
|
||||||
+ if (this.player.getWorld().paperConfig.useVanillaScoreboardColoring) {
|
+ if (this.player.getWorld().paperConfig.useVanillaScoreboardColoring) {
|
||||||
+ displayName = ScoreboardTeam.getPlayerDisplayName(this.player.aO(), player.getDisplayName());
|
+ displayName = ScoreboardTeam.getPlayerDisplayName(this.player.aQ(), player.getDisplayName());
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ s = String.format(event.getFormat(), displayName, event.getMessage());
|
+ s = String.format(event.getFormat(), displayName, event.getMessage());
|
||||||
|
|
|
@ -189,7 +189,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
|
||||||
world.addEntity(entitytntprimed);
|
world.addEntity(entitytntprimed);
|
||||||
world.a((EntityHuman) null, entitytntprimed.locX, entitytntprimed.locY, entitytntprimed.locZ, SoundEffects.gk, SoundCategory.BLOCKS, 1.0F, 1.0F);
|
world.a((EntityHuman) null, entitytntprimed.locX, entitytntprimed.locY, entitytntprimed.locZ, SoundEffects.gz, SoundCategory.BLOCKS, 1.0F, 1.0F);
|
||||||
diff --git a/src/main/java/net/minecraft/server/DispenserRegistry.java b/src/main/java/net/minecraft/server/DispenserRegistry.java
|
diff --git a/src/main/java/net/minecraft/server/DispenserRegistry.java b/src/main/java/net/minecraft/server/DispenserRegistry.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/DispenserRegistry.java
|
--- a/src/main/java/net/minecraft/server/DispenserRegistry.java
|
||||||
|
@ -214,14 +214,14 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean aj() {
|
public boolean ak() {
|
||||||
+ // Paper start - OBFHELPER
|
+ // Paper start - OBFHELPER
|
||||||
+ return this.doWaterMovement();
|
+ return this.doWaterMovement();
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public boolean doWaterMovement() {
|
+ public boolean doWaterMovement() {
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
if (this.bz() instanceof EntityBoat) {
|
if (this.bB() instanceof EntityBoat) {
|
||||||
this.inWater = false;
|
this.inWater = false;
|
||||||
} else if (this.world.a(this.getBoundingBox().grow(0.0D, -0.4000000059604645D, 0.0D).shrink(0.001D), Material.WATER, this)) {
|
} else if (this.world.a(this.getBoundingBox().grow(0.0D, -0.4000000059604645D, 0.0D).shrink(0.001D), Material.WATER, this)) {
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
|
@ -253,7 +253,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean be() {
|
public boolean bg() {
|
||||||
+ // Paper start - OBFHELPER
|
+ // Paper start - OBFHELPER
|
||||||
+ return this.pushedByWater();
|
+ return this.pushedByWater();
|
||||||
+ }
|
+ }
|
||||||
|
@ -268,7 +268,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
--- a/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
+++ b/src/main/java/net/minecraft/server/EntityFallingBlock.java
|
||||||
@@ -0,0 +0,0 @@ public class EntityFallingBlock extends Entity {
|
@@ -0,0 +0,0 @@ public class EntityFallingBlock extends Entity {
|
||||||
public boolean bs() {
|
public boolean bu() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
+
|
+
|
||||||
|
|
|
@ -17,16 +17,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ <groupId>com.destroystokyo.paper</groupId>
|
+ <groupId>com.destroystokyo.paper</groupId>
|
||||||
+ <artifactId>paper</artifactId>
|
+ <artifactId>paper</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<version>1.9.4-R0.1-SNAPSHOT</version>
|
<version>1.10-R0.1-SNAPSHOT</version>
|
||||||
- <name>Spigot</name>
|
- <name>Spigot</name>
|
||||||
- <url>http://www.spigotmc.org</url>
|
- <url>http://www.spigotmc.org</url>
|
||||||
+ <name>Paper</name>
|
+ <name>Paper</name>
|
||||||
+ <url>https://github.com/PaperSpigot/Paper</url>
|
+ <url>https://github.com/PaperMC/Paper</url>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
@@ -0,0 +0,0 @@
|
@@ -0,0 +0,0 @@
|
||||||
<minecraft_version>1_9_R2</minecraft_version>
|
<minecraft_version>1_10_R1</minecraft_version>
|
||||||
<buildtag.prefix>git-Bukkit-</buildtag.prefix>
|
<buildtag.prefix>git-Bukkit-</buildtag.prefix>
|
||||||
<buildtag.suffix></buildtag.suffix>
|
<buildtag.suffix></buildtag.suffix>
|
||||||
- <maven.compiler.source>1.6</maven.compiler.source>
|
- <maven.compiler.source>1.6</maven.compiler.source>
|
||||||
|
|
|
@ -23,7 +23,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/Village.java
|
--- a/src/main/java/net/minecraft/server/Village.java
|
||||||
+++ b/src/main/java/net/minecraft/server/Village.java
|
+++ b/src/main/java/net/minecraft/server/Village.java
|
||||||
@@ -0,0 +0,0 @@ public class Village {
|
@@ -0,0 +0,0 @@ public class Village {
|
||||||
private List<Village.Aggressor> k;
|
private final List<Village.Aggressor> k;
|
||||||
private int l;
|
private int l;
|
||||||
|
|
||||||
- public Village() {
|
- public Village() {
|
||||||
|
@ -31,13 +31,4 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
this.c = BlockPosition.ZERO;
|
this.c = BlockPosition.ZERO;
|
||||||
this.d = BlockPosition.ZERO;
|
this.d = BlockPosition.ZERO;
|
||||||
this.j = new TreeMap();
|
this.j = new TreeMap();
|
||||||
@@ -0,0 +0,0 @@ public class Village {
|
|
||||||
NBTTagCompound nbttagcompound2 = nbttaglist1.get(j);
|
|
||||||
|
|
||||||
if (nbttagcompound2.hasKey("UUID")) {
|
|
||||||
- UserCache usercache = this.a.getMinecraftServer().getUserCache();
|
|
||||||
+ UserCache usercache = MinecraftServer.getServer().getUserCache(); // Paper - Bandaid for world being null
|
|
||||||
GameProfile gameprofile = usercache.a(UUID.fromString(nbttagcompound2.getString("UUID")));
|
|
||||||
|
|
||||||
if (gameprofile != null) {
|
|
||||||
--
|
--
|
|
@ -53,6 +53,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- this.applyExhaustion(0.015F * (float) i * 0.01F);
|
- this.applyExhaustion(0.015F * (float) i * 0.01F);
|
||||||
+ this.applyExhaustion(world.paperConfig.playerSwimmingExhaustion); // Paper - Configurable swimming exhaustion
|
+ this.applyExhaustion(world.paperConfig.playerSwimmingExhaustion); // Paper - Configurable swimming exhaustion
|
||||||
}
|
}
|
||||||
} else if (this.n_()) {
|
} else if (this.m_()) {
|
||||||
if (d1 > 0.0D) {
|
if (d1 > 0.0D) {
|
||||||
--
|
--
|
|
@ -17,7 +17,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
import com.mojang.authlib.GameProfile;
|
import com.mojang.authlib.GameProfile;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityHuman extends EntityLiving {
|
@@ -0,0 +0,0 @@ public abstract class EntityHuman extends EntityLiving {
|
||||||
private final ItemCooldown bV = this.l();
|
private final ItemCooldown bW = this.l();
|
||||||
public EntityFishingHook hookedFish;
|
public EntityFishingHook hookedFish;
|
||||||
|
|
||||||
+ // Paper start - affectsSpawning API
|
+ // Paper start - affectsSpawning API
|
||||||
|
@ -55,8 +55,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+++ b/src/main/java/net/minecraft/server/EntitySilverfish.java
|
+++ b/src/main/java/net/minecraft/server/EntitySilverfish.java
|
||||||
@@ -0,0 +0,0 @@ public class EntitySilverfish extends EntityMonster {
|
@@ -0,0 +0,0 @@ public class EntitySilverfish extends EntityMonster {
|
||||||
|
|
||||||
public boolean cG() {
|
public boolean cK() {
|
||||||
if (super.cG()) {
|
if (super.cK()) {
|
||||||
- EntityHuman entityhuman = this.world.b(this, 5.0D);
|
- EntityHuman entityhuman = this.world.b(this, 5.0D);
|
||||||
+ EntityHuman entityhuman = this.world.findNearbyPlayerNotInCreativeMode(this, 5.0D, EntityHuman.affectsSpawningFilter()); // Paper - affectsSpawning filter
|
+ EntityHuman entityhuman = this.world.findNearbyPlayerNotInCreativeMode(this, 5.0D, EntityHuman.affectsSpawningFilter()); // Paper - affectsSpawning filter
|
||||||
|
|
||||||
|
|
|
@ -45,5 +45,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
return i;
|
return i;
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private void flow(World world, BlockPosition blockposition, IBlockData iblockdata, int i) {
|
private void flow(World world, BlockPosition blockposition, IBlockData iblockdata, int i) {
|
||||||
- if (world.isLoaded(blockposition) && this.h(world, blockposition, iblockdata)) { // CraftBukkit - add isLoaded check
|
- if (world.isLoaded(blockposition) && this.h(world, blockposition, iblockdata)) { // CraftBukkit - add isLoaded check
|
||||||
+ if (/*world.isLoaded(blockposition) &&*/ this.h(world, blockposition, iblockdata)) { // CraftBukkit - add isLoaded check // Paper - Already checked before we get here for isLoaded
|
+ if (/*world.isLoaded(blockposition) &&*/ this.h(world, blockposition, iblockdata)) { // CraftBukkit - add isLoaded check // Paper - Already checked before we get here for isLoaded
|
||||||
if (iblockdata.getBlock() != Blocks.AIR) {
|
if (iblockdata.getMaterial() != Material.AIR) {
|
||||||
if (this.material == Material.LAVA) {
|
if (this.material == Material.LAVA) {
|
||||||
this.fizz(world, blockposition);
|
this.fizz(world, blockposition);
|
||||||
--
|
--
|
|
@ -44,7 +44,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
||||||
((ITickable) tileentity).c();
|
((ITickable) tileentity).E_();
|
||||||
this.methodProfiler.b();
|
this.methodProfiler.b();
|
||||||
} catch (Throwable throwable2) {
|
} catch (Throwable throwable2) {
|
||||||
- crashreport1 = CrashReport.a(throwable2, "Ticking block entity");
|
- crashreport1 = CrashReport.a(throwable2, "Ticking block entity");
|
||||||
|
|
|
@ -9,59 +9,45 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/PlayerConnection.java
|
--- a/src/main/java/net/minecraft/server/PlayerConnection.java
|
||||||
+++ b/src/main/java/net/minecraft/server/PlayerConnection.java
|
+++ b/src/main/java/net/minecraft/server/PlayerConnection.java
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
||||||
ItemStack itemstack;
|
|
||||||
ItemStack itemstack1;
|
|
||||||
|
|
||||||
+ try { // Paper - Reimplement BookEditEvent
|
|
||||||
if ("MC|BEdit".equals(s)) {
|
|
||||||
packetdataserializer = new PacketDataSerializer(Unpooled.wrappedBuffer(packetplayincustompayload.b()));
|
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
|
||||||
if (itemstack1 != null) {
|
|
||||||
if (itemstack.getItem() == Items.WRITABLE_BOOK && itemstack.getItem() == itemstack1.getItem()) {
|
if (itemstack.getItem() == Items.WRITABLE_BOOK && itemstack.getItem() == itemstack1.getItem()) {
|
||||||
itemstack1.a("pages", (NBTBase) itemstack.getTag().getList("pages", 8));
|
itemstack1.a("pages", (NBTBase) itemstack.getTag().getList("pages", 8));
|
||||||
+ CraftEventFactory.handleEditBookEvent(player, itemstack1); // Paper
|
+ CraftEventFactory.handleEditBookEvent(player, itemstack1); // Paper
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} catch (Exception exception) {
|
} catch (Exception exception) {
|
||||||
PlayerConnection.LOGGER.error("Couldn\'t handle book info", exception);
|
PlayerConnection.LOGGER.error("Couldn\'t handle book info", exception);
|
||||||
+ this.disconnect("Invalid Book Data!"); // Paper
|
+ this.disconnect("Invalid Book Data!"); // Paper
|
||||||
return;
|
}
|
||||||
} finally {
|
} else {
|
||||||
packetdataserializer.release();
|
String s1;
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
||||||
|
|
||||||
itemstack1.a("pages", (NBTBase) nbttaglist);
|
itemstack1.a("pages", (NBTBase) nbttaglist);
|
||||||
itemstack1.setItem(Items.WRITTEN_BOOK);
|
itemstack1.setItem(Items.WRITTEN_BOOK);
|
||||||
+ CraftEventFactory.handleEditBookEvent(player, itemstack1); // Paper
|
+ CraftEventFactory.handleEditBookEvent(player, itemstack1); // Paper
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} catch (Exception exception1) {
|
} catch (Exception exception1) {
|
||||||
PlayerConnection.LOGGER.error("Couldn\'t sign book", exception1);
|
PlayerConnection.LOGGER.error("Couldn\'t sign book", exception1);
|
||||||
+ this.disconnect("Invalid Book Data!"); // Paper
|
+ this.disconnect("Invalid Book Data!"); // Paper
|
||||||
return;
|
}
|
||||||
} finally {
|
} else if ("MC|TrSel".equals(s)) {
|
||||||
packetdataserializer.release();
|
try {
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
||||||
}
|
}
|
||||||
} catch (Exception exception3) {
|
} catch (Exception exception3) {
|
||||||
PlayerConnection.LOGGER.error("Couldn\'t set command block", exception3);
|
PlayerConnection.LOGGER.error("Couldn\'t set command block", exception3);
|
||||||
+ this.disconnect("Invalid Command Block Data!"); // Paper
|
+ this.disconnect("Invalid Command Block Data!"); // Paper
|
||||||
} finally {
|
|
||||||
packetdataserializer.release();
|
|
||||||
}
|
}
|
||||||
|
} else if ("MC|AutoCmd".equals(s)) {
|
||||||
|
if (!this.minecraftServer.getEnableCommandBlock()) {
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
||||||
}
|
}
|
||||||
} catch (Exception exception4) {
|
} catch (Exception exception4) {
|
||||||
PlayerConnection.LOGGER.error("Couldn\'t set command block", exception4);
|
PlayerConnection.LOGGER.error("Couldn\'t set command block", exception4);
|
||||||
+ this.disconnect("Invalid Command Block Data!"); // Paper
|
+ this.disconnect("Invalid Command Block Data!"); // Paper
|
||||||
} finally {
|
|
||||||
packetdataserializer.release();
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
int k;
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
||||||
}
|
}
|
||||||
} catch (Exception exception5) {
|
} catch (Exception exception5) {
|
||||||
|
@ -70,20 +56,4 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if ("MC|ItemName".equals(s)) {
|
} else if ("MC|ItemName".equals(s)) {
|
||||||
@@ -0,0 +0,0 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+ // Paper start
|
|
||||||
+ } finally {
|
|
||||||
+ if (packetplayincustompayload.b().refCnt() > 0) {
|
|
||||||
+ packetplayincustompayload.b().release();
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -51,5 +51,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public boolean interact(World world, BlockPosition blockposition, IBlockData iblockdata, EntityHuman entityhuman, EnumHand enumhand, @Nullable ItemStack itemstack, EnumDirection enumdirection, float f, float f1, float f2) {
|
public boolean interact(World world, BlockPosition blockposition, IBlockData iblockdata, EntityHuman entityhuman, EnumHand enumhand, @Nullable ItemStack itemstack, EnumDirection enumdirection, float f, float f1, float f2) {
|
||||||
if (world.isClientSide) {
|
if (world.isClientSide) {
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private boolean x;
|
private boolean x;
|
||||||
private boolean y;
|
private boolean y;
|
||||||
public boolean b;
|
public boolean b;
|
||||||
- public Set<EntityPlayer> trackedPlayers = Sets.newHashSet();
|
- public final Set<EntityPlayer> trackedPlayers = Sets.newHashSet();
|
||||||
+ // Paper start
|
+ // Paper start
|
||||||
+ // Replace trackedPlayers Set with a Map. The value is true until the player receives
|
+ // Replace trackedPlayers Set with a Map. The value is true until the player receives
|
||||||
+ // their first update (which is forced to have absolute coordinates), false afterward.
|
+ // their first update (which is forced to have absolute coordinates), false afterward.
|
||||||
|
@ -23,38 +23,21 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public EntityTrackerEntry(Entity entity, int i, int j, int k, boolean flag) {
|
public EntityTrackerEntry(Entity entity, int i, int j, int k, boolean flag) {
|
||||||
this.tracker = entity;
|
this.tracker = entity;
|
||||||
@@ -0,0 +0,0 @@ public class EntityTrackerEntry {
|
@@ -0,0 +0,0 @@ public class EntityTrackerEntry {
|
||||||
boolean flag = k1 * k1 + l1 * l1 + i2 * i2 >= 128L || this.a % 60 == 0;
|
boolean flag1 = l1 * l1 + i2 * i2 + j2 * j2 >= 128L || this.a % 60 == 0;
|
||||||
boolean flag1 = Math.abs(i1 - this.yRot) >= 1 || Math.abs(j1 - this.xRot) >= 1;
|
boolean flag2 = Math.abs(j1 - this.yRot) >= 1 || Math.abs(k1 - this.xRot) >= 1;
|
||||||
|
|
||||||
- // CraftBukkit start - Code moved from below
|
|
||||||
- if (flag) {
|
|
||||||
- this.xLoc = j;
|
|
||||||
- this.yLoc = k;
|
|
||||||
- this.zLoc = l;
|
|
||||||
- }
|
|
||||||
+ if (this.a > 0 || this.tracker instanceof EntityArrow) { // Paper - Moved up
|
+ if (this.a > 0 || this.tracker instanceof EntityArrow) { // Paper - Moved up
|
||||||
+ // CraftBukkit start - Code moved from below
|
// CraftBukkit start - Code moved from below
|
||||||
+ if (flag) {
|
if (flag1) {
|
||||||
+ this.xLoc = j;
|
this.xLoc = k;
|
||||||
+ this.yLoc = k;
|
@@ -0,0 +0,0 @@ public class EntityTrackerEntry {
|
||||||
+ this.zLoc = l;
|
}
|
||||||
+ }
|
|
||||||
|
|
||||||
- if (flag1) {
|
|
||||||
+ if (flag1) {
|
|
||||||
+ this.yRot = i1;
|
|
||||||
+ this.xRot = j1;
|
|
||||||
+ }
|
|
||||||
+ // CraftBukkit end
|
|
||||||
this.yRot = i1;
|
|
||||||
this.xRot = j1;
|
|
||||||
- }
|
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
-
|
|
||||||
- if (this.a > 0 || this.tracker instanceof EntityArrow) {
|
- if (this.a > 0 || this.tracker instanceof EntityArrow) {
|
||||||
if (k1 >= -32768L && k1 < 32768L && l1 >= -32768L && l1 < 32768L && i2 >= -32768L && i2 < 32768L && this.v <= 400 && !this.x && this.y == this.tracker.onGround) {
|
if (l1 >= -32768L && l1 < 32768L && i2 >= -32768L && i2 < 32768L && j2 >= -32768L && j2 < 32768L && this.v <= 400 && !this.x && this.y == this.tracker.onGround) {
|
||||||
if ((!flag || !flag1) && !(this.tracker instanceof EntityArrow)) {
|
if ((!flag1 || !flag2) && !(this.tracker instanceof EntityArrow)) {
|
||||||
if (flag) {
|
if (flag1) {
|
||||||
@@ -0,0 +0,0 @@ public class EntityTrackerEntry {
|
@@ -0,0 +0,0 @@ public class EntityTrackerEntry {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ properties.store(fileoutputstream, "By changing the setting below to TRUE you are indicating your agreement to our EULA (https://account.mojang.com/documents/minecraft_eula)." +
|
+ properties.store(fileoutputstream, "By changing the setting below to TRUE you are indicating your agreement to our EULA (https://account.mojang.com/documents/minecraft_eula)." +
|
||||||
+ "\nand also agreeing that tacos are tasty."); // Paper - fix lag
|
+ "\nand also agreeing that tacos are tasty."); // Paper - fix lag
|
||||||
} catch (Exception exception) {
|
} catch (Exception exception) {
|
||||||
EULA.a.warn("Failed to save " + this.b, exception);
|
EULA.a.warn("Failed to save {}", new Object[] { this.b, exception});
|
||||||
} finally {
|
} finally {
|
||||||
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
|
|
@ -24,7 +24,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ this.whitelist(minecraftserver, astring[1], true);
|
+ this.whitelist(minecraftserver, astring[1], true);
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
a(icommandlistener, (ICommand) this, "commands.whitelist.add.success", new Object[] { astring[1]});
|
a(icommandlistener, (ICommand) this, "commands.whitelist.add.success", new Object[] { astring[1]});
|
||||||
} else if (astring[0].equals("remove")) {
|
} else if ("remove".equals(astring[0])) {
|
||||||
if (astring.length < 2) {
|
if (astring.length < 2) {
|
||||||
throw new ExceptionUsage("commands.whitelist.remove.usage", new Object[0]);
|
throw new ExceptionUsage("commands.whitelist.remove.usage", new Object[0]);
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ this.whitelist(minecraftserver, astring[1], false);
|
+ this.whitelist(minecraftserver, astring[1], false);
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
a(icommandlistener, (ICommand) this, "commands.whitelist.remove.success", new Object[] { astring[1]});
|
a(icommandlistener, (ICommand) this, "commands.whitelist.remove.success", new Object[] { astring[1]});
|
||||||
} else if (astring[0].equals("reload")) {
|
} else if ("reload".equals(astring[0])) {
|
||||||
minecraftserver.getPlayerList().reloadWhitelist();
|
minecraftserver.getPlayerList().reloadWhitelist();
|
||||||
@@ -0,0 +0,0 @@ public class CommandWhitelist extends CommandAbstract {
|
@@ -0,0 +0,0 @@ public class CommandWhitelist extends CommandAbstract {
|
||||||
return Collections.emptyList();
|
return Collections.emptyList();
|
||||||
|
|
|
@ -18,5 +18,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
Logger log = Bukkit.getServer().getLogger();
|
Logger log = Bukkit.getServer().getLogger();
|
||||||
log.log( Level.SEVERE, "The server has stopped responding!" );
|
log.log( Level.SEVERE, "The server has stopped responding!" );
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -381,7 +381,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public void m() {
|
public void m() {
|
||||||
- SpigotTimings.timerEntityBaseTick.startTiming(); // Spigot
|
- SpigotTimings.timerEntityBaseTick.startTiming(); // Spigot
|
||||||
super.m();
|
super.m();
|
||||||
this.cv();
|
this.cz();
|
||||||
if (!this.world.isClientSide) {
|
if (!this.world.isClientSide) {
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
||||||
}
|
}
|
||||||
|
@ -395,7 +395,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
float f = (float) (d0 * d0 + d1 * d1);
|
float f = (float) (d0 * d0 + d1 * d1);
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
||||||
} else {
|
} else {
|
||||||
this.bp = 0;
|
this.bq = 0;
|
||||||
}
|
}
|
||||||
-
|
-
|
||||||
- SpigotTimings.timerEntityTickRest.stopTiming(); // Spigot
|
- SpigotTimings.timerEntityTickRest.stopTiming(); // Spigot
|
||||||
|
@ -407,9 +407,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
this.world.methodProfiler.a("ai");
|
this.world.methodProfiler.a("ai");
|
||||||
- SpigotTimings.timerEntityAI.startTiming(); // Spigot
|
- SpigotTimings.timerEntityAI.startTiming(); // Spigot
|
||||||
if (this.cg()) {
|
if (this.cj()) {
|
||||||
this.bd = false;
|
this.be = false;
|
||||||
this.be = 0.0F;
|
this.bf = 0.0F;
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
||||||
this.doTick();
|
this.doTick();
|
||||||
this.world.methodProfiler.b();
|
this.world.methodProfiler.b();
|
||||||
|
@ -419,16 +419,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
this.world.methodProfiler.b();
|
this.world.methodProfiler.b();
|
||||||
this.world.methodProfiler.a("jump");
|
this.world.methodProfiler.a("jump");
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
@@ -0,0 +0,0 @@ public abstract class EntityLiving extends Entity {
|
||||||
this.bf *= 0.98F;
|
this.bg *= 0.98F;
|
||||||
this.bg *= 0.9F;
|
this.bh *= 0.9F;
|
||||||
this.r();
|
this.r();
|
||||||
- SpigotTimings.timerEntityAIMove.startTiming(); // Spigot
|
- SpigotTimings.timerEntityAIMove.startTiming(); // Spigot
|
||||||
this.g(this.be, this.bf);
|
this.g(this.bf, this.bg);
|
||||||
- SpigotTimings.timerEntityAIMove.stopTiming(); // Spigot
|
- SpigotTimings.timerEntityAIMove.stopTiming(); // Spigot
|
||||||
this.world.methodProfiler.b();
|
this.world.methodProfiler.b();
|
||||||
this.world.methodProfiler.a("push");
|
this.world.methodProfiler.a("push");
|
||||||
- SpigotTimings.timerEntityAICollision.startTiming(); // Spigot
|
- SpigotTimings.timerEntityAICollision.startTiming(); // Spigot
|
||||||
this.co();
|
this.cs();
|
||||||
- SpigotTimings.timerEntityAICollision.stopTiming(); // Spigot
|
- SpigotTimings.timerEntityAICollision.stopTiming(); // Spigot
|
||||||
this.world.methodProfiler.b();
|
this.world.methodProfiler.b();
|
||||||
}
|
}
|
||||||
|
@ -486,7 +486,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (this.server != null) {
|
if (this.server != null) {
|
||||||
this.server.disablePlugins();
|
this.server.disablePlugins();
|
||||||
@@ -0,0 +0,0 @@ public abstract class MinecraftServer implements Runnable, ICommandListener, IAs
|
@@ -0,0 +0,0 @@ public abstract class MinecraftServer implements Runnable, ICommandListener, IAs
|
||||||
protected void B() {}
|
public void B() {}
|
||||||
|
|
||||||
protected void C() throws ExceptionWorldConflict { // CraftBukkit - added throws
|
protected void C() throws ExceptionWorldConflict { // CraftBukkit - added throws
|
||||||
- SpigotTimings.serverTickTimer.startTiming(); // Spigot
|
- SpigotTimings.serverTickTimer.startTiming(); // Spigot
|
||||||
|
@ -602,7 +602,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- SpigotTimings.tickablesTimer.startTiming(); // Spigot
|
- SpigotTimings.tickablesTimer.startTiming(); // Spigot
|
||||||
+ MinecraftTimings.tickablesTimer.startTiming(); // Spigot
|
+ MinecraftTimings.tickablesTimer.startTiming(); // Spigot
|
||||||
for (i = 0; i < this.o.size(); ++i) {
|
for (i = 0; i < this.o.size(); ++i) {
|
||||||
((ITickable) this.o.get(i)).c();
|
((ITickable) this.o.get(i)).E_();
|
||||||
}
|
}
|
||||||
- SpigotTimings.tickablesTimer.stopTiming(); // Spigot
|
- SpigotTimings.tickablesTimer.stopTiming(); // Spigot
|
||||||
+ MinecraftTimings.tickablesTimer.stopTiming(); // Spigot
|
+ MinecraftTimings.tickablesTimer.stopTiming(); // Spigot
|
||||||
|
@ -775,8 +775,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- public CustomTimingsHandler tickTimer = org.bukkit.craftbukkit.SpigotTimings.getTileEntityTimings(this); // Spigot
|
- public CustomTimingsHandler tickTimer = org.bukkit.craftbukkit.SpigotTimings.getTileEntityTimings(this); // Spigot
|
||||||
+ public Timing tickTimer = MinecraftTimings.getTileEntityTimings(this); // Paper
|
+ public Timing tickTimer = MinecraftTimings.getTileEntityTimings(this); // Paper
|
||||||
private static final Logger a = LogManager.getLogger();
|
private static final Logger a = LogManager.getLogger();
|
||||||
private static Map<String, Class<? extends TileEntity>> f = Maps.newHashMap();
|
private static final Map<String, Class<? extends TileEntity>> f = Maps.newHashMap();
|
||||||
private static Map<Class<? extends TileEntity>, String> g = Maps.newHashMap();
|
private static final Map<Class<? extends TileEntity>, String> g = Maps.newHashMap();
|
||||||
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/World.java
|
--- a/src/main/java/net/minecraft/server/World.java
|
||||||
|
@ -868,7 +868,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
entity.N = entity.locY;
|
entity.N = entity.locY;
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
||||||
entity.lastPitch = entity.pitch;
|
entity.lastPitch = entity.pitch;
|
||||||
if (flag && entity.aa) {
|
if (flag && entity.ab) {
|
||||||
++entity.ticksLived;
|
++entity.ticksLived;
|
||||||
+ ++co.aikar.timings.TimingHistory.activatedEntityTicks; // Paper
|
+ ++co.aikar.timings.TimingHistory.activatedEntityTicks; // Paper
|
||||||
if (entity.isPassenger()) {
|
if (entity.isPassenger()) {
|
||||||
|
@ -944,7 +944,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
@@ -0,0 +0,0 @@ public class WorldServer extends World implements IAsyncTaskHandler {
|
@@ -0,0 +0,0 @@ public class WorldServer extends World implements IAsyncTaskHandler {
|
||||||
|
|
||||||
if (this.areChunksLoadedBetween(nextticklistentry.a.a(-b0, -b0, -b0), nextticklistentry.a.a(b0, b0, b0))) {
|
if (this.areChunksLoadedBetween(nextticklistentry.a.a(0, 0, 0), nextticklistentry.a.a(0, 0, 0))) {
|
||||||
IBlockData iblockdata = this.getType(nextticklistentry.a);
|
IBlockData iblockdata = this.getType(nextticklistentry.a);
|
||||||
+ co.aikar.timings.Timing timing = iblockdata.getBlock().getTiming(); // Paper
|
+ co.aikar.timings.Timing timing = iblockdata.getBlock().getTiming(); // Paper
|
||||||
+ timing.startTiming(); // Paper
|
+ timing.startTiming(); // Paper
|
||||||
|
@ -1398,7 +1398,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
- SpigotTimings.checkIfActiveTimer.startTiming();
|
- SpigotTimings.checkIfActiveTimer.startTiming();
|
||||||
// Never safe to skip fireworks or entities not yet added to chunk
|
// Never safe to skip fireworks or entities not yet added to chunk
|
||||||
// PAIL: inChunk
|
// PAIL: inChunk
|
||||||
if ( !entity.aa || entity instanceof EntityFireworks ) {
|
if ( !entity.ab || entity instanceof EntityFireworks ) {
|
||||||
- SpigotTimings.checkIfActiveTimer.stopTiming();
|
- SpigotTimings.checkIfActiveTimer.stopTiming();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public class ChunkProviderServer implements IChunkProvider {
|
public class ChunkProviderServer implements IChunkProvider {
|
||||||
|
|
||||||
private static final Logger a = LogManager.getLogger();
|
private static final Logger a = LogManager.getLogger();
|
||||||
- public final Set<Long> unloadQueue = Sets.newHashSet(); // PAIL: private -> public
|
- public final Set<Long> unloadQueue = Sets.newHashSet();
|
||||||
+ public final it.unimi.dsi.fastutil.longs.LongSet unloadQueue = new it.unimi.dsi.fastutil.longs.LongArraySet(); // PAIL: private -> public // Paper
|
+ public final it.unimi.dsi.fastutil.longs.LongSet unloadQueue = new it.unimi.dsi.fastutil.longs.LongArraySet(); // PAIL: private -> public // Paper
|
||||||
public final ChunkGenerator chunkGenerator;
|
public final ChunkGenerator chunkGenerator;
|
||||||
private final IChunkLoader chunkLoader;
|
private final IChunkLoader chunkLoader;
|
||||||
|
|
|
@ -20,7 +20,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
this.width = 0.6F;
|
this.width = 0.6F;
|
||||||
this.length = 1.8F;
|
this.length = 1.8F;
|
||||||
this.aw = 1;
|
this.ax = 1;
|
||||||
- this.random = new Random();
|
- this.random = new Random();
|
||||||
+ this.random = SHARED_RANDOM; // Paper
|
+ this.random = SHARED_RANDOM; // Paper
|
||||||
this.maxFireTicks = 1;
|
this.maxFireTicks = 1;
|
||||||
|
|
|
@ -12,7 +12,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean a(Entity entity, boolean flag) {
|
public boolean a(Entity entity, boolean flag) {
|
||||||
+ return this.mountEntity(entity, flag, false); // Paper - forward
|
+ return this.mountEntity(entity, flag, false); // Paper - OBFHELPER
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public boolean mountEntity(Entity entity, boolean flag, boolean suppressEvents) { // Paper
|
+ public boolean mountEntity(Entity entity, boolean flag, boolean suppressEvents) { // Paper
|
||||||
|
@ -22,9 +22,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
this.at = entity;
|
this.au = entity;
|
||||||
- this.at.o(this);
|
- this.au.o(this);
|
||||||
+ this.at.addRider(this, suppressEvents); // Paper
|
+ this.au.addRider(this, suppressEvents); // Paper
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -32,13 +32,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void o(Entity entity) {
|
protected void o(Entity entity) {
|
||||||
+ // Paper start - Forward
|
+ // Paper start - OBFHELPER
|
||||||
+ this.addRider(entity, false);
|
+ this.addRider(entity, false);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private void addRider(Entity entity, boolean suppressEvents) {
|
+ private void addRider(Entity entity, boolean suppressEvents) {
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
if (entity.bz() != this) {
|
if (entity.bB() != this) {
|
||||||
throw new IllegalStateException("Use x.startRiding(y), not y.addPassenger(x)");
|
throw new IllegalStateException("Use x.startRiding(y), not y.addPassenger(x)");
|
||||||
} else {
|
} else {
|
||||||
// CraftBukkit start
|
// CraftBukkit start
|
||||||
|
@ -55,7 +55,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
// Spigot end
|
// Spigot end
|
||||||
+ // =============================================================
|
+ // =============================================================
|
||||||
+ } // Paper - end suppressible block
|
+ } // Paper - end suppressible block
|
||||||
if (!this.world.isClientSide && entity instanceof EntityHuman && !(this.bu() instanceof EntityHuman)) {
|
if (!this.world.isClientSide && entity instanceof EntityHuman && !(this.bw() instanceof EntityHuman)) {
|
||||||
this.passengers.add(0, entity);
|
this.passengers.add(0, entity);
|
||||||
} else {
|
} else {
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements ICommandListener {
|
||||||
|
@ -87,8 +87,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
+
|
+
|
||||||
protected boolean q(Entity entity) {
|
protected boolean q(Entity entity) {
|
||||||
return this.bv().size() < 1;
|
return this.bx().size() < 1;
|
||||||
}
|
}
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -5,13 +5,13 @@ Subject: [PATCH] Water mobs should only spawn in the water
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/EntityWaterAnimal.java b/src/main/java/net/minecraft/server/EntityWaterAnimal.java
|
diff --git a/src/main/java/net/minecraft/server/EntityWaterAnimal.java b/src/main/java/net/minecraft/server/EntityWaterAnimal.java
|
||||||
index 0000000000000000000000000000000000000000..00000000000000000000000000000000000000005 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/EntityWaterAnimal.java
|
--- a/src/main/java/net/minecraft/server/EntityWaterAnimal.java
|
||||||
+++ b/src/main/java/net/minecraft/server/EntityWaterAnimal.java
|
+++ b/src/main/java/net/minecraft/server/EntityWaterAnimal.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class EntityWaterAnimal extends EntityInsentient implements IAni
|
@@ -0,0 +0,0 @@ public abstract class EntityWaterAnimal extends EntityInsentient implements IAni
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean cG() {
|
public boolean cK() {
|
||||||
- return true;
|
- return true;
|
||||||
+ // Paper start - Don't let water mobs spawn in non-water blocks
|
+ // Paper start - Don't let water mobs spawn in non-water blocks
|
||||||
+ // Based around EntityAnimal's implementation
|
+ // Based around EntityAnimal's implementation
|
||||||
|
|
|
@ -35,5 +35,3 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
|
|
||||||
--
|
--
|
||||||
2.7.4 (Apple Git-66)
|
|
||||||
|
|
||||||
|
|
|
@ -62,7 +62,6 @@ import NavigationAbstract
|
||||||
import NBTTagCompound
|
import NBTTagCompound
|
||||||
import NBTTagList
|
import NBTTagList
|
||||||
import PersistentScoreboard
|
import PersistentScoreboard
|
||||||
import PacketPlayInResourcePackStatus
|
|
||||||
import PacketPlayInUseEntity
|
import PacketPlayInUseEntity
|
||||||
import PacketPlayOutPlayerListHeaderFooter
|
import PacketPlayOutPlayerListHeaderFooter
|
||||||
import PacketPlayOutScoreboardTeam
|
import PacketPlayOutScoreboardTeam
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 9b100f8a6f0d86b5fd5f22f65dd6dd9eba6547d3
|
Subproject commit cede5450c952c76341e047b8d04f9894f16e596d
|
|
@ -1 +1 @@
|
||||||
Subproject commit c5bf6bc614bfd1e119e7fc067ff30cd8e8221cb2
|
Subproject commit a4fe2264e678cdc646098df61398ea8a10b0731a
|
|
@ -1 +1 @@
|
||||||
Subproject commit 0cd0397a8295992112ad3bf0d37795a04d22503e
|
Subproject commit 885f4dce9e238040777536ff34b5b7cee76d6d80
|
|
@ -1 +1 @@
|
||||||
Subproject commit 798f32dcaacf2cb2af0d4e17ff0d221dafe141ab
|
Subproject commit da278d16b469b98f961d0e8fbffe81f274a930db
|
Loading…
Reference in a new issue