summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWesley Wolfe <weswolf@aol.com>2012-08-17 14:33:23 -0500
committerWesley Wolfe <weswolf@aol.com>2012-08-17 14:33:23 -0500
commit6bbeb931031c934cbb6b095e3d52750e7218d381 (patch)
tree06e7fb3ae0a1a8642b089634c865f33e5c3b1674
parent11fd4acb565ead02c802ec1f42a33a9715e837dc (diff)
downloadbukkit-6bbeb931031c934cbb6b095e3d52750e7218d381.tar
bukkit-6bbeb931031c934cbb6b095e3d52750e7218d381.tar.gz
bukkit-6bbeb931031c934cbb6b095e3d52750e7218d381.tar.lz
bukkit-6bbeb931031c934cbb6b095e3d52750e7218d381.tar.xz
bukkit-6bbeb931031c934cbb6b095e3d52750e7218d381.zip
Let TripwireHook be attachable. Addresses BUKKIT-2278
This commit also makes TripwireHook consistent with other attachables for the facing property.
-rw-r--r--src/main/java/org/bukkit/material/TripwireHook.java59
1 files changed, 29 insertions, 30 deletions
diff --git a/src/main/java/org/bukkit/material/TripwireHook.java b/src/main/java/org/bukkit/material/TripwireHook.java
index 58b8711b..9f8e13d3 100644
--- a/src/main/java/org/bukkit/material/TripwireHook.java
+++ b/src/main/java/org/bukkit/material/TripwireHook.java
@@ -6,8 +6,8 @@ import org.bukkit.block.BlockFace;
/**
* Represents the tripwire hook
*/
-public class TripwireHook extends MaterialData implements Directional, Redstone {
-
+public class TripwireHook extends SimpleAttachableMaterialData implements Redstone {
+
public TripwireHook() {
super(Material.TRIPWIRE_HOOK);
}
@@ -19,12 +19,12 @@ public class TripwireHook extends MaterialData implements Directional, Redstone
public TripwireHook(final int type, final byte data) {
super(type, data);
}
-
+
public TripwireHook(BlockFace dir) {
this();
setFacingDirection(dir);
}
-
+
/**
* Test if tripwire is connected
* @return true if connected, false if not
@@ -32,7 +32,7 @@ public class TripwireHook extends MaterialData implements Directional, Redstone
public boolean isConnected() {
return (getData() & 0x4) != 0;
}
-
+
/**
* Set tripwire connection state
* @param connected - true if connected, false if not
@@ -52,7 +52,7 @@ public class TripwireHook extends MaterialData implements Directional, Redstone
public boolean isActivated() {
return (getData() & 0x8) != 0;
}
-
+
/**
* Set hook activated state
* @param act - true if activated, false if not
@@ -64,41 +64,40 @@ public class TripwireHook extends MaterialData implements Directional, Redstone
}
setData((byte) dat);
}
-
+
public void setFacingDirection(BlockFace face) {
int dat = getData() & 0xC;
switch (face) {
- case EAST:
- break;
- case SOUTH:
- dat |= 0x1;
- break;
- case WEST:
- dat |= 0x2;
- break;
- case NORTH:
- dat |= 0x3;
- break;
- default:
- break;
+ case NORTH:
+ dat |= 0x1;
+ break;
+ case EAST:
+ dat |= 0x2;
+ break;
+ case SOUTH:
+ dat |= 0x3;
+ break;
+ case WEST:
+ default:
+ break;
}
setData((byte) dat);
}
- public BlockFace getFacing() {
+ public BlockFace getAttachedFace() {
switch (getData() & 0x3) {
- case 0:
- return BlockFace.EAST;
- case 1:
- return BlockFace.SOUTH;
- case 2:
- return BlockFace.WEST;
- case 3:
- return BlockFace.NORTH;
+ case 0:
+ return BlockFace.EAST;
+ case 1:
+ return BlockFace.SOUTH;
+ case 2:
+ return BlockFace.WEST;
+ case 3:
+ return BlockFace.NORTH;
}
return null;
}
-
+
public boolean isPowered() {
return isActivated();
}