summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/PlayerInstance.java
diff options
context:
space:
mode:
authorDinnerbone <dinnerbone@dinnerbone.com>2011-02-05 18:15:04 +0000
committerDinnerbone <dinnerbone@dinnerbone.com>2011-02-07 01:44:43 +0000
commit2be5181b0c721baf520a372350693377c261dd37 (patch)
tree790918614919ce0dd2801ceffadc43ebf9c7a141 /src/main/java/net/minecraft/server/PlayerInstance.java
parent9e7991ab528cfc195200e342cd022ab3f63de3f6 (diff)
downloadcraftbukkit-2be5181b0c721baf520a372350693377c261dd37.tar
craftbukkit-2be5181b0c721baf520a372350693377c261dd37.tar.gz
craftbukkit-2be5181b0c721baf520a372350693377c261dd37.tar.lz
craftbukkit-2be5181b0c721baf520a372350693377c261dd37.tar.xz
craftbukkit-2be5181b0c721baf520a372350693377c261dd37.zip
Added internal MC support for multiple worlds
Diffstat (limited to 'src/main/java/net/minecraft/server/PlayerInstance.java')
-rw-r--r--src/main/java/net/minecraft/server/PlayerInstance.java190
1 files changed, 190 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/PlayerInstance.java b/src/main/java/net/minecraft/server/PlayerInstance.java
new file mode 100644
index 00000000..23443e03
--- /dev/null
+++ b/src/main/java/net/minecraft/server/PlayerInstance.java
@@ -0,0 +1,190 @@
+package net.minecraft.server;
+
+import java.util.ArrayList;
+import java.util.List;
+
+class PlayerInstance {
+
+ private List b;
+ private int c;
+ private int d;
+ private ChunkCoordIntPair e;
+ private short[] f;
+ private int g;
+ private int h;
+ private int i;
+ private int j;
+ private int k;
+ private int l;
+ private int m;
+ private WorldServer world; // Craftbukkit
+
+ final PlayerManager a;
+
+ // Craftbukkit - this method signature is changed.
+ public PlayerInstance(PlayerManager playermanager, int i, int j, WorldServer world) {
+ this.a = playermanager;
+ this.b = new ArrayList();
+ this.f = new short[10];
+ this.g = 0;
+ this.c = i;
+ this.d = j;
+ this.e = new ChunkCoordIntPair(i, j);
+
+ // Craftbukkit start
+ this.world = world;
+ world.A.d(i, j);
+ // Craftbukkit end
+ }
+
+ public void a(EntityPlayer entityplayer) {
+ if (this.b.contains(entityplayer)) {
+ throw new IllegalStateException("Failed to add player. " + entityplayer + " already is in chunk " + this.c + ", " + this.d);
+ } else {
+ entityplayer.ak.add(this.e);
+ entityplayer.a.b((Packet) (new Packet50PreChunk(this.e.a, this.e.b, true)));
+ this.b.add(entityplayer);
+ entityplayer.f.add(this.e);
+ }
+ }
+
+ public void b(EntityPlayer entityplayer) {
+ if (!this.b.contains(entityplayer)) {
+ (new IllegalStateException("Failed to remove player. " + entityplayer + " isn\'t in chunk " + this.c + ", " + this.d)).printStackTrace();
+ } else {
+ this.b.remove(entityplayer);
+ if (this.b.size() == 0) {
+ long i = (long) this.c + 2147483647L | (long) this.d + 2147483647L << 32;
+
+ PlayerManager.b(this.a).b(i);
+ if (this.g > 0) {
+ PlayerManager.c(this.a).remove(this);
+ }
+
+ ((WorldServer)entityplayer.world).A.c(this.c, this.d); // Craftbukkit
+ }
+
+ entityplayer.f.remove(this.e);
+ if (entityplayer.ak.contains(this.e)) {
+ entityplayer.a.b((Packet) (new Packet50PreChunk(this.c, this.d, false)));
+ }
+ }
+ }
+
+ public void a(int i, int j, int k) {
+ if (this.g == 0) {
+ PlayerManager.c(this.a).add(this);
+ this.h = this.i = i;
+ this.j = this.k = j;
+ this.l = this.m = k;
+ }
+
+ if (this.h > i) {
+ this.h = i;
+ }
+
+ if (this.i < i) {
+ this.i = i;
+ }
+
+ if (this.j > j) {
+ this.j = j;
+ }
+
+ if (this.k < j) {
+ this.k = j;
+ }
+
+ if (this.l > k) {
+ this.l = k;
+ }
+
+ if (this.m < k) {
+ this.m = k;
+ }
+
+ if (this.g < 10) {
+ short short1 = (short) (i << 12 | k << 8 | j);
+
+ for (int l = 0; l < this.g; ++l) {
+ if (this.f[l] == short1) {
+ return;
+ }
+ }
+
+ this.f[this.g++] = short1;
+ }
+ }
+
+ public void a(Packet packet) {
+ for (int i = 0; i < this.b.size(); ++i) {
+ EntityPlayer entityplayer = (EntityPlayer) this.b.get(i);
+
+ if (entityplayer.ak.contains(this.e)) {
+ entityplayer.a.b(packet);
+ }
+ }
+ }
+
+ public void a() {
+ if (this.g != 0) {
+ int i;
+ int j;
+ int k;
+
+ if (this.g == 1) {
+ i = this.c * 16 + this.h;
+ j = this.j;
+ k = this.d * 16 + this.l;
+ this.a((Packet) (new Packet53BlockChange(i, j, k, world))); // Craftbukkit
+ if (Block.p[world.getTypeId(i, j, k)]) { // Craftbukkit
+ this.a(world.getTileEntity(i, j, k)); // Craftbukkit
+ }
+ } else {
+ int l;
+
+ if (this.g == 10) {
+ this.j = this.j / 2 * 2;
+ this.k = (this.k / 2 + 1) * 2;
+ i = this.h + this.c * 16;
+ j = this.j;
+ k = this.l + this.d * 16;
+ l = this.i - this.h + 1;
+ int i1 = this.k - this.j + 2;
+ int j1 = this.m - this.l + 1;
+
+ this.a((Packet) (new Packet51MapChunk(i, j, k, l, i1, j1, world))); // Craftbukkit
+ List list = world.d(i, j, k, i + l, j + i1, k + j1); // Craftbukkit
+
+ for (int k1 = 0; k1 < list.size(); ++k1) {
+ this.a((TileEntity) list.get(k1));
+ }
+ } else {
+ this.a((Packet) (new Packet52MultiBlockChange(this.c, this.d, this.f, this.g, world))); // Craftbukkit
+
+ for (i = 0; i < this.g; ++i) {
+ j = this.c * 16 + (this.g >> 12 & 15);
+ k = this.g & 255;
+ l = this.d * 16 + (this.g >> 8 & 15);
+ if (Block.p[world.getTypeId(j, k, l)]) { // Craftbukkit
+ System.out.println("Sending!");
+ this.a(world.getTileEntity(j, k, l)); // Craftbukkit
+ }
+ }
+ }
+ }
+
+ this.g = 0;
+ }
+ }
+
+ private void a(TileEntity tileentity) {
+ if (tileentity != null) {
+ Packet packet = tileentity.g();
+
+ if (packet != null) {
+ this.a(packet);
+ }
+ }
+ }
+}