Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
3115637
commit 640143a
Showing
4 changed files
with
185 additions
and
120 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
117 changes: 0 additions & 117 deletions
117
.../src/main/java/com/denizenscript/denizen/objects/properties/material/MaterialHeights.java
This file was deleted.
Oops, something went wrong.
173 changes: 173 additions & 0 deletions
173
...in/src/main/java/com/denizenscript/denizen/objects/properties/material/MaterialSides.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,173 @@ | ||
package com.denizenscript.denizen.objects.properties.material; | ||
|
||
import com.denizenscript.denizen.objects.MaterialTag; | ||
import com.denizenscript.denizencore.objects.Mechanism; | ||
import com.denizenscript.denizencore.objects.ObjectTag; | ||
import com.denizenscript.denizencore.objects.core.ListTag; | ||
import com.denizenscript.denizencore.objects.properties.Property; | ||
import com.denizenscript.denizencore.objects.properties.PropertyParser; | ||
import org.bukkit.block.BlockFace; | ||
import org.bukkit.block.data.*; | ||
import org.bukkit.block.data.type.RedstoneWire; | ||
import org.bukkit.block.data.type.Wall; | ||
|
||
public class MaterialSides implements Property { | ||
|
||
public static boolean describes(ObjectTag material) { | ||
if (!(material instanceof MaterialTag)) { | ||
return false; | ||
} | ||
MaterialTag mat = (MaterialTag) material; | ||
if (!mat.hasModernData()) { | ||
return false; | ||
} | ||
BlockData data = mat.getModernData(); | ||
if (!(data instanceof Wall) && !(data instanceof RedstoneWire)) { | ||
return false; | ||
} | ||
return true; | ||
} | ||
|
||
public static MaterialSides getFrom(ObjectTag _material) { | ||
if (!describes(_material)) { | ||
return null; | ||
} | ||
else { | ||
return new MaterialSides((MaterialTag) _material); | ||
} | ||
} | ||
|
||
public static final String[] handledMechs = new String[] { | ||
"sides", "heights" | ||
}; | ||
|
||
private MaterialSides(MaterialTag _material) { | ||
material = _material; | ||
} | ||
|
||
MaterialTag material; | ||
|
||
public static void registerTags() { | ||
|
||
// <--[tag] | ||
// @attribute <MaterialTag.heights> | ||
// @returns ListTag | ||
// @mechanism MaterialTag.heights | ||
// @group properties | ||
// @deprecated Use 'sides' | ||
// @description | ||
// Deprecated in favor of <@link tag MaterialTag.sides> | ||
// --> | ||
// <--[tag] | ||
// @attribute <MaterialTag.sides> | ||
// @returns ListTag | ||
// @mechanism MaterialTag.sides | ||
// @group properties | ||
// @description | ||
// Returns the list of heights for a wall block, or connections for a redstone wire, in order North|East|South|West|Vertical. | ||
// For wall blocks: For n/e/s/w, can be "tall", "low", or "none". For vertical, can be "tall" or "none". | ||
// For redstone wires: For n/e/s/w, can be "none", "side", or "up". No vertical. | ||
// --> | ||
PropertyParser.<MaterialSides, ListTag>registerStaticTag(ListTag.class, "sides", (attribute, material) -> { | ||
return material.getSidesList(); | ||
}, "heights"); | ||
} | ||
|
||
public boolean isWall() { | ||
return material.getModernData() instanceof Wall; | ||
} | ||
|
||
public Wall getWall() { | ||
return (Wall) material.getModernData(); | ||
} | ||
|
||
public boolean isWire() { | ||
return material.getModernData() instanceof RedstoneWire; | ||
} | ||
|
||
public RedstoneWire getWire() { | ||
return (RedstoneWire) material.getModernData(); | ||
} | ||
|
||
public ListTag getSidesList() { | ||
ListTag list = new ListTag(5); | ||
if (isWall()) { | ||
Wall wall = getWall(); | ||
list.add(wall.getHeight(BlockFace.NORTH).name()); | ||
list.add(wall.getHeight(BlockFace.EAST).name()); | ||
list.add(wall.getHeight(BlockFace.SOUTH).name()); | ||
list.add(wall.getHeight(BlockFace.WEST).name()); | ||
list.add(wall.isUp() ? "TALL" : "NONE"); | ||
} | ||
else if (isWire()) { | ||
RedstoneWire wire = getWire(); | ||
list.add(wire.getFace(BlockFace.NORTH).name()); | ||
list.add(wire.getFace(BlockFace.EAST).name()); | ||
list.add(wire.getFace(BlockFace.SOUTH).name()); | ||
list.add(wire.getFace(BlockFace.WEST).name()); | ||
} | ||
return list; | ||
} | ||
|
||
@Override | ||
public String getPropertyString() { | ||
return getSidesList().identify(); | ||
} | ||
|
||
@Override | ||
public String getPropertyId() { | ||
return "sides"; | ||
} | ||
|
||
@Override | ||
public void adjust(Mechanism mechanism) { | ||
|
||
// <--[mechanism] | ||
// @object MaterialTag | ||
// @name heights | ||
// @input ElementTag | ||
// @deprecated Use 'sides' | ||
// @description | ||
// Deprecated in favor of <@link mechanism MaterialTag.sides> | ||
// @tags | ||
// <MaterialTag.heights> | ||
// --> | ||
// <--[mechanism] | ||
// @object MaterialTag | ||
// @name sides | ||
// @input ElementTag | ||
// @description | ||
// Sets the list of heights for a wall block, or connections for a redstone wire, in order North|East|South|West|Vertical. | ||
// For wall blocks: For n/e/s/w, can be "tall", "low", or "none". For vertical, can be "tall" or "none". | ||
// For redstone wires: For n/e/s/w, can be "none", "side", or "up". No vertical. | ||
// @tags | ||
// <MaterialTag.sides> | ||
// --> | ||
if ((mechanism.matches("sides") || mechanism.matches("heights")) && mechanism.requireObject(ListTag.class)) { | ||
ListTag list = mechanism.valueAsType(ListTag.class); | ||
if (isWall()) { | ||
if (list.size() != 5) { | ||
mechanism.echoError("Invalid sides list, size must be 5."); | ||
return; | ||
} | ||
Wall wall = getWall(); | ||
wall.setHeight(BlockFace.NORTH, Wall.Height.valueOf(list.get(0).toUpperCase())); | ||
wall.setHeight(BlockFace.EAST, Wall.Height.valueOf(list.get(1).toUpperCase())); | ||
wall.setHeight(BlockFace.SOUTH, Wall.Height.valueOf(list.get(2).toUpperCase())); | ||
wall.setHeight(BlockFace.WEST, Wall.Height.valueOf(list.get(3).toUpperCase())); | ||
wall.setUp(list.get(4).toUpperCase().equals("TALL")); | ||
} | ||
else if (isWire()) { | ||
if (list.size() != 4) { | ||
mechanism.echoError("Invalid sides list, size must be 4."); | ||
return; | ||
} | ||
RedstoneWire wire = getWire(); | ||
wire.setFace(BlockFace.NORTH, RedstoneWire.Connection.valueOf(list.get(0).toUpperCase())); | ||
wire.setFace(BlockFace.EAST, RedstoneWire.Connection.valueOf(list.get(1).toUpperCase())); | ||
wire.setFace(BlockFace.SOUTH, RedstoneWire.Connection.valueOf(list.get(2).toUpperCase())); | ||
wire.setFace(BlockFace.WEST, RedstoneWire.Connection.valueOf(list.get(3).toUpperCase())); | ||
} | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters