Skip to content

Commit

Permalink
Improve sign error handling; resolves #404 and resolves #411
Browse files Browse the repository at this point in the history
  • Loading branch information
Sataniel98 committed Jun 4, 2018
1 parent e6055dd commit b236431
Show file tree
Hide file tree
Showing 13 changed files with 59 additions and 31 deletions.
2 changes: 1 addition & 1 deletion src/main/java/de/erethon/dungeonsxl/sign/BedSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ public void onInit() {
}
getSign().getBlock().setType(VanillaItem.AIR.getMaterial());
} else {
markAsErroneous();
markAsErroneous("No bed attached");
}
}

Expand Down
34 changes: 22 additions & 12 deletions src/main/java/de/erethon/dungeonsxl/sign/BlockSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -48,20 +48,30 @@ public boolean check() {

@Override
public void onInit() {
if (!lines[1].isEmpty()) {
String line1[] = lines[1].split(",");
offBlock = plugin.getCaliburn().getExItem(line1[0]);
if (line1.length > 1) {
offBlockData = (byte) NumberUtil.parseInt(line1[1]);
}
if (lines[1].isEmpty()) {
offBlock = VanillaItem.AIR;
} else if (lines[2].isEmpty()) {
onBlock = VanillaItem.AIR;
}

if (!lines[2].isEmpty()) {
String line2[] = lines[2].split(",");
onBlock = plugin.getCaliburn().getExItem(line2[0]);
if (line2.length > 1) {
onBlockData = (byte) NumberUtil.parseInt(line2[1]);
}
String[] line1 = lines[1].split(",");
offBlock = plugin.getCaliburn().getExItem(line1[0]);
if (offBlock == null) {
markAsErroneous("Could not recognize offBlock, input: " + lines[1]);
return;
}
if (line1.length > 1) {
offBlockData = (byte) NumberUtil.parseInt(line1[1]);
}

String[] line2 = lines[2].split(",");
onBlock = plugin.getCaliburn().getExItem(line2[0]);
if (onBlock == null) {
markAsErroneous("Could not recognize onBlock, input: " + lines[2]);
return;
}
if (line2.length > 1) {
onBlockData = (byte) NumberUtil.parseInt(line2[1]);
}

getSign().getBlock().setType(offBlock.getMaterial());
Expand Down
7 changes: 5 additions & 2 deletions src/main/java/de/erethon/dungeonsxl/sign/BossShopSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,11 @@ public boolean check() {

@Override
public void onInit() {
if (bossShop == null || bossShop.getAPI().getShop(lines[1]) == null) {
markAsErroneous();
if (bossShop == null) {
markAsErroneous("BossShop not enabled");
return;
} else if (bossShop.getAPI().getShop(lines[1]) == null) {
markAsErroneous("No such BossShop");
return;
}

Expand Down
2 changes: 1 addition & 1 deletion src/main/java/de/erethon/dungeonsxl/sign/ChestSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,7 @@ public void onInit() {
getSign().getBlock().setType(VanillaItem.AIR.getMaterial());

} else {
markAsErroneous();
markAsErroneous("No chest attached");
}
}

Expand Down
19 changes: 17 additions & 2 deletions src/main/java/de/erethon/dungeonsxl/sign/DSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,8 @@ public abstract class DSign {
// List of Triggers
private Set<Trigger> triggers = new HashSet<>();

private boolean erroneous;

public DSign(Sign sign, String[] lines, DGameWorld gameWorld) {
this.sign = sign;
this.lines = lines;
Expand Down Expand Up @@ -168,6 +170,10 @@ public void onDisable() {
}

public void onUpdate() {
if (erroneous) {
return;
}

for (Trigger trigger : triggers) {
if (!trigger.isTriggered()) {
onDisable();
Expand Down Expand Up @@ -197,17 +203,26 @@ public boolean hasTriggers() {
return !triggers.isEmpty();
}

public boolean isErroneous() {
return erroneous;
}

/**
* Set a placeholder to show that the sign is setup incorrectly.
*
* @param reason
* the reason why the sign is marked as erroneous
*/
public void markAsErroneous() {
public void markAsErroneous(String reason) {
erroneous = true;
sign.setLine(0, ERROR_0);
sign.setLine(1, ERROR_1);
sign.setLine(2, ERROR_2);
sign.setLine(3, ERROR_3);
sign.update();

DMessage.LOG_ERROR_SIGN_SETUP.getMessage(sign.getX() + ", " + sign.getY() + ", " + sign.getZ());
MessageUtil.log(plugin, DMessage.LOG_ERROR_SIGN_SETUP.getMessage(sign.getX() + ", " + sign.getY() + ", " + sign.getZ()));
MessageUtil.log(plugin, getType().getName() + ": " + reason);
}

/* Statics */
Expand Down
2 changes: 1 addition & 1 deletion src/main/java/de/erethon/dungeonsxl/sign/OpenDoorSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ public void onInit() {
getSign().getBlock().setType(VanillaItem.AIR.getMaterial());

} else {
markAsErroneous();
markAsErroneous("No door attached");
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ public void onInit() {
resourcePack = (String) url;

} else {
markAsErroneous();
markAsErroneous("Unknown resourcepack format");
return;
}

Expand Down
3 changes: 3 additions & 0 deletions src/main/java/de/erethon/dungeonsxl/sign/ScriptSign.java
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,9 @@ public void onInit() {
SignScript script = plugin.getSignScripts().getByName(name);
for (String[] lines : script.getSigns()) {
DSign dSign = DSign.create(getSign(), lines, getGameWorld());
if (dSign.isErroneous()) {
continue;
}
getGameWorld().getDSigns().add(dSign);

dSign.onInit();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ public void onInit() {
getGameWorld().getClassesSigns().add(getSign());

} else {
markAsErroneous();
markAsErroneous("No such class");
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ public boolean check() {
@Override
public void onInit() {
if (Bukkit.getPluginManager().getPlugin("HolographicDisplays") == null) {
markAsErroneous();
markAsErroneous("HolographicDisplays not enabled");
return;
}
getSign().getBlock().setType(VanillaItem.AIR.getMaterial());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ public void onInit() {
getSign().getBlock().setType(VanillaItem.AIR.getMaterial());
initialized = true;
} else {
markAsErroneous();
markAsErroneous("1. Line is empty; expected input: sound name");
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -233,7 +233,7 @@ public void onInit() {
}

if (provider == null) {
markAsErroneous();
markAsErroneous("Could not fetch a known external mob provider from " + lines[2]);
return;
}
}
Expand Down
11 changes: 4 additions & 7 deletions src/main/java/de/erethon/dungeonsxl/world/DGameWorld.java
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@
import de.erethon.dungeonsxl.player.DGroup;
import de.erethon.dungeonsxl.sign.DSign;
import de.erethon.dungeonsxl.sign.DSignType;
import de.erethon.dungeonsxl.sign.DSignTypeDefault;
import de.erethon.dungeonsxl.sign.LocationSign;
import de.erethon.dungeonsxl.sign.lobby.StartSign;
import de.erethon.dungeonsxl.sign.mob.MobSign;
Expand Down Expand Up @@ -174,7 +173,7 @@ public Location getStartLocation(DGroup dGroup) {

// Try the matching location
for (DSign dSign : dSigns) {
if (dSign.getType() == DSignTypeDefault.START) {
if (dSign instanceof StartSign) {
if (((StartSign) dSign).getId() == index) {
return ((LocationSign) dSign).getLocation();
}
Expand All @@ -183,7 +182,7 @@ public Location getStartLocation(DGroup dGroup) {

// Try any location
for (DSign dSign : dSigns) {
if (dSign.getType() == DSignTypeDefault.START) {
if (dSign instanceof StartSign) {
return ((LocationSign) dSign).getLocation();
}
}
Expand Down Expand Up @@ -479,10 +478,8 @@ public void startGame() {
}

for (DSign dSign : dSigns) {
if (dSign != null) {
if (!dSign.hasTriggers()) {
dSign.onTrigger();
}
if (dSign != null && !dSign.isErroneous() && !dSign.hasTriggers()) {
dSign.onTrigger();
}
}
}
Expand Down

0 comments on commit b236431

Please sign in to comment.