Move HologramFormat code to a dedicated package and add comments to understand the code

This commit is contained in:
Flowsqy 2022-02-13 18:55:59 +01:00
parent 5c001ae979
commit 571c046202
4 changed files with 21 additions and 10 deletions

View File

@ -36,7 +36,7 @@ import org.codemc.worldguardwrapper.WorldGuardWrapper;
import de.epiceric.shopchest.command.ShopCommand; import de.epiceric.shopchest.command.ShopCommand;
import de.epiceric.shopchest.config.Config; import de.epiceric.shopchest.config.Config;
import de.epiceric.shopchest.config.HologramFormat; import de.epiceric.shopchest.config.hologram.HologramFormat;
import de.epiceric.shopchest.event.ShopInitializedEvent; import de.epiceric.shopchest.event.ShopInitializedEvent;
import de.epiceric.shopchest.external.BentoBoxShopFlag; import de.epiceric.shopchest.external.BentoBoxShopFlag;
import de.epiceric.shopchest.external.PlotSquaredOldShopFlag; import de.epiceric.shopchest.external.PlotSquaredOldShopFlag;

View File

@ -1,4 +1,4 @@
package de.epiceric.shopchest.config; package de.epiceric.shopchest.config.hologram;
import java.io.File; import java.io.File;
import java.util.List; import java.util.List;
@ -10,11 +10,11 @@ import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager; import javax.script.ScriptEngineManager;
import javax.script.ScriptException; import javax.script.ScriptException;
import de.epiceric.shopchest.config.Placeholder;
import org.bukkit.configuration.ConfigurationSection; import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.configuration.file.YamlConfiguration; import org.bukkit.configuration.file.YamlConfiguration;
import de.epiceric.shopchest.ShopChest; import de.epiceric.shopchest.ShopChest;
import de.epiceric.shopchest.utils.Operator;
public class HologramFormat { public class HologramFormat {
@ -55,26 +55,37 @@ public class HologramFormat {
public String getFormat(int line, Map<Requirement, Object> reqMap, Map<Placeholder, Object> plaMap) { public String getFormat(int line, Map<Requirement, Object> reqMap, Map<Placeholder, Object> plaMap) {
ConfigurationSection options = config.getConfigurationSection("lines." + line + ".options"); ConfigurationSection options = config.getConfigurationSection("lines." + line + ".options");
// For every option
optionLoop: optionLoop:
for (String key : options.getKeys(false)) { for (String key : options.getKeys(false)) {
ConfigurationSection option = options.getConfigurationSection(key); ConfigurationSection option = options.getConfigurationSection(key);
List<String> requirements = option.getStringList("requirements"); List<String> requirements = option.getStringList("requirements");
String format = option.getString("format"); // Check every requirement
for (String sReq : requirements) { for (String sReq : requirements) {
for (Requirement req : reqMap.keySet()) { for (Requirement req : reqMap.keySet()) {
// If the configuration requirement contain a requirement specified by the shop
if (sReq.contains(req.toString())) { if (sReq.contains(req.toString())) {
// Then evaluate the requirement.
// If the requirement is not fulfilled, skip this option and go to the next one
if (!evalRequirement(sReq, reqMap)) { if (!evalRequirement(sReq, reqMap)) {
continue optionLoop; continue optionLoop;
} }
// TODO Maybe skip to the next config requirement as the requirement has been found and is valid
} }
} }
} }
// Here, every requirement is fulfilled and this is the first valid option
String format = option.getString("format");
// Evaluate placeholders and return the formatted line
return evalPlaceholder(format, plaMap); return evalPlaceholder(format, plaMap);
} }
// No option matching to que shop requirements
// Returning an empty string
return ""; return "";
} }
@ -158,12 +169,12 @@ public class HologramFormat {
Matcher matcher = SIMPLE_NUMERIC_CONDITION.matcher(cond); Matcher matcher = SIMPLE_NUMERIC_CONDITION.matcher(cond);
if (matcher.find()) { if (matcher.find()) {
Double a, b; double a, b;
Operator operator; Operator operator;
try { try {
a = Double.valueOf(matcher.group(1)); a = Double.parseDouble(matcher.group(1));
operator = Operator.from(matcher.group(2)); operator = Operator.from(matcher.group(2));
b = Double.valueOf(matcher.group(3)); b = Double.parseDouble(matcher.group(3));
return operator.compare(a, b); return operator.compare(a, b);
} catch (IllegalArgumentException ignored) { } catch (IllegalArgumentException ignored) {

View File

@ -1,4 +1,4 @@
package de.epiceric.shopchest.utils; package de.epiceric.shopchest.config.hologram;
public enum Operator { public enum Operator {

View File

@ -22,7 +22,7 @@ import org.bukkit.scheduler.BukkitRunnable;
import de.epiceric.shopchest.ShopChest; import de.epiceric.shopchest.ShopChest;
import de.epiceric.shopchest.config.Config; import de.epiceric.shopchest.config.Config;
import de.epiceric.shopchest.config.HologramFormat; import de.epiceric.shopchest.config.hologram.HologramFormat;
import de.epiceric.shopchest.config.Placeholder; import de.epiceric.shopchest.config.Placeholder;
import de.epiceric.shopchest.exceptions.ChestNotFoundException; import de.epiceric.shopchest.exceptions.ChestNotFoundException;
import de.epiceric.shopchest.exceptions.NotEnoughSpaceException; import de.epiceric.shopchest.exceptions.NotEnoughSpaceException;