Update to 1.3.2

This commit is contained in:
Travis Watkins 2012-08-24 19:51:51 -05:00 committed by EvilSeph
parent 35cff16da5
commit b8cc862083
18 changed files with 103 additions and 79 deletions

View file

@ -4,7 +4,7 @@
<groupId>org.bukkit</groupId> <groupId>org.bukkit</groupId>
<artifactId>craftbukkit</artifactId> <artifactId>craftbukkit</artifactId>
<packaging>jar</packaging> <packaging>jar</packaging>
<version>1.3.1-R2.1-SNAPSHOT</version> <version>1.3.2-R0.1-SNAPSHOT</version>
<name>CraftBukkit</name> <name>CraftBukkit</name>
<url>http://www.bukkit.org</url> <url>http://www.bukkit.org</url>
@ -51,14 +51,14 @@
<dependency> <dependency>
<groupId>org.bukkit</groupId> <groupId>org.bukkit</groupId>
<artifactId>bukkit</artifactId> <artifactId>bukkit</artifactId>
<version>1.3.1-R2.1-SNAPSHOT</version> <version>1.3.2-R0.1-SNAPSHOT</version>
<type>jar</type> <type>jar</type>
<scope>compile</scope> <scope>compile</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.bukkit</groupId> <groupId>org.bukkit</groupId>
<artifactId>minecraft-server</artifactId> <artifactId>minecraft-server</artifactId>
<version>1.3.1</version> <version>1.3.2</version>
<type>jar</type> <type>jar</type>
<scope>compile</scope> <scope>compile</scope>
</dependency> </dependency>

View file

@ -255,7 +255,7 @@ public class Chunk {
} }
if (i1 != l) { if (i1 != l) {
this.world.g(i, k, i1, l); this.world.g(i + this.x * 16, k + this.z * 16, i1, l);
this.heightMap[k << 4 | i] = i1; this.heightMap[k << 4 | i] = i1;
int j1 = this.x * 16 + i; int j1 = this.x * 16 + i;
int k1 = this.z * 16 + k; int k1 = this.z * 16 + k;

View file

@ -47,7 +47,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
System.setErr(new PrintStream(new LoggerOutputStream(log, Level.SEVERE), true)); System.setErr(new PrintStream(new LoggerOutputStream(log, Level.SEVERE), true));
// CraftBukkit end // CraftBukkit end
log.info("Starting minecraft server version 1.3.1"); log.info("Starting minecraft server version 1.3.2");
if (Runtime.getRuntime().maxMemory() / 1024L / 1024L < 512L) { if (Runtime.getRuntime().maxMemory() / 1024L / 1024L < 512L) {
log.warning("To start the server with more ram, launch it as \"java -Xmx1024M -Xms1024M -jar minecraft_server.jar\""); log.warning("To start the server with more ram, launch it as \"java -Xmx1024M -Xms1024M -jar minecraft_server.jar\"");
} }
@ -189,7 +189,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
protected void a(CrashReport crashreport) { protected void a(CrashReport crashreport) {
while (this.isRunning()) { while (this.isRunning()) {
this.ah(); this.ai();
try { try {
Thread.sleep(10L); Thread.sleep(10L);
@ -200,8 +200,9 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
} }
public CrashReport b(CrashReport crashreport) { public CrashReport b(CrashReport crashreport) {
crashreport = super.b(crashreport);
crashreport.a("Type", (Callable) (new CrashReportType(this))); crashreport.a("Type", (Callable) (new CrashReportType(this)));
return super.b(crashreport); return crashreport;
} }
protected void o() { protected void o() {
@ -210,7 +211,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
public void q() { public void q() {
super.q(); super.q();
this.ah(); this.ai();
} }
public boolean getAllowNether() { public boolean getAllowNether() {
@ -222,8 +223,8 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
} }
public void a(MojangStatisticsGenerator mojangstatisticsgenerator) { public void a(MojangStatisticsGenerator mojangstatisticsgenerator) {
mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(this.ai().getHasWhitelist())); mojangstatisticsgenerator.a("whitelist_enabled", Boolean.valueOf(this.aj().getHasWhitelist()));
mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(this.ai().getWhitelisted().size())); mojangstatisticsgenerator.a("whitelist_count", Integer.valueOf(this.aj().getWhitelisted().size()));
super.a(mojangstatisticsgenerator); super.a(mojangstatisticsgenerator);
} }
@ -235,7 +236,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
this.l.add(new ServerCommand(s, icommandlistener)); this.l.add(new ServerCommand(s, icommandlistener));
} }
public void ah() { public void ai() {
while (!this.l.isEmpty()) { while (!this.l.isEmpty()) {
ServerCommand servercommand = (ServerCommand) this.l.remove(0); ServerCommand servercommand = (ServerCommand) this.l.remove(0);
@ -254,7 +255,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
return true; return true;
} }
public ServerConfigurationManager ai() { public ServerConfigurationManager aj() {
return (ServerConfigurationManager) super.getServerConfigurationManager(); return (ServerConfigurationManager) super.getServerConfigurationManager();
} }
@ -288,7 +289,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
return file1 != null ? file1.getAbsolutePath() : "No settings file"; return file1 != null ? file1.getAbsolutePath() : "No settings file";
} }
public void aj() { public void ak() {
ServerGUI.a(this); ServerGUI.a(this);
this.s = true; this.s = true;
} }
@ -302,6 +303,6 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
} }
public ServerConfigurationManagerAbstract getServerConfigurationManager() { public ServerConfigurationManagerAbstract getServerConfigurationManager() {
return this.ai(); return this.aj();
} }
} }

View file

@ -132,7 +132,7 @@ public class EntityEnderman extends EntityMonster {
this.world.a("portal", this.locX + (this.random.nextDouble() - 0.5D) * (double) this.width, this.locY + this.random.nextDouble() * (double) this.length - 0.25D, this.locZ + (this.random.nextDouble() - 0.5D) * (double) this.width, (this.random.nextDouble() - 0.5D) * 2.0D, -this.random.nextDouble(), (this.random.nextDouble() - 0.5D) * 2.0D); this.world.a("portal", this.locX + (this.random.nextDouble() - 0.5D) * (double) this.width, this.locY + this.random.nextDouble() * (double) this.length - 0.25D, this.locZ + (this.random.nextDouble() - 0.5D) * (double) this.width, (this.random.nextDouble() - 0.5D) * 2.0D, -this.random.nextDouble(), (this.random.nextDouble() - 0.5D) * 2.0D);
} }
if (this.world.r() && !this.world.isStatic) { if (this.world.s() && !this.world.isStatic) {
float f = this.c(1.0F); float f = this.c(1.0F);
if (f > 0.5F && this.world.j(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) { if (f > 0.5F && this.world.j(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) {

View file

@ -12,6 +12,8 @@ public class EntityExperienceOrb extends Entity {
public int c; public int c;
private int d = 5; private int d = 5;
public int value; // CraftBukkit - private -> public public int value; // CraftBukkit - private -> public
private EntityHuman targetPlayer;
private int targetTime;
public EntityExperienceOrb(World world, double d0, double d1, double d2, int i) { public EntityExperienceOrb(World world, double d0, double d1, double d2, int i) {
super(world); super(world);
@ -56,11 +58,18 @@ public class EntityExperienceOrb extends Entity {
this.i(this.locX, (this.boundingBox.b + this.boundingBox.e) / 2.0D, this.locZ); this.i(this.locX, (this.boundingBox.b + this.boundingBox.e) / 2.0D, this.locZ);
double d0 = 8.0D; double d0 = 8.0D;
EntityHuman entityhuman = this.world.findNearbyPlayer(this, d0);
if (entityhuman != null) { if (this.targetTime < this.a - 20 + this.id % 100) {
if (this.targetPlayer == null || this.targetPlayer.e(this) > d0 * d0) {
this.targetPlayer = this.world.findNearbyPlayer(this, d0);
}
this.targetTime = this.a;
}
if (this.targetPlayer != null) {
// CraftBukkit start // CraftBukkit start
EntityTargetEvent event = CraftEventFactory.callEntityTargetEvent(this, entityhuman, EntityTargetEvent.TargetReason.CLOSEST_PLAYER); EntityTargetEvent event = CraftEventFactory.callEntityTargetEvent(this, targetPlayer, EntityTargetEvent.TargetReason.CLOSEST_PLAYER);
Entity target = event.getTarget() == null ? null : ((org.bukkit.craftbukkit.entity.CraftEntity) event.getTarget()).getHandle(); Entity target = event.getTarget() == null ? null : ((org.bukkit.craftbukkit.entity.CraftEntity) event.getTarget()).getHandle();
if (!event.isCancelled() && target != null) { if (!event.isCancelled() && target != null) {

View file

@ -144,7 +144,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen
if (!this.world.isStatic) { if (!this.world.isStatic) {
if (!this.l()) { if (!this.l()) {
this.a(true, true, false); this.a(true, true, false);
} else if (this.world.r()) { } else if (this.world.s()) {
this.a(false, true, true); this.a(false, true, true);
} }
} }
@ -855,7 +855,7 @@ public abstract class EntityHuman extends EntityLiving implements ICommandListen
return EnumBedResult.NOT_POSSIBLE_HERE; return EnumBedResult.NOT_POSSIBLE_HERE;
} }
if (this.world.r()) { if (this.world.s()) {
return EnumBedResult.NOT_POSSIBLE_NOW; return EnumBedResult.NOT_POSSIBLE_NOW;
} }

View file

@ -721,7 +721,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
} }
public boolean b(String s) { public boolean b(String s) {
return "seed".equals(s) && !this.server.S() ? true : this.server.getServerConfigurationManager().isOp(this.name); return "seed".equals(s) && !this.server.S() ? true : (!"tell".equals(s) && !"help".equals(s) && !"me".equals(s) ? this.server.getServerConfigurationManager().isOp(this.name) : true);
} }
public String r() { public String r() {

View file

@ -46,7 +46,7 @@ public class EntitySkeleton extends EntityMonster {
} }
public void d() { public void d() {
if (this.world.r() && !this.world.isStatic) { if (this.world.s() && !this.world.isStatic) {
float f = this.c(1.0F); float f = this.c(1.0F);
if (f > 0.5F && this.world.j(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) { if (f > 0.5F && this.world.j(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) {

View file

@ -37,7 +37,7 @@ public class EntityZombie extends EntityMonster {
} }
public void d() { public void d() {
if (this.world.r() && !this.world.isStatic) { if (this.world.s() && !this.world.isStatic) {
float f = this.c(1.0F); float f = this.c(1.0F);
if (f > 0.5F && this.world.j(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) { if (f > 0.5F && this.world.j(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ)) && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F) {

View file

@ -304,7 +304,7 @@ public abstract class MinecraftServer implements Runnable, IMojangStatistics, IC
if (worldserver != null) { if (worldserver != null) {
if (!flag) { if (!flag) {
log.info("Saving chunks for level \'" + worldserver.getWorldData().getName() + "\'/" + worldserver.worldProvider); log.info("Saving chunks for level \'" + worldserver.getWorldData().getName() + "\'/" + worldserver.worldProvider.getName());
worldserver.save(true, (IProgressUpdate) null); // Perform a full save worldserver.save(true, (IProgressUpdate) null); // Perform a full save
} else { } else {
worldserver.save(false, (IProgressUpdate) null); // Queue chunk saving worldserver.save(false, (IProgressUpdate) null); // Queue chunk saving
@ -561,10 +561,7 @@ public abstract class MinecraftServer implements Runnable, IMojangStatistics, IC
while (true) { while (true) {
if (!worldserver.updateLights()) { if (!worldserver.updateLights()) {
// this.methodProfiler.b(); // CraftBukkit - not in production code // this.methodProfiler.b(); // CraftBukkit - not in production code
if (true || !worldserver.players.isEmpty()) { // CraftBukkit - this prevents entity cleanup, other issue on servers with no players worldserver.tickEntities();
worldserver.tickEntities();
}
// this.methodProfiler.a("tracker"); // CraftBukkit - not in production code // this.methodProfiler.a("tracker"); // CraftBukkit - not in production code
worldserver.getTracker().updatePlayers(); worldserver.getTracker().updatePlayers();
// this.methodProfiler.b(); // CraftBukkit - not in production code // this.methodProfiler.b(); // CraftBukkit - not in production code
@ -691,7 +688,7 @@ public abstract class MinecraftServer implements Runnable, IMojangStatistics, IC
} }
if (flag) { if (flag) {
dedicatedserver.aj(); dedicatedserver.ak();
} }
*/ */
@ -744,7 +741,7 @@ public abstract class MinecraftServer implements Runnable, IMojangStatistics, IC
} }
public String getVersion() { public String getVersion() {
return "1.3.1"; return "1.3.2";
} }
public int x() { public int x() {

View file

@ -126,6 +126,9 @@ public class NetServerHandler extends NetHandler {
// this.minecraftServer.methodProfiler.c("playerTick"); // CraftBukkit - not in production code // this.minecraftServer.methodProfiler.c("playerTick"); // CraftBukkit - not in production code
if (!this.h && !this.player.viewingCredits) { if (!this.h && !this.player.viewingCredits) {
this.player.g(); this.player.g();
if (this.player.vehicle == null) {
this.player.setPositionRotation(this.y, this.z, this.q, this.player.yaw, this.player.pitch);
}
} }
// this.minecraftServer.methodProfiler.b(); // CraftBukkit - not in production code // this.minecraftServer.methodProfiler.b(); // CraftBukkit - not in production code
@ -266,13 +269,11 @@ public class NetServerHandler extends NetHandler {
} }
if (packet10flying.hasPos && packet10flying.y == -999.0D && packet10flying.stance == -999.0D) { if (packet10flying.hasPos && packet10flying.y == -999.0D && packet10flying.stance == -999.0D) {
// CraftBukkit start if (Math.abs(packet10flying.x) > 1.0D || Math.abs(packet10flying.z) > 1.0D) {
if (Math.abs(packet10flying.x) > 1 || Math.abs(packet10flying.z) > 1) {
System.err.println(player.getName() + " was caught trying to crash the server with an invalid position."); System.err.println(player.getName() + " was caught trying to crash the server with an invalid position.");
player.kickPlayer("Nope!"); player.kickPlayer("Nope!");
return; return;
} }
// CraftBukkit end
d5 = packet10flying.x; d5 = packet10flying.x;
d4 = packet10flying.z; d4 = packet10flying.z;
@ -875,6 +876,7 @@ public class NetServerHandler extends NetHandler {
} }
try { try {
logger.info(event.getPlayer().getName() + " issued server command: " + event.getMessage()); // CraftBukkit
if (this.server.dispatchCommand(event.getPlayer(), event.getMessage().substring(1))) { if (this.server.dispatchCommand(event.getPlayer(), event.getMessage().substring(1))) {
return; return;
} }
@ -886,10 +888,7 @@ public class NetServerHandler extends NetHandler {
// CraftBukkit end // CraftBukkit end
/* CraftBukkit start - No longer needed as we have already handled it in server.dispatchServerCommand above. /* CraftBukkit start - No longer needed as we have already handled it in server.dispatchServerCommand above.
if (this.minecraftServer.getServerConfigurationManager().isOp(this.player.name) || "/seed".equals(s)) { this.minecraftServer.getCommandHandler().a(this.player, s);
logger.info(this.player.name + " issued server command: " + s);
this.minecraftServer.getCommandHandler().a(this.player, s);
}
// CraftBukkit end */ // CraftBukkit end */
} }

View file

@ -142,8 +142,4 @@ public class Packet56MapChunkBulk extends Packet {
public int d() { public int d() {
return this.c.length; return this.c.length;
} }
public boolean a_() {
return true;
}
} }

View file

@ -229,7 +229,7 @@ public class PlayerManager {
public boolean a(EntityPlayer entityplayer, int i, int j) { public boolean a(EntityPlayer entityplayer, int i, int j) {
PlayerInstance playerinstance = this.a(i, j, false); PlayerInstance playerinstance = this.a(i, j, false);
return playerinstance == null ? false : PlayerInstance.b(playerinstance).contains(entityplayer); return playerinstance == null ? false : PlayerInstance.b(playerinstance).contains(entityplayer) && !entityplayer.chunkCoordIntPairQueue.contains(PlayerInstance.a(playerinstance));
} }
public static int getFurthestViewableBlock(int i) { public static int getFurthestViewableBlock(int i) {

View file

@ -499,12 +499,8 @@ public abstract class ServerConfigurationManagerAbstract {
} }
public void sendAll(Packet packet) { public void sendAll(Packet packet) {
Iterator iterator = this.players.iterator(); for (int i = 0; i < this.players.size(); ++i) {
((EntityPlayer) this.players.get(i)).netServerHandler.sendPacket(packet);
while (iterator.hasNext()) {
EntityPlayer entityplayer = (EntityPlayer) iterator.next();
entityplayer.netServerHandler.sendPacket(packet);
} }
} }

View file

@ -28,7 +28,7 @@ public class VillageSiege {
return; return;
} }
} else { } else {
if (this.world.r()) { if (this.world.s()) {
this.c = 0; this.c = 0;
return; return;
} }

View file

@ -134,7 +134,7 @@ public abstract class World implements IBlockAccess {
} }
this.worldProvider.a(this); this.worldProvider.a(this);
this.chunkProvider = this.h(); this.chunkProvider = this.i();
if (!this.worldData.isInitialized()) { if (!this.worldData.isInitialized()) {
this.a(worldsettings); this.a(worldsettings);
this.worldData.d(true); this.worldData.d(true);
@ -146,7 +146,7 @@ public abstract class World implements IBlockAccess {
this.getServer().addWorld(this.world); // CraftBukkit this.getServer().addWorld(this.world); // CraftBukkit
} }
protected abstract IChunkProvider h(); protected abstract IChunkProvider i();
protected void a(WorldSettings worldsettings) { protected void a(WorldSettings worldsettings) {
this.worldData.d(true); this.worldData.d(true);
@ -586,7 +586,7 @@ public abstract class World implements IBlockAccess {
return this.worldProvider.f[this.getLightLevel(i, j, k)]; return this.worldProvider.f[this.getLightLevel(i, j, k)];
} }
public boolean r() { public boolean s() {
return this.k < 4; return this.k < 4;
} }
@ -1704,7 +1704,7 @@ public abstract class World implements IBlockAccess {
} }
public void doTick() { public void doTick() {
this.l(); this.m();
} }
private void a() { private void a() {
@ -1716,7 +1716,7 @@ public abstract class World implements IBlockAccess {
} }
} }
protected void l() { protected void m() {
if (!this.worldProvider.e) { if (!this.worldProvider.e) {
if (this.r > 0) { if (this.r > 0) {
--this.r; --this.r;

View file

@ -118,7 +118,7 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree
aint1[b2] = aint[b2] + k1; aint1[b2] = aint[b2] + k1;
int l1 = this.world.getTypeId(aint1[0], aint1[1], aint1[2]); int l1 = this.world.getTypeId(aint1[0], aint1[1], aint1[2]);
if (l1 != 0 && l1 != 18) { if (l1 != 0 && l1 != Block.LEAVES.id) {
++k1; ++k1;
} else { } else {
this.setTypeAndData(this.world, aint1[0], aint1[1], aint1[2], l, 0); this.setTypeAndData(this.world, aint1[0], aint1[1], aint1[2], l, 0);
@ -160,7 +160,7 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree
for (int i1 = j + this.n; l < i1; ++l) { for (int i1 = j + this.n; l < i1; ++l) {
float f = this.b(l - j); float f = this.b(l - j);
this.a(i, l, k, f, (byte) 1, 18); this.a(i, l, k, f, (byte) 1, Block.LEAVES.id);
} }
} }
@ -197,7 +197,20 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree
aint3[b1] = MathHelper.floor((double) (aint[b1] + j) + 0.5D); aint3[b1] = MathHelper.floor((double) (aint[b1] + j) + 0.5D);
aint3[b2] = MathHelper.floor((double) aint[b2] + (double) j * d0 + 0.5D); aint3[b2] = MathHelper.floor((double) aint[b2] + (double) j * d0 + 0.5D);
aint3[b3] = MathHelper.floor((double) aint[b3] + (double) j * d1 + 0.5D); aint3[b3] = MathHelper.floor((double) aint[b3] + (double) j * d1 + 0.5D);
this.setTypeAndData(this.world, aint3[0], aint3[1], aint3[2], i, 0); byte b5 = 0;
int l = Math.abs(aint3[0] - aint[0]);
int i1 = Math.abs(aint3[2] - aint[2]);
int j1 = Math.max(l, i1);
if (j1 > 0) {
if (l == j1) {
b5 = 4;
} else if (i1 == j1) {
b5 = 8;
}
}
this.setTypeAndData(this.world, aint3[0], aint3[1], aint3[2], i, b5);
} }
} }
} }
@ -226,17 +239,17 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree
int[] aint = new int[] { i, j, l}; int[] aint = new int[] { i, j, l};
int[] aint1 = new int[] { i, k, l}; int[] aint1 = new int[] { i, k, l};
this.a(aint, aint1, 17); this.a(aint, aint1, Block.LOG.id);
if (this.l == 2) { if (this.l == 2) {
++aint[0]; ++aint[0];
++aint1[0]; ++aint1[0];
this.a(aint, aint1, 17); this.a(aint, aint1, Block.LOG.id);
++aint[2]; ++aint[2];
++aint1[2]; ++aint1[2];
this.a(aint, aint1, 17); this.a(aint, aint1, Block.LOG.id);
aint[0] += -1; aint[0] += -1;
aint1[0] += -1; aint1[0] += -1;
this.a(aint, aint1, 17); this.a(aint, aint1, Block.LOG.id);
} }
} }
@ -252,7 +265,7 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree
int k = aint[1] - this.d[1]; int k = aint[1] - this.d[1];
if (this.c(k)) { if (this.c(k)) {
this.a(aint, aint2, 17); this.a(aint, aint2, (byte) Block.LOG.id);
} }
} }
} }
@ -296,7 +309,7 @@ public class WorldGenBigTree extends WorldGenerator implements BlockSapling.Tree
aint3[b3] = MathHelper.floor((double) aint[b3] + (double) i * d1); aint3[b3] = MathHelper.floor((double) aint[b3] + (double) i * d1);
int k = this.world.getTypeId(aint3[0], aint3[1], aint3[2]); int k = this.world.getTypeId(aint3[0], aint3[1], aint3[2]);
if ((k != 0 && k != 18) || aint3[1] >= 256) { // CraftBukkit - fix trees wrapping around if ((k != 0 && k != Block.LEAVES.id) || aint3[1] >= 256) { // CraftBukkit - fix trees wrapping around
break; break;
} }
} }

View file

@ -30,9 +30,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
public boolean weirdIsOpCache = false; public boolean weirdIsOpCache = false;
public boolean savingDisabled; public boolean savingDisabled;
private boolean P; private boolean P;
private NoteDataList[] Q = new NoteDataList[] { new NoteDataList((EmptyClass2) null), new NoteDataList((EmptyClass2) null)}; private int emptyTime = 0;
private int R = 0; private NoteDataList[] R = new NoteDataList[] { new NoteDataList((EmptyClass2) null), new NoteDataList((EmptyClass2) null)};
private static final StructurePieceTreasure[] S = new StructurePieceTreasure[] { new StructurePieceTreasure(Item.STICK.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.WOOD.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.LOG.id, 0, 1, 3, 10), new StructurePieceTreasure(Item.STONE_AXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_AXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.STONE_PICKAXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_PICKAXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.APPLE.id, 0, 2, 3, 5), new StructurePieceTreasure(Item.BREAD.id, 0, 2, 3, 3)}; private int S = 0;
private static final StructurePieceTreasure[] T = new StructurePieceTreasure[] { new StructurePieceTreasure(Item.STICK.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.WOOD.id, 0, 1, 3, 10), new StructurePieceTreasure(Block.LOG.id, 0, 1, 3, 10), new StructurePieceTreasure(Item.STONE_AXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_AXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.STONE_PICKAXE.id, 0, 1, 1, 3), new StructurePieceTreasure(Item.WOOD_PICKAXE.id, 0, 1, 1, 5), new StructurePieceTreasure(Item.APPLE.id, 0, 2, 3, 5), new StructurePieceTreasure(Item.BREAD.id, 0, 2, 3, 3)};
private IntHashMap entitiesById; private IntHashMap entitiesById;
// CraftBukkit start // CraftBukkit start
@ -415,6 +416,18 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
} }
} }
public void tickEntities() {
if (false && this.players.isEmpty()) { // CraftBukkit - this prevents entity cleanup, other issues on servers with no players
if (this.emptyTime++ >= 60) {
return;
}
} else {
this.emptyTime = 0;
}
super.tickEntities();
}
public boolean a(boolean flag) { public boolean a(boolean flag) {
int i = this.O.size(); int i = this.O.size();
@ -503,7 +516,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
super.entityJoinedWorld(entity, flag); super.entityJoinedWorld(entity, flag);
} }
protected IChunkProvider h() { protected IChunkProvider i() {
IChunkLoader ichunkloader = this.dataManager.createChunkLoader(this.worldProvider); IChunkLoader ichunkloader = this.dataManager.createChunkLoader(this.worldProvider);
// CraftBukkit start // CraftBukkit start
@ -621,13 +634,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
this.worldData.setSpawn(i, j, k); this.worldData.setSpawn(i, j, k);
this.isLoading = false; this.isLoading = false;
if (worldsettings.c()) { if (worldsettings.c()) {
this.i(); this.j();
} }
} }
} }
protected void i() { protected void j() {
WorldGenBonusChest worldgenbonuschest = new WorldGenBonusChest(S, 10); WorldGenBonusChest worldgenbonuschest = new WorldGenBonusChest(T, 10);
for (int i = 0; i < 10; ++i) { for (int i = 0; i < 10; ++i) {
int j = this.worldData.c() + this.random.nextInt(6) - this.random.nextInt(6); int j = this.worldData.c() + this.random.nextInt(6) - this.random.nextInt(6);
@ -756,13 +769,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
public void playNote(int i, int j, int k, int l, int i1, int j1) { public void playNote(int i, int j, int k, int l, int i1, int j1) {
NoteBlockData noteblockdata = new NoteBlockData(i, j, k, l, i1, j1); NoteBlockData noteblockdata = new NoteBlockData(i, j, k, l, i1, j1);
Iterator iterator = this.Q[this.R].iterator(); Iterator iterator = this.R[this.S].iterator();
NoteBlockData noteblockdata1; NoteBlockData noteblockdata1;
do { do {
if (!iterator.hasNext()) { if (!iterator.hasNext()) {
this.Q[this.R].add(noteblockdata); this.R[this.S].add(noteblockdata);
return; return;
} }
@ -772,11 +785,11 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
} }
private void Q() { private void Q() {
while (!this.Q[this.R].isEmpty()) { while (!this.R[this.S].isEmpty()) {
int i = this.R; int i = this.S;
this.R ^= 1; this.S ^= 1;
Iterator iterator = this.Q[i].iterator(); Iterator iterator = this.R[i].iterator();
while (iterator.hasNext()) { while (iterator.hasNext()) {
NoteBlockData noteblockdata = (NoteBlockData) iterator.next(); NoteBlockData noteblockdata = (NoteBlockData) iterator.next();
@ -787,7 +800,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
} }
} }
this.Q[i].clear(); this.R[i].clear();
} }
} }
@ -806,10 +819,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate
this.dataManager.a(); this.dataManager.a();
} }
protected void l() { protected void m() {
boolean flag = this.J(); boolean flag = this.J();
super.l(); super.m();
if (flag != this.J()) { if (flag != this.J()) {
// CraftBukkit start - only sending weather packets to those affected // CraftBukkit start - only sending weather packets to those affected
for (int i = 0; i < this.players.size(); ++i) { for (int i = 0; i < this.players.size(); ++i) {