PowerActionEntry parsing work.
This commit is contained in:
@@ -43,6 +43,7 @@ public class EffectsParser {
|
||||
} catch (IOException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
|
||||
String fileContents = new String(fileData);
|
||||
|
||||
// Iterate over effect entries from .wpak data
|
||||
|
||||
+208
-213
@@ -57,256 +57,251 @@ public class PowersParser {
|
||||
|
||||
PowerEntry powerEntry = new PowerEntry();
|
||||
|
||||
try {
|
||||
|
||||
StringBuilder conditionString = new StringBuilder();
|
||||
StringBuilder powerString = new StringBuilder();
|
||||
StringBuilder conditionString = new StringBuilder();
|
||||
StringBuilder powerString = new StringBuilder();
|
||||
|
||||
int endPos = 0;
|
||||
int endPos = 0;
|
||||
|
||||
// Separate out any conditions from the power data
|
||||
// Separate out any conditions from the power data
|
||||
|
||||
Matcher matcher = CONDITION_REGEX.matcher(powerData);
|
||||
Matcher matcher = CONDITION_REGEX.matcher(powerData);
|
||||
|
||||
while (matcher.find()) {
|
||||
conditionString.append(matcher.group().trim());
|
||||
powerString.append(powerData, endPos, matcher.start());
|
||||
endPos = matcher.end();
|
||||
}
|
||||
while (matcher.find()) {
|
||||
conditionString.append(matcher.group().trim());
|
||||
powerString.append(powerData, endPos, matcher.start());
|
||||
endPos = matcher.end();
|
||||
}
|
||||
|
||||
powerString.append(powerData.substring(endPos));
|
||||
powerString.append(powerData.substring(endPos));
|
||||
|
||||
// Cleanup dangling tags and lines that contain a # and leading/trailing blank lines
|
||||
// Cleanup dangling tags and lines that contain a # and leading/trailing blank lines
|
||||
|
||||
powerString = new StringBuilder(powerString.toString().replaceAll("CONDITIONBEGINCONDITIONEND", ""));
|
||||
powerString = new StringBuilder(powerString.toString().replaceAll("(?m)^(\\s*#.*|\\s*)\r?\n?", ""));
|
||||
powerString = new StringBuilder(powerString.toString().replaceAll("CONDITIONBEGINCONDITIONEND", ""));
|
||||
powerString = new StringBuilder(powerString.toString().replaceAll("(?m)^(\\s*#.*|\\s*)\r?\n?", ""));
|
||||
|
||||
conditionString = new StringBuilder(conditionString.toString().replaceAll("(?m)^(\\s*#.*|\\s*)\r?\n?", ""));
|
||||
conditionString = new StringBuilder(conditionString.toString().replaceAll("(?m)^(\\s*#.*|\\s*)\r?\n?", ""));
|
||||
|
||||
// Parse header line in power data
|
||||
// Parse header line in power data
|
||||
|
||||
String[] lineData = powerString.toString().trim().split("\n");
|
||||
ArrayList<String> powerHeader = new ArrayList<>();
|
||||
String[] lineData = powerString.toString().trim().split("\n");
|
||||
ArrayList<String> powerHeader = new ArrayList<>();
|
||||
|
||||
String headerString = lineData[0];
|
||||
headerString = headerString.replace("\n", " ");
|
||||
String headerString = lineData[0];
|
||||
headerString = headerString.replace("\n", " ");
|
||||
|
||||
matcher = STRSPLIT_REGEX.matcher(headerString);
|
||||
matcher = STRSPLIT_REGEX.matcher(headerString);
|
||||
|
||||
while (matcher.find())
|
||||
powerHeader.add(matcher.group().trim());
|
||||
while (matcher.find())
|
||||
powerHeader.add(matcher.group().trim());
|
||||
|
||||
java.util.Iterator<String> iterator = powerHeader.iterator();
|
||||
java.util.Iterator<String> iterator = powerHeader.iterator();
|
||||
|
||||
powerEntry.power_id = iterator.next();
|
||||
powerEntry.power = iterator.next().replaceAll("\"", "");
|
||||
powerEntry.power_id = iterator.next();
|
||||
powerEntry.power = iterator.next().replaceAll("\"", "");
|
||||
|
||||
PowerData power = new PowerData();
|
||||
power.power_type = mbEnums.PowerType.valueOf(iterator.next());
|
||||
PowerData power = new PowerData();
|
||||
power.power_type = mbEnums.PowerType.valueOf(iterator.next());
|
||||
power.icon = Integer.parseInt(iterator.next());
|
||||
power.powerBase = iterator.next().replaceAll("\"", "");
|
||||
powerEntry.powers.add(power);
|
||||
|
||||
String nextValue = iterator.next();
|
||||
|
||||
// Account for second definition
|
||||
|
||||
if (nextValue.equals("SPELL") || nextValue.equals("SKILL")) {
|
||||
power = new PowerData();
|
||||
power.power_type = mbEnums.PowerType.valueOf(nextValue);
|
||||
power.icon = Integer.parseInt(iterator.next());
|
||||
power.powerBase = iterator.next().replaceAll("\"", "");
|
||||
powerEntry.powers.add(power);
|
||||
powerEntry.target_type = mbEnums.PowerTargetType.valueOf(iterator.next());
|
||||
} else
|
||||
powerEntry.target_type = mbEnums.PowerTargetType.valueOf(nextValue);
|
||||
|
||||
String nextValue = iterator.next();
|
||||
powerEntry.range = Integer.parseInt(iterator.next());
|
||||
powerEntry.areaType = mbEnums.AreaType.valueOf(iterator.next());
|
||||
powerEntry.areaRange = Integer.parseInt(iterator.next());
|
||||
powerEntry.excludeType = mbEnums.ExcludeType.valueOf(iterator.next());
|
||||
powerEntry.costType = mbEnums.CostType.valueOf(iterator.next());
|
||||
powerEntry.cost = Float.parseFloat(iterator.next());
|
||||
powerEntry.difficulty = Float.parseFloat(iterator.next());
|
||||
powerEntry.precision = Float.parseFloat(iterator.next());
|
||||
powerEntry.init_time = Float.parseFloat(iterator.next().replaceAll("(\\.0)+$", ""));
|
||||
powerEntry.release_time = Float.parseFloat(iterator.next());
|
||||
powerEntry.recycle_time = Float.parseFloat(iterator.next());
|
||||
powerEntry.hitRollYN = Integer.parseInt(iterator.next());
|
||||
powerEntry.castingMode = mbEnums.CastingModeType.valueOf(iterator.next());
|
||||
powerEntry.initAmin = Integer.parseInt(iterator.next());
|
||||
powerEntry.releaseAnim = Integer.parseInt(iterator.next());
|
||||
powerEntry.targetSelect = mbEnums.TargetSelectType.valueOf(iterator.next());
|
||||
|
||||
// Account for second definition
|
||||
// Process key value pairs after header
|
||||
|
||||
if (nextValue.equals("SPELL") || nextValue.equals("SKILL")) {
|
||||
power = new PowerData();
|
||||
power.power_type = mbEnums.PowerType.valueOf(nextValue);
|
||||
power.icon = Integer.parseInt(iterator.next());
|
||||
power.powerBase = iterator.next().replaceAll("\"", "");
|
||||
powerEntry.powers.add(power);
|
||||
powerEntry.target_type = mbEnums.PowerTargetType.valueOf(iterator.next());
|
||||
} else
|
||||
powerEntry.target_type = mbEnums.PowerTargetType.valueOf(nextValue);
|
||||
iterator = Arrays.stream(lineData).iterator();
|
||||
iterator.next(); // Ignore header
|
||||
|
||||
powerEntry.range = Integer.parseInt(iterator.next());
|
||||
powerEntry.areaType = mbEnums.AreaType.valueOf(iterator.next());
|
||||
powerEntry.areaRange = Integer.parseInt(iterator.next());
|
||||
powerEntry.excludeType = mbEnums.ExcludeType.valueOf(iterator.next());
|
||||
powerEntry.costType = mbEnums.CostType.valueOf(iterator.next());
|
||||
powerEntry.cost = Float.parseFloat(iterator.next());
|
||||
powerEntry.difficulty = Float.parseFloat(iterator.next());
|
||||
powerEntry.precision = Float.parseFloat(iterator.next());
|
||||
powerEntry.init_time = Float.parseFloat(iterator.next().replaceAll("(\\.0)+$", ""));
|
||||
powerEntry.release_time = Float.parseFloat(iterator.next());
|
||||
powerEntry.recycle_time = Float.parseFloat(iterator.next());
|
||||
powerEntry.hitRollYN = Integer.parseInt(iterator.next());
|
||||
powerEntry.castingMode = mbEnums.CastingModeType.valueOf(iterator.next());
|
||||
powerEntry.initAmin = Integer.parseInt(iterator.next());
|
||||
powerEntry.releaseAnim = Integer.parseInt(iterator.next());
|
||||
powerEntry.targetSelect = mbEnums.TargetSelectType.valueOf(iterator.next());
|
||||
while (iterator.hasNext()) {
|
||||
|
||||
// Process key value pairs after header
|
||||
String lineValue = iterator.next();
|
||||
String[] lineValues = lineValue.split("=");
|
||||
String key = lineValues[0].trim();
|
||||
ActionEntry actionEntry;
|
||||
String[] arguments;
|
||||
Matcher matcher1;
|
||||
ArrayList<String> args;
|
||||
|
||||
iterator = Arrays.stream(lineData).iterator();
|
||||
iterator.next(); // Ignore header
|
||||
switch (key) {
|
||||
case "ACTION":
|
||||
actionEntry = new ActionEntry();
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
|
||||
while (iterator.hasNext()) {
|
||||
if (powerEntry.power_id.equals("HNT-050"))
|
||||
Logger.error("debug");
|
||||
|
||||
String lineValue = iterator.next();
|
||||
String[] lineValues = lineValue.split("=");
|
||||
String key = lineValues[0].trim();
|
||||
ActionEntry actionEntry;
|
||||
String[] arguments;
|
||||
Matcher matcher1;
|
||||
ArrayList<String> args;
|
||||
actionEntry.effect_id = arguments[0];
|
||||
actionEntry.minTrains = Integer.parseInt(arguments[1]);
|
||||
actionEntry.maxTrains = Integer.parseInt(arguments[2]);
|
||||
actionEntry.duration = Float.parseFloat(arguments[3]);
|
||||
actionEntry.curve = mbEnums.CompoundCurveType.valueOf(arguments[4]);
|
||||
actionEntry.stackingCategory = arguments[5];
|
||||
actionEntry.stackingPriority = Integer.parseInt(arguments[6]);
|
||||
actionEntry.categoryToPower = mbEnums.CategoryToPowerType.valueOf(arguments[7]);
|
||||
powerEntry.actionEntries.add(actionEntry);
|
||||
break;
|
||||
case "MaxLevel":
|
||||
powerEntry.maxLevel = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "HateValue":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
powerEntry.hateValue = Integer.parseInt(arguments[0]);
|
||||
|
||||
switch (key) {
|
||||
case "ACTION":
|
||||
actionEntry = new ActionEntry();
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
// Not all entries have a curve. Defaults to DefaultFlat;
|
||||
|
||||
if (powerEntry.power_id.equals("HNT-050"))
|
||||
Logger.error("debug");
|
||||
if (arguments.length > 1)
|
||||
powerEntry.hateCurve = mbEnums.CompoundCurveType.valueOf(arguments[1]);
|
||||
break;
|
||||
case "LOOPANIMID":
|
||||
powerEntry.loopAnimID = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "GRANTOVERRIDEVAR":
|
||||
powerEntry.grantOverrideVar = lineValues[1].trim();
|
||||
break;
|
||||
case "DESCRIPTION":
|
||||
powerEntry.description.add(lineValues[1].trim());
|
||||
break;
|
||||
case "CATEGORY":
|
||||
powerEntry.category = lineValues[1].trim();
|
||||
break;
|
||||
case "CURVE":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
powerEntry.curves.put(arguments[0], mbEnums.CompoundCurveType.valueOf(arguments[1]));
|
||||
break;
|
||||
case "EQPREREQ":
|
||||
EquipmentPreReq equipmentPreReq = new EquipmentPreReq();
|
||||
matcher1 = STRSPLIT_REGEX.matcher(lineValues[1].trim());
|
||||
args = new ArrayList<>();
|
||||
|
||||
actionEntry.effect_id = arguments[0];
|
||||
actionEntry.minTrains = Integer.parseInt(arguments[1]);
|
||||
actionEntry.maxTrains = Integer.parseInt(arguments[2]);
|
||||
actionEntry.duration = Float.parseFloat(arguments[3]);
|
||||
actionEntry.curve = mbEnums.CompoundCurveType.valueOf(arguments[4]);
|
||||
actionEntry.stackingCategory = arguments[5];
|
||||
actionEntry.stackingPriority = Integer.parseInt(arguments[6]);
|
||||
actionEntry.categoryToPower = mbEnums.CategoryToPowerType.valueOf(arguments[7]);
|
||||
powerEntry.actionEntries.add(actionEntry);
|
||||
break;
|
||||
case "MaxLevel":
|
||||
powerEntry.maxLevel = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "HateValue":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
powerEntry.hateValue = Integer.parseInt(arguments[0]);
|
||||
while (matcher1.find())
|
||||
args.add(matcher1.group().trim());
|
||||
|
||||
// Not all entries have a curve. Defaults to DefaultFlat;
|
||||
|
||||
if (arguments.length > 1)
|
||||
powerEntry.hateCurve = mbEnums.CompoundCurveType.valueOf(arguments[1]);
|
||||
break;
|
||||
case "LOOPANIMID":
|
||||
powerEntry.loopAnimID = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "GRANTOVERRIDEVAR":
|
||||
powerEntry.grantOverrideVar = lineValues[1].trim();
|
||||
break;
|
||||
case "DESCRIPTION":
|
||||
powerEntry.description.add(lineValues[1].trim());
|
||||
break;
|
||||
case "CATEGORY":
|
||||
powerEntry.category = lineValues[1].trim();
|
||||
break;
|
||||
case "CURVE":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
powerEntry.curves.put(arguments[0], mbEnums.CompoundCurveType.valueOf(arguments[1]));
|
||||
break;
|
||||
case "EQPREREQ":
|
||||
EquipmentPreReq equipmentPreReq = new EquipmentPreReq();
|
||||
matcher1 = STRSPLIT_REGEX.matcher(lineValues[1].trim());
|
||||
args = new ArrayList<>();
|
||||
|
||||
while (matcher1.find())
|
||||
args.add(matcher1.group().trim());
|
||||
|
||||
equipmentPreReq.slot = mbEnums.EquipSlotType.valueOf(args.get(0));
|
||||
equipmentPreReq.skill = args.get(1).replaceAll("\"", "");
|
||||
equipmentPreReq.level = Integer.parseInt(args.get(2));
|
||||
powerEntry.equipmentPreReq = equipmentPreReq;
|
||||
break;
|
||||
case "CANCASTWHILEMOVING":
|
||||
powerEntry.canCastWhileMoving = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "CANCASTWHILEFLYING":
|
||||
powerEntry.canCastWhileFlying = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "BLADETRAILS":
|
||||
powerEntry.bladeTrails = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "EFFECTPREREQ":
|
||||
EffectDescription effectPreReq = new EffectDescription();
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
effectPreReq.effect_id = arguments[9];
|
||||
effectPreReq.level = Integer.parseInt(arguments[1]);
|
||||
effectPreReq.message = arguments[2];
|
||||
powerEntry.effectPreReqs.add(effectPreReq);
|
||||
break;
|
||||
case "MONSTERTYPERESTRICTS":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
for (String restriction : arguments)
|
||||
powerEntry.monsterRestricts.add(mbEnums.MonsterType.valueOf(restriction.trim()));
|
||||
break;
|
||||
case "MONSTERTYPEPREREQS":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
for (String restriction : arguments)
|
||||
powerEntry.monsterPrereqs.add(mbEnums.MonsterType.valueOf(restriction.trim()));
|
||||
break;
|
||||
case "SHOULDCHECKPATH":
|
||||
powerEntry.shouldCheckPath = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "STICKY":
|
||||
powerEntry.sticky = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "PULSEINFO":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
powerEntry.pulseCycle = Integer.parseInt(arguments[0]);
|
||||
powerEntry.pulseDuration = Integer.parseInt(arguments[1]);
|
||||
break;
|
||||
case "MAXNUMMOBTARGETS":
|
||||
powerEntry.maxMobTargets = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "MAXNUMPLAYERTARGETS":
|
||||
powerEntry.maxPlayerTargets = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "ISADMINPOWER":
|
||||
powerEntry.isAdminPower = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "ISPROJECTILE":
|
||||
powerEntry.isProjectile = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "CASTERSPULSEPARTICLE":
|
||||
powerEntry.casterPulseParticle = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "TARGETEFFECTPREREQS_ORED":
|
||||
EffectDescription preReq = new EffectDescription();
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
preReq.effect_id = arguments[0];
|
||||
preReq.level = Integer.parseInt(arguments[1]);
|
||||
powerEntry.targetEffectPrereqs.add(preReq);
|
||||
break;
|
||||
case "SOUNDS": // Values not parsed
|
||||
case "APPLYDAMAGESELF":
|
||||
case "APPLYDAMAGECASTER":
|
||||
case "APPLYDAMAGEOTHER":
|
||||
case "APPLYDAMAGETARGET":
|
||||
case "APPLYEFFECTSELF":
|
||||
case "APPLYEFFECTOTHER":
|
||||
case "APPLYEFFECTCASTER":
|
||||
case "APPLYEFFECTTARGET":
|
||||
case "FIZZLEOTHER":
|
||||
case "FIZZLESELF":
|
||||
case "INITSTRING":
|
||||
case "SUCCESSOTHER":
|
||||
case "SUCCESSSELF":
|
||||
case "WEAROFFEFFECTOTHER":
|
||||
case "WEAROFFEFFECTSELF":
|
||||
break;
|
||||
default:
|
||||
Logger.error("Unhandled variable type:" + key + " for power: " + powerEntry.power_id);
|
||||
}
|
||||
equipmentPreReq.slot = mbEnums.EquipSlotType.valueOf(args.get(0));
|
||||
equipmentPreReq.skill = args.get(1).replaceAll("\"", "");
|
||||
equipmentPreReq.level = Integer.parseInt(args.get(2));
|
||||
powerEntry.equipmentPreReq = equipmentPreReq;
|
||||
break;
|
||||
case "CANCASTWHILEMOVING":
|
||||
powerEntry.canCastWhileMoving = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "CANCASTWHILEFLYING":
|
||||
powerEntry.canCastWhileFlying = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "BLADETRAILS":
|
||||
powerEntry.bladeTrails = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "EFFECTPREREQ":
|
||||
EffectDescription effectPreReq = new EffectDescription();
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
effectPreReq.effect_id = arguments[9];
|
||||
effectPreReq.level = Integer.parseInt(arguments[1]);
|
||||
effectPreReq.message = arguments[2];
|
||||
powerEntry.effectPreReqs.add(effectPreReq);
|
||||
break;
|
||||
case "MONSTERTYPERESTRICTS":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
for (String restriction : arguments)
|
||||
powerEntry.monsterRestricts.add(mbEnums.MonsterType.valueOf(restriction.trim()));
|
||||
break;
|
||||
case "MONSTERTYPEPREREQS":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
for (String restriction : arguments)
|
||||
powerEntry.monsterPrereqs.add(mbEnums.MonsterType.valueOf(restriction.trim()));
|
||||
break;
|
||||
case "SHOULDCHECKPATH":
|
||||
powerEntry.shouldCheckPath = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "STICKY":
|
||||
powerEntry.sticky = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "PULSEINFO":
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
powerEntry.pulseCycle = Integer.parseInt(arguments[0]);
|
||||
powerEntry.pulseDuration = Integer.parseInt(arguments[1]);
|
||||
break;
|
||||
case "MAXNUMMOBTARGETS":
|
||||
powerEntry.maxMobTargets = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "MAXNUMPLAYERTARGETS":
|
||||
powerEntry.maxPlayerTargets = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "ISADMINPOWER":
|
||||
powerEntry.isAdminPower = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "ISPROJECTILE":
|
||||
powerEntry.isProjectile = Boolean.parseBoolean(lineValues[1].trim());
|
||||
break;
|
||||
case "CASTERSPULSEPARTICLE":
|
||||
powerEntry.casterPulseParticle = Integer.parseInt(lineValues[1].trim());
|
||||
break;
|
||||
case "TARGETEFFECTPREREQS_ORED":
|
||||
EffectDescription preReq = new EffectDescription();
|
||||
arguments = lineValues[1].trim().split("\\s+");
|
||||
preReq.effect_id = arguments[0];
|
||||
preReq.level = Integer.parseInt(arguments[1]);
|
||||
powerEntry.targetEffectPrereqs.add(preReq);
|
||||
break;
|
||||
case "SOUNDS": // Values not parsed
|
||||
case "APPLYDAMAGESELF":
|
||||
case "APPLYDAMAGECASTER":
|
||||
case "APPLYDAMAGEOTHER":
|
||||
case "APPLYDAMAGETARGET":
|
||||
case "APPLYEFFECTSELF":
|
||||
case "APPLYEFFECTOTHER":
|
||||
case "APPLYEFFECTCASTER":
|
||||
case "APPLYEFFECTTARGET":
|
||||
case "FIZZLEOTHER":
|
||||
case "FIZZLESELF":
|
||||
case "INITSTRING":
|
||||
case "SUCCESSOTHER":
|
||||
case "SUCCESSSELF":
|
||||
case "WEAROFFEFFECTOTHER":
|
||||
case "WEAROFFEFFECTSELF":
|
||||
break;
|
||||
default:
|
||||
Logger.error("Unhandled variable type:" + key + " for power: " + powerEntry.power_id);
|
||||
}
|
||||
}
|
||||
|
||||
// Parse power conditions
|
||||
// Parse power conditions
|
||||
|
||||
if (conditionString.toString().isEmpty() == false) {
|
||||
String[] conditions = conditionString.toString().split("\n");
|
||||
if (!conditionString.toString().isEmpty()) {
|
||||
String[] conditions = conditionString.toString().split("\n");
|
||||
|
||||
for (String condition : conditions) {
|
||||
String[] parameters = condition.trim().split("\\s+");
|
||||
powerEntry.conditions.put(parameters[0], Float.parseFloat(parameters[1]));
|
||||
}
|
||||
for (String condition : conditions) {
|
||||
String[] parameters = condition.trim().split("\\s+");
|
||||
powerEntry.conditions.put(parameters[0], Float.parseFloat(parameters[1]));
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
Logger.error(powerEntry.power_id + " " + e);
|
||||
}
|
||||
|
||||
return powerEntry;
|
||||
|
||||
@@ -34,7 +34,4 @@ public class PowerActionEntry {
|
||||
public boolean applyEffectBlank = false;
|
||||
public boolean wearOffEffectBlank = false;
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user