mirror of
https://github.com/PaperMC/Paper.git
synced 2025-08-17 05:03:55 -07:00
Update to Minecraft Server 1.2
This commit is contained in:
@@ -30,8 +30,10 @@ public class BlockLeaves extends BlockLeavesBase {
|
||||
for (int l1 = -l; l1 <= l; l1++) {
|
||||
int i2 = world.a(i + j1, j + k1, k + l1);
|
||||
|
||||
if (i2 == Block.K.bh) {
|
||||
world.c(i + j1, j + k1, k + l1, 7);
|
||||
if (i2 == Block.K.bi) {
|
||||
int j2 = world.b(i + j1, j + k1, k + l1);
|
||||
|
||||
world.d(i + j1, j + k1, k + l1, j2 | 4);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -43,69 +45,71 @@ public class BlockLeaves extends BlockLeavesBase {
|
||||
if (world.z) {
|
||||
return;
|
||||
}
|
||||
if (world.b(i, j, k) == 7) {
|
||||
int l = world.b(i, j, k);
|
||||
|
||||
if ((l & 4) != 0) {
|
||||
byte byte0 = 4;
|
||||
int l = byte0 + 1;
|
||||
int i1 = byte0 + 1;
|
||||
byte byte1 = 32;
|
||||
int i1 = byte1 * byte1;
|
||||
int j1 = byte1 / 2;
|
||||
int j1 = byte1 * byte1;
|
||||
int k1 = byte1 / 2;
|
||||
|
||||
if (b == null) {
|
||||
b = new int[byte1 * byte1 * byte1];
|
||||
}
|
||||
if (world.a(i - l, j - l, k - l, i + l, j + l, k + l)) {
|
||||
for (int k1 = -byte0; k1 <= byte0; k1++) {
|
||||
for (int j2 = -byte0; j2 <= byte0; j2++) {
|
||||
for (int l2 = -byte0; l2 <= byte0; l2++) {
|
||||
int j3 = world.a(i + k1, j + j2, k + l2);
|
||||
if (world.a(i - i1, j - i1, k - i1, i + i1, j + i1, k + i1)) {
|
||||
for (int l1 = -byte0; l1 <= byte0; l1++) {
|
||||
for (int k2 = -byte0; k2 <= byte0; k2++) {
|
||||
for (int i3 = -byte0; i3 <= byte0; i3++) {
|
||||
int k3 = world.a(i + l1, j + k2, k + i3);
|
||||
|
||||
if (j3 == Block.J.bh) {
|
||||
b[(k1 + j1) * i1 + (j2 + j1) * byte1 + (l2 + j1)] = 0;
|
||||
if (k3 == Block.J.bi) {
|
||||
b[(l1 + k1) * j1 + (k2 + k1) * byte1 + (i3 + k1)] = 0;
|
||||
continue;
|
||||
}
|
||||
if (j3 == Block.K.bh) {
|
||||
b[(k1 + j1) * i1 + (j2 + j1) * byte1 + (l2 + j1)] = -2;
|
||||
if (k3 == Block.K.bi) {
|
||||
b[(l1 + k1) * j1 + (k2 + k1) * byte1 + (i3 + k1)] = -2;
|
||||
} else {
|
||||
b[(k1 + j1) * i1 + (j2 + j1) * byte1 + (l2 + j1)] = -1;
|
||||
b[(l1 + k1) * j1 + (k2 + k1) * byte1 + (i3 + k1)] = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
for (int l1 = 1; l1 <= 4; l1++) {
|
||||
for (int k2 = -byte0; k2 <= byte0; k2++) {
|
||||
for (int i3 = -byte0; i3 <= byte0; i3++) {
|
||||
for (int k3 = -byte0; k3 <= byte0; k3++) {
|
||||
if (b[(k2 + j1) * i1 + (i3 + j1) * byte1 + (k3 + j1)] != l1 - 1) {
|
||||
for (int i2 = 1; i2 <= 4; i2++) {
|
||||
for (int l2 = -byte0; l2 <= byte0; l2++) {
|
||||
for (int j3 = -byte0; j3 <= byte0; j3++) {
|
||||
for (int l3 = -byte0; l3 <= byte0; l3++) {
|
||||
if (b[(l2 + k1) * j1 + (j3 + k1) * byte1 + (l3 + k1)] != i2 - 1) {
|
||||
continue;
|
||||
}
|
||||
if (b[((k2 + j1) - 1) * i1 + (i3 + j1) * byte1 + (k3 + j1)] == -2) {
|
||||
b[((k2 + j1) - 1) * i1 + (i3 + j1) * byte1 + (k3 + j1)] = l1;
|
||||
if (b[((l2 + k1) - 1) * j1 + (j3 + k1) * byte1 + (l3 + k1)] == -2) {
|
||||
b[((l2 + k1) - 1) * j1 + (j3 + k1) * byte1 + (l3 + k1)] = i2;
|
||||
}
|
||||
if (b[(k2 + j1 + 1) * i1 + (i3 + j1) * byte1 + (k3 + j1)] == -2) {
|
||||
b[(k2 + j1 + 1) * i1 + (i3 + j1) * byte1 + (k3 + j1)] = l1;
|
||||
if (b[(l2 + k1 + 1) * j1 + (j3 + k1) * byte1 + (l3 + k1)] == -2) {
|
||||
b[(l2 + k1 + 1) * j1 + (j3 + k1) * byte1 + (l3 + k1)] = i2;
|
||||
}
|
||||
if (b[(k2 + j1) * i1 + ((i3 + j1) - 1) * byte1 + (k3 + j1)] == -2) {
|
||||
b[(k2 + j1) * i1 + ((i3 + j1) - 1) * byte1 + (k3 + j1)] = l1;
|
||||
if (b[(l2 + k1) * j1 + ((j3 + k1) - 1) * byte1 + (l3 + k1)] == -2) {
|
||||
b[(l2 + k1) * j1 + ((j3 + k1) - 1) * byte1 + (l3 + k1)] = i2;
|
||||
}
|
||||
if (b[(k2 + j1) * i1 + (i3 + j1 + 1) * byte1 + (k3 + j1)] == -2) {
|
||||
b[(k2 + j1) * i1 + (i3 + j1 + 1) * byte1 + (k3 + j1)] = l1;
|
||||
if (b[(l2 + k1) * j1 + (j3 + k1 + 1) * byte1 + (l3 + k1)] == -2) {
|
||||
b[(l2 + k1) * j1 + (j3 + k1 + 1) * byte1 + (l3 + k1)] = i2;
|
||||
}
|
||||
if (b[(k2 + j1) * i1 + (i3 + j1) * byte1 + ((k3 + j1) - 1)] == -2) {
|
||||
b[(k2 + j1) * i1 + (i3 + j1) * byte1 + ((k3 + j1) - 1)] = l1;
|
||||
if (b[(l2 + k1) * j1 + (j3 + k1) * byte1 + ((l3 + k1) - 1)] == -2) {
|
||||
b[(l2 + k1) * j1 + (j3 + k1) * byte1 + ((l3 + k1) - 1)] = i2;
|
||||
}
|
||||
if (b[(k2 + j1) * i1 + (i3 + j1) * byte1 + (k3 + j1 + 1)] == -2) {
|
||||
b[(k2 + j1) * i1 + (i3 + j1) * byte1 + (k3 + j1 + 1)] = l1;
|
||||
if (b[(l2 + k1) * j1 + (j3 + k1) * byte1 + (l3 + k1 + 1)] == -2) {
|
||||
b[(l2 + k1) * j1 + (j3 + k1) * byte1 + (l3 + k1 + 1)] = i2;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
int i2 = b[j1 * i1 + j1 * byte1 + j1];
|
||||
int j2 = b[k1 * j1 + k1 * byte1 + k1];
|
||||
|
||||
if (i2 >= 0) {
|
||||
world.b(i, j, k, 0);
|
||||
if (j2 >= 0) {
|
||||
world.c(i, j, k, l & -5);
|
||||
} else {
|
||||
g(world, i, j, k);
|
||||
}
|
||||
@@ -123,7 +127,7 @@ public class BlockLeaves extends BlockLeavesBase {
|
||||
// CraftBukkit end
|
||||
|
||||
a_(world, i, j, k, world.b(i, j, k));
|
||||
world.d(i, j, k, 0);
|
||||
world.e(i, j, k, 0);
|
||||
}
|
||||
|
||||
public int a(Random random) {
|
||||
@@ -131,7 +135,7 @@ public class BlockLeaves extends BlockLeavesBase {
|
||||
}
|
||||
|
||||
public int a(int i, Random random) {
|
||||
return Block.y.bh;
|
||||
return Block.y.bi;
|
||||
}
|
||||
|
||||
public boolean a() {
|
||||
|
Reference in New Issue
Block a user