summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/BlockBed.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockBed.java')
-rw-r--r--src/main/java/net/minecraft/server/BlockBed.java203
1 files changed, 0 insertions, 203 deletions
diff --git a/src/main/java/net/minecraft/server/BlockBed.java b/src/main/java/net/minecraft/server/BlockBed.java
deleted file mode 100644
index 7558dce7..00000000
--- a/src/main/java/net/minecraft/server/BlockBed.java
+++ /dev/null
@@ -1,203 +0,0 @@
-package net.minecraft.server;
-
-import java.util.Iterator;
-import java.util.Random;
-
-public class BlockBed extends BlockDirectional {
-
- public static final int[][] a = new int[][] { { 0, 1}, { -1, 0}, { 0, -1}, { 1, 0}};
-
- public BlockBed(int i) {
- super(i, 134, Material.CLOTH);
- this.t();
- }
-
- public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman) {
- if (world.isStatic) {
- return true;
- } else {
- int l = world.getData(i, j, k);
-
- if (!d(l)) {
- int i1 = b(l);
-
- i += a[i1][0];
- k += a[i1][1];
- if (world.getTypeId(i, j, k) != this.id) {
- return true;
- }
-
- l = world.getData(i, j, k);
- }
-
- if (!world.worldProvider.c()) {
- double d0 = (double) i + 0.5D;
- double d1 = (double) j + 0.5D;
- double d2 = (double) k + 0.5D;
-
- world.setTypeId(i, j, k, 0);
- int j1 = b(l);
-
- i += a[j1][0];
- k += a[j1][1];
- if (world.getTypeId(i, j, k) == this.id) {
- world.setTypeId(i, j, k, 0);
- d0 = (d0 + (double) i + 0.5D) / 2.0D;
- d1 = (d1 + (double) j + 0.5D) / 2.0D;
- d2 = (d2 + (double) k + 0.5D) / 2.0D;
- }
-
- world.createExplosion((Entity) null, (double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), 5.0F, true);
- return true;
- } else {
- if (e(l)) {
- EntityHuman entityhuman1 = null;
- Iterator iterator = world.players.iterator();
-
- while (iterator.hasNext()) {
- EntityHuman entityhuman2 = (EntityHuman) iterator.next();
-
- if (entityhuman2.isSleeping()) {
- ChunkCoordinates chunkcoordinates = entityhuman2.F;
-
- if (chunkcoordinates.x == i && chunkcoordinates.y == j && chunkcoordinates.z == k) {
- entityhuman1 = entityhuman2;
- }
- }
- }
-
- if (entityhuman1 != null) {
- entityhuman.a("tile.bed.occupied");
- return true;
- }
-
- a(world, i, j, k, false);
- }
-
- EnumBedResult enumbedresult = entityhuman.a(i, j, k);
-
- if (enumbedresult == EnumBedResult.OK) {
- a(world, i, j, k, true);
- return true;
- } else {
- if (enumbedresult == EnumBedResult.NOT_POSSIBLE_NOW) {
- entityhuman.a("tile.bed.noSleep");
- } else if (enumbedresult == EnumBedResult.NOT_SAFE) {
- entityhuman.a("tile.bed.notSafe");
- }
-
- return true;
- }
- }
- }
- }
-
- public int a(int i, int j) {
- if (i == 0) {
- return Block.WOOD.textureId;
- } else {
- int k = b(j);
- int l = Direction.h[k][i];
-
- return d(j) ? (l == 2 ? this.textureId + 2 + 16 : (l != 5 && l != 4 ? this.textureId + 1 : this.textureId + 1 + 16)) : (l == 3 ? this.textureId - 1 + 16 : (l != 5 && l != 4 ? this.textureId : this.textureId + 16));
- }
- }
-
- public int c() {
- return 14;
- }
-
- public boolean b() {
- return false;
- }
-
- public boolean a() {
- return false;
- }
-
- public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) {
- this.t();
- }
-
- public void doPhysics(World world, int i, int j, int k, int l) {
- int i1 = world.getData(i, j, k);
- int j1 = b(i1);
-
- if (d(i1)) {
- if (world.getTypeId(i - a[j1][0], j, k - a[j1][1]) != this.id) {
- world.setTypeId(i, j, k, 0);
- }
- } else if (world.getTypeId(i + a[j1][0], j, k + a[j1][1]) != this.id) {
- world.setTypeId(i, j, k, 0);
- /* CraftBukkit - Move this to on break instead of on physics
- if (!world.isStatic) {
- this.b(world, i, j, k, i1, 0);
- }
- // */
- }
- }
-
- public int getDropType(int i, Random random, int j) {
- return /* d(i) ? 0 CraftBukkit : */ Item.BED.id;
- }
-
- private void t() {
- this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.5625F, 1.0F);
- }
-
- public static boolean d(int i) {
- return (i & 8) != 0;
- }
-
- public static boolean e(int i) {
- return (i & 4) != 0;
- }
-
- public static void a(World world, int i, int j, int k, boolean flag) {
- int l = world.getData(i, j, k);
-
- if (flag) {
- l |= 4;
- } else {
- l &= -5;
- }
-
- world.setData(i, j, k, l);
- }
-
- public static ChunkCoordinates f(World world, int i, int j, int k, int l) {
- int i1 = world.getData(i, j, k);
- int j1 = BlockDirectional.b(i1);
-
- for (int k1 = 0; k1 <= 1; ++k1) {
- int l1 = i - a[j1][0] * k1 - 1;
- int i2 = k - a[j1][1] * k1 - 1;
- int j2 = l1 + 2;
- int k2 = i2 + 2;
-
- for (int l2 = l1; l2 <= j2; ++l2) {
- for (int i3 = i2; i3 <= k2; ++i3) {
- if (world.e(l2, j - 1, i3) && world.isEmpty(l2, j, i3) && world.isEmpty(l2, j + 1, i3)) {
- if (l <= 0) {
- return new ChunkCoordinates(l2, j, i3);
- }
-
- --l;
- }
- }
- }
- }
-
- return null;
- }
-
- public void dropNaturally(World world, int i, int j, int k, int l, float f, int i1) {
- //if (!d(l)) { // CraftBukkit
- super.dropNaturally(world, i, j, k, l, f, 0);
- // } // CraftBukkit
- }
-
- public int g() {
- return 1;
- }
-}