diff --git a/paper-api/src/main/java/org/bukkit/Material.java b/paper-api/src/main/java/org/bukkit/Material.java
index 9321f8e11d..3230f6d8a5 100644
--- a/paper-api/src/main/java/org/bukkit/Material.java
+++ b/paper-api/src/main/java/org/bukkit/Material.java
@@ -255,12 +255,12 @@ public enum Material {
BIRCH_FENCE(189),
JUNGLE_FENCE(190),
DARK_OAK_FENCE(191),
- ACACIA_FENCE(192),
- SPRUCE_DOOR(193),
- BIRCH_DOOR(194),
- JUNGLE_DOOR(195),
- ACACIA_DOOR(196),
- DARK_OAK_DOOR(197),
+ ACACIA_FENCE(192, Door.class),
+ SPRUCE_DOOR(193, Door.class),
+ BIRCH_DOOR(194, Door.class),
+ JUNGLE_DOOR(195, Door.class),
+ ACACIA_DOOR(196, Door.class),
+ DARK_OAK_DOOR(197, Door.class),
// ----- Item Separator -----
IRON_SPADE(256, 1, 250),
IRON_PICKAXE(257, 1, 250),
diff --git a/paper-api/src/main/java/org/bukkit/material/Door.java b/paper-api/src/main/java/org/bukkit/material/Door.java
index 0c5b52f0c3..27bb6814e2 100644
--- a/paper-api/src/main/java/org/bukkit/material/Door.java
+++ b/paper-api/src/main/java/org/bukkit/material/Door.java
@@ -6,10 +6,19 @@ import org.bukkit.block.BlockFace;
/**
* Represents a door.
*
- * @deprecated No longer functions. Do not use.
+ * This class was previously deprecated, but has been retrofitted to
+ * work with modern doors. Some methods are undefined dependant on isTopHalf()
+ * due to Minecraft's internal representation of doors.
*/
-@Deprecated
public class Door extends MaterialData implements Directional, Openable {
+
+ // This class breaks API contracts on Directional and Openable because
+ // of the way doors are currently implemented. Beware!
+
+ /**
+ * @deprecated Artifact of old API, equivalent to new Door(Material.WOODEN_DOOR);
+ */
+ @Deprecated
public Door() {
super(Material.WOODEN_DOOR);
}
@@ -48,17 +57,15 @@ public class Door extends MaterialData implements Directional, Openable {
}
/**
- * @deprecated Does not work (correctly) anymore
+ * Result is undefined if isTopHalf()
is true.
*/
- @Deprecated
public boolean isOpen() {
return ((getData() & 0x4) == 0x4);
}
/**
- * @deprecated Does not work (correctly) anymore
+ * Set whether the door is open. Undefined if isTopHalf()
is true.
*/
- @Deprecated
public void setOpen(boolean isOpen) {
setData((byte) (isOpen ? (getData() | 0x4) : (getData() & ~0x4)));
}
@@ -74,30 +81,18 @@ public class Door extends MaterialData implements Directional, Openable {
* Configure this part of the door to be either the top or the bottom half
*
* @param isTopHalf True to make it the top half.
- * @deprecated Shouldn't be used anymore
*/
- @Deprecated
public void setTopHalf(boolean isTopHalf) {
setData((byte) (isTopHalf ? (getData() | 0x8) : (getData() & ~0x8)));
}
/**
* @return BlockFace.SELF
- * @deprecated Does not work (correctly) anymore
+ * @deprecated This method should not be used; use hinge and facing accessors instead.
*/
@Deprecated
public BlockFace getHingeCorner() {
- byte d = getData();
-
- if ((d & 0x3) == 0x3) {
- return BlockFace.NORTH_WEST;
- } else if ((d & 0x1) == 0x1) {
- return BlockFace.SOUTH_EAST;
- } else if ((d & 0x2) == 0x2) {
- return BlockFace.SOUTH_WEST;
- }
-
- return BlockFace.NORTH_EAST;
+ return BlockFace.SELF;
}
@Override
@@ -108,13 +103,17 @@ public class Door extends MaterialData implements Directional, Openable {
/**
* Set the direction that this door should is facing.
*
+ * Undefined if isTopHalf()
is true.
+ *
* @param face the direction
- * @deprecated Does not work (correctly) anymore
*/
- @Deprecated
public void setFacingDirection(BlockFace face) {
byte data = (byte) (getData() & 0x12);
switch (face) {
+ case WEST:
+ data |= 0x0;
+ break;
+
case NORTH:
data |= 0x1;
break;
@@ -133,10 +132,10 @@ public class Door extends MaterialData implements Directional, Openable {
/**
* Get the direction that this door is facing.
*
+ * Undefined if isTopHalf()
is true.
+ *
* @return the direction
- * @deprecated Does not work (correctly) anymore
*/
- @Deprecated
public BlockFace getFacing() {
byte data = (byte) (getData() & 0x3);
switch (data) {
@@ -155,6 +154,26 @@ public class Door extends MaterialData implements Directional, Openable {
return null; // shouldn't happen
}
+ /**
+ * Returns the side of the door the hinge is on.
+ *
+ * Undefined if isTopHalf()
is false.
+ *
+ * @return false for left hinge, true for right hinge
+ */
+ public boolean getHinge() {
+ return (getData() & 0x1) == 1;
+ }
+
+ /**
+ * Set whether the hinge is on the left or right side. Left is false, right is true.
+ *
+ * Undefined if isTopHalf()
is false.
+ */
+ public void setHinge(boolean hinge) {
+ setData((byte) (hinge ? (getData() | 0x1) : (getData() & ~0x1)));
+ }
+
@Override
public Door clone() {
return (Door) super.clone();