diff options
author | Travis Watkins <amaranth@ubuntu.com> | 2013-03-13 17:33:27 -0500 |
---|---|---|
committer | Travis Watkins <amaranth@ubuntu.com> | 2013-03-15 13:28:59 -0500 |
commit | 83d29e461c85733f0113b6eb19db6e3b42da2949 (patch) | |
tree | b3063a1c28f478ab368d5ba3413a842def68c28f /src/main/java/net/minecraft/server/WorldServer.java | |
parent | ba6e4c38cfa98ad291974195cc46d70a4f138ac1 (diff) | |
download | craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.gz craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.lz craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.xz craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.zip |
Update CraftBukkit to Minecraft 1.5
Diffstat (limited to 'src/main/java/net/minecraft/server/WorldServer.java')
-rw-r--r-- | src/main/java/net/minecraft/server/WorldServer.java | 183 |
1 files changed, 117 insertions, 66 deletions
diff --git a/src/main/java/net/minecraft/server/WorldServer.java b/src/main/java/net/minecraft/server/WorldServer.java index 3f73ef97..d99b6a3b 100644 --- a/src/main/java/net/minecraft/server/WorldServer.java +++ b/src/main/java/net/minecraft/server/WorldServer.java @@ -34,13 +34,14 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate private NoteDataList[] Q = new NoteDataList[] { new NoteDataList((EmptyClass2) null), new NoteDataList((EmptyClass2) null)}; private int R = 0; 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 ArrayList T = new ArrayList(); private IntHashMap entitiesById; // CraftBukkit start public final int dimension; - public WorldServer(MinecraftServer minecraftserver, IDataManager idatamanager, String s, int i, WorldSettings worldsettings, MethodProfiler methodprofiler, org.bukkit.World.Environment env, org.bukkit.generator.ChunkGenerator gen) { - super(idatamanager, s, worldsettings, WorldProvider.byDimension(env.getId()), methodprofiler, gen, env); + public WorldServer(MinecraftServer minecraftserver, IDataManager idatamanager, String s, int i, WorldSettings worldsettings, MethodProfiler methodprofiler, IConsoleLogManager iconsolelogmanager, org.bukkit.World.Environment env, org.bukkit.generator.ChunkGenerator gen) { + super(idatamanager, s, worldsettings, WorldProvider.byDimension(env.getId()), methodprofiler, iconsolelogmanager, gen, env); this.dimension = i; this.pvpMode = minecraftserver.getPvP(); // CraftBukkit end @@ -60,6 +61,16 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } this.P = new org.bukkit.craftbukkit.CraftTravelAgent(this); // CraftBukkit + this.scoreboard = new ScoreboardServer(minecraftserver); + ScoreboardSaveData scoreboardsavedata = (ScoreboardSaveData) this.worldMaps.get(ScoreboardSaveData.class, "scoreboard"); + + if (scoreboardsavedata == null) { + scoreboardsavedata = new ScoreboardSaveData(); + this.worldMaps.a("scoreboard", scoreboardsavedata); + } + + scoreboardsavedata.a(this.scoreboard); + ((ScoreboardServer) this.scoreboard).a(scoreboardsavedata); } // CraftBukkit start @@ -106,15 +117,15 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } private TileEntity fixTileEntity(int x, int y, int z, int type, TileEntity found) { - getServer().getLogger().severe("Block at " + x + "," + y + "," + z + " is " + org.bukkit.Material.getMaterial(type).toString() + " but has " + found + ". " + this.getServer().getLogger().severe("Block at " + x + "," + y + "," + z + " is " + org.bukkit.Material.getMaterial(type).toString() + " but has " + found + ". " + "Bukkit will attempt to fix this, but there may be additional damage that we cannot recover."); if (Block.byId[type] instanceof BlockContainer) { - TileEntity replacement = ((BlockContainer) Block.byId[type]).a(this); - setTileEntity(x, y, z, replacement); + TileEntity replacement = ((BlockContainer) Block.byId[type]).b(this); + this.setTileEntity(x, y, z, replacement); return replacement; } else { - getServer().getLogger().severe("Don't know how to fix for this type... Can't do anything! :("); + this.getServer().getLogger().severe("Don't know how to fix for this type... Can't do anything! :("); return found; } } @@ -165,7 +176,6 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.j = j; } - this.V(); this.worldData.setTime(this.worldData.getTime() + 1L); this.worldData.setDayTime(this.worldData.getDayTime() + 1L); this.methodProfiler.c("tickPending"); @@ -180,13 +190,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate this.methodProfiler.c("portalForcer"); this.P.a(this.getTime()); this.methodProfiler.b(); - this.V(); + this.Y(); this.getWorld().processChunkGC(); // CraftBukkit } public BiomeMeta a(EnumCreatureType enumcreaturetype, int i, int j, int k) { - List list = this.I().getMobsFor(enumcreaturetype, i, j, k); + List list = this.J().getMobsFor(enumcreaturetype, i, j, k); return list != null && !list.isEmpty() ? (BiomeMeta) WeightedRandom.a(this.random, (Collection) list) : null; } @@ -217,10 +227,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } - this.U(); + this.X(); } - private void U() { + private void X() { // CraftBukkit start WeatherChangeEvent weather = new WeatherChangeEvent(this.getWorld(), false); this.getServer().getPluginManager().callEvent(weather); @@ -293,13 +303,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate int k1; int l1; - if (this.random.nextInt(100000) == 0 && this.N() && this.M()) { + if (this.random.nextInt(100000) == 0 && this.O() && this.N()) { this.k = this.k * 3 + 1013904223; i1 = this.k >> 2; j1 = k + (i1 & 15); k1 = l + (i1 >> 8 & 15); l1 = this.h(j1, k1); - if (this.D(j1, l1, k1)) { + if (this.F(j1, l1, k1)) { this.strikeLightning(new EntityLightning(this, (double) j1, (double) l1, (double) k1)); } } @@ -313,7 +323,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate j1 = i1 & 15; k1 = i1 >> 8 & 15; l1 = this.h(j1 + k, k1 + l); - if (this.x(j1 + k, l1 - 1, k1 + l)) { + if (this.y(j1 + k, l1 - 1, k1 + l)) { // CraftBukkit start BlockState blockState = this.getWorld().getBlockAt(j1 + k, l1 - 1, k1 + l).getState(); blockState.setTypeId(Block.ICE.id); @@ -326,7 +336,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - if (this.N() && this.y(j1 + k, l1, k1 + l)) { + if (this.O() && this.z(j1 + k, l1, k1 + l)) { // CraftBukkit start BlockState blockState = this.getWorld().getBlockAt(j1 + k, l1, k1 + l).getState(); blockState.setTypeId(Block.SNOW.id); @@ -339,13 +349,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - if (this.N()) { + if (this.O()) { BiomeBase biomebase = this.getBiome(j1 + k, k1 + l); if (biomebase.d()) { i2 = this.getTypeId(j1 + k, l1 - 1, k1 + l); if (i2 != 0) { - Block.byId[i2].f(this, j1 + k, l1 - 1, k1 + l); + Block.byId[i2].g(this, j1 + k, l1 - 1, k1 + l); } } } @@ -373,7 +383,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate if (block != null && block.isTicking()) { ++i; - block.b(this, k2 + k, i3 + chunksection.d(), l2 + l, this.random); + block.a(this, k2 + k, i3 + chunksection.d(), l2 + l, this.random); } } } @@ -383,21 +393,27 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } + public boolean a(int i, int j, int k, int l) { + NextTickListEntry nextticklistentry = new NextTickListEntry(i, j, k, l); + + return this.T.contains(nextticklistentry); + } + public void a(int i, int j, int k, int l, int i1) { this.a(i, j, k, l, i1, 0); } public void a(int i, int j, int k, int l, int i1, int j1) { NextTickListEntry nextticklistentry = new NextTickListEntry(i, j, k, l); - byte b0 = 8; + byte b0 = 0; if (this.d && l > 0) { if (Block.byId[l].l()) { - if (this.d(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { + if (this.e(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { int k1 = this.getTypeId(nextticklistentry.a, nextticklistentry.b, nextticklistentry.c); if (k1 == nextticklistentry.d && k1 > 0) { - Block.byId[k1].b(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); + Block.byId[k1].a(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); } } @@ -407,7 +423,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate i1 = 1; } - if (this.d(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { + if (this.e(i - b0, j - b0, k - b0, i + b0, j + b0, k + b0)) { if (l > 0) { nextticklistentry.a((long) i1 + this.worldData.getTime()); nextticklistentry.a(j1); @@ -420,9 +436,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } } - public void b(int i, int j, int k, int l, int i1) { + public void b(int i, int j, int k, int l, int i1, int j1) { NextTickListEntry nextticklistentry = new NextTickListEntry(i, j, k, l); + nextticklistentry.a(j1); if (l > 0) { nextticklistentry.a((long) i1 + this.worldData.getTime()); } @@ -465,23 +482,36 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate // CraftBukkit end } - for (int j = 0; j < i; ++j) { - NextTickListEntry nextticklistentry = (NextTickListEntry) this.M.first(); + this.methodProfiler.a("cleaning"); + + NextTickListEntry nextticklistentry; + for (int j = 0; j < i; ++j) { + nextticklistentry = (NextTickListEntry) this.M.first(); if (!flag && nextticklistentry.e > this.worldData.getTime()) { break; } this.M.remove(nextticklistentry); this.L.remove(nextticklistentry); - byte b0 = 8; + this.T.add(nextticklistentry); + } - if (this.d(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { + this.methodProfiler.b(); + this.methodProfiler.a("ticking"); + Iterator iterator = this.T.iterator(); + + while (iterator.hasNext()) { + nextticklistentry = (NextTickListEntry) iterator.next(); + iterator.remove(); + byte b0 = 0; + + if (this.e(nextticklistentry.a - b0, nextticklistentry.b - b0, nextticklistentry.c - b0, nextticklistentry.a + b0, nextticklistentry.b + b0, nextticklistentry.c + b0)) { int k = this.getTypeId(nextticklistentry.a, nextticklistentry.b, nextticklistentry.c); - if (k == nextticklistentry.d && k > 0) { + if (k > 0 && Block.b(k, nextticklistentry.d)) { try { - Block.byId[k].b(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); + Block.byId[k].a(this, nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, this.random); } catch (Throwable throwable) { CrashReport crashreport = CrashReport.a(throwable, "Exception while ticking a block"); CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Block being ticked"); @@ -498,9 +528,13 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate throw new ReportedException(crashreport); } } + } else { + this.a(nextticklistentry.a, nextticklistentry.b, nextticklistentry.c, nextticklistentry.d, 0); } } + this.methodProfiler.b(); + this.T.clear(); return !this.M.isEmpty(); } } @@ -508,26 +542,38 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public List a(Chunk chunk, boolean flag) { ArrayList arraylist = null; ChunkCoordIntPair chunkcoordintpair = chunk.l(); - int i = chunkcoordintpair.x << 4; - int j = i + 16; - int k = chunkcoordintpair.z << 4; - int l = k + 16; - Iterator iterator = this.M.iterator(); + int i = (chunkcoordintpair.x << 4) - 2; + int j = i + 16 + 2; + int k = (chunkcoordintpair.z << 4) - 2; + int l = k + 16 + 2; - while (iterator.hasNext()) { - NextTickListEntry nextticklistentry = (NextTickListEntry) iterator.next(); + for (int i1 = 0; i1 < 2; ++i1) { + Iterator iterator; - if (nextticklistentry.a >= i && nextticklistentry.a < j && nextticklistentry.c >= k && nextticklistentry.c < l) { - if (flag) { - this.L.remove(nextticklistentry); - iterator.remove(); + if (i1 == 0) { + iterator = this.M.iterator(); + } else { + iterator = this.T.iterator(); + if (!this.T.isEmpty()) { + System.out.println(this.T.size()); } + } - if (arraylist == null) { - arraylist = new ArrayList(); - } + while (iterator.hasNext()) { + NextTickListEntry nextticklistentry = (NextTickListEntry) iterator.next(); - arraylist.add(nextticklistentry); + if (nextticklistentry.a >= i && nextticklistentry.a < j && nextticklistentry.c >= k && nextticklistentry.c < l) { + if (flag) { + this.L.remove(nextticklistentry); + iterator.remove(); + } + + if (arraylist == null) { + arraylist = new ArrayList(); + } + + arraylist.add(nextticklistentry); + } } } @@ -593,15 +639,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } public boolean a(EntityHuman entityhuman, int i, int j, int k) { - int l = MathHelper.a(i - this.worldData.c()); - int i1 = MathHelper.a(k - this.worldData.e()); - - if (l > i1) { - i1 = l; - } - - // CraftBukkit - Configurable spawn protection - return i1 > this.getServer().getSpawnRadius() || this.server.getPlayerList().isOp(entityhuman.name) || this.server.I(); + return !this.server.a(this, i, j, k, entityhuman); } protected void a(WorldSettings worldsettings) { @@ -655,7 +693,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate i = chunkposition.x; k = chunkposition.z; } else { - System.out.println("Unable to find spawn biome"); + this.getLogger().warning("Unable to find spawn biome"); } int l = 0; @@ -711,7 +749,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void a() throws ExceptionWorldConflict { // CraftBukkit - added throws - this.D(); + this.E(); this.dataManager.saveWorldData(this.worldData, this.server.getPlayerList().q()); this.worldMaps.a(); } @@ -719,7 +757,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate protected void a(Entity entity) { super.a(entity); this.entitiesById.a(entity.id, entity); - Entity[] aentity = entity.ao(); + Entity[] aentity = entity.an(); if (aentity != null) { for (int i = 0; i < aentity.length; ++i) { @@ -731,7 +769,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate protected void b(Entity entity) { super.b(entity); this.entitiesById.d(entity.id); - Entity[] aentity = entity.ao(); + Entity[] aentity = entity.an(); if (aentity != null) { for (int i = 0; i < aentity.length; ++i) { @@ -818,7 +856,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } - private void V() { + private void Y() { while (!this.Q[this.R].isEmpty()) { int i = this.R; @@ -841,12 +879,7 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate private boolean a(NoteBlockData noteblockdata) { int i = this.getTypeId(noteblockdata.a(), noteblockdata.b(), noteblockdata.c()); - if (i == noteblockdata.f()) { - Block.byId[i].b(this, noteblockdata.a(), noteblockdata.b(), noteblockdata.c(), noteblockdata.d(), noteblockdata.e()); - return true; - } else { - return false; - } + return i == noteblockdata.f() ? Block.byId[i].b(this, noteblockdata.a(), noteblockdata.b(), noteblockdata.c(), noteblockdata.d(), noteblockdata.e()) : false; } public void saveLevel() { @@ -854,10 +887,10 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate } protected void n() { - boolean flag = this.N(); + boolean flag = this.O(); super.n(); - if (flag != this.N()) { + if (flag != this.O()) { // CraftBukkit start - only sending weather packets to those affected for (int i = 0; i < this.players.size(); ++i) { if (((EntityPlayer) this.players.get(i)).world == this) { @@ -883,4 +916,22 @@ public class WorldServer extends World implements org.bukkit.BlockChangeDelegate public PortalTravelAgent s() { return this.P; } + + // CraftBukkit start - Compatibility methods for BlockChangeDelegate + public boolean setRawTypeId(int x, int y, int z, int typeId) { + return this.setTypeIdAndData(x, y, z, typeId, 0, 4); + } + + public boolean setRawTypeIdAndData(int x, int y, int z, int typeId, int data) { + return this.setTypeIdAndData(x, y, z, typeId, data, 4); + } + + public boolean setTypeId(int x, int y, int z, int typeId) { + return this.setTypeIdAndData(x, y, z, typeId, 0, 3); + } + + public boolean setTypeIdAndData(int x, int y, int z, int typeId, int data) { + return this.setTypeIdAndData(x, y, z, typeId, data, 3); + } + // CraftBukkit end } |