Newer
Older
ultramine_bukkit / src / main / java / org / bukkit / material / Door.java
@vlad20012 vlad20012 on 24 Feb 2017 2 KB initial
package org.bukkit.material;

import org.bukkit.Material;
import org.bukkit.block.BlockFace;

/**
 * Represents a door.
 *
 * @deprecated No longer functions. Do not use.
 */
@Deprecated
public class Door extends MaterialData implements Directional, Openable
{
	public Door()
	{
		super(Material.WOODEN_DOOR);
	}

	/**
	 * @deprecated Magic value
	 */
	@Deprecated
	public Door(final int type)
	{
		super(type);
	}

	public Door(final Material type)
	{
		super(type);
	}

	/**
	 * @deprecated Magic value
	 */
	@Deprecated
	public Door(final int type, final byte data)
	{
		super(type, data);
	}

	/**
	 * @deprecated Magic value
	 */
	@Deprecated
	public Door(final Material type, final byte data)
	{
		super(type, data);
	}

	/**
	 * @deprecated Does not work (correctly) anymore
	 */
	@Deprecated
	public boolean isOpen()
	{
		return ((getData() & 0x4) == 0x4);
	}

	/**
	 * @deprecated Does not work (correctly) anymore
	 */
	@Deprecated
	public void setOpen(boolean isOpen)
	{
		setData((byte) (isOpen ? (getData() | 0x4) : (getData() & ~0x4)));
	}

	/**
	 * @return whether this is the top half of the door
	 */
	public boolean isTopHalf()
	{
		return ((getData() & 0x8) == 0x8);
	}

	/**
	 * 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
	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;
	}

	@Override
	public String toString()
	{
		return (isTopHalf() ? "TOP" : "BOTTOM") + " half of " + super.toString();
	}

	/**
	 * Set the direction that this door should is facing.
	 *
	 * @param face the direction
	 * @deprecated Does not work (correctly) anymore
	 */
	@Deprecated
	public void setFacingDirection(BlockFace face)
	{
		byte data = (byte) (getData() & 0x12);
		switch(face)
		{
		case NORTH:
			data |= 0x1;
			break;

		case EAST:
			data |= 0x2;
			break;

		case SOUTH:
			data |= 0x3;
			break;
		}
		setData(data);
	}

	/**
	 * Get the direction that this door is facing.
	 *
	 * @return the direction
	 * @deprecated Does not work (correctly) anymore
	 */
	@Deprecated
	public BlockFace getFacing()
	{
		byte data = (byte) (getData() & 0x3);
		switch(data)
		{
		case 0:
			return BlockFace.WEST;

		case 1:
			return BlockFace.NORTH;

		case 2:
			return BlockFace.EAST;

		case 3:
			return BlockFace.SOUTH;
		}
		return null; // shouldn't happen
	}

	@Override
	public Door clone()
	{
		return (Door) super.clone();
	}
}