Browse Source

Iterate through all effects for action

feature-config-usage
MagicBot 2 days ago
parent
commit
99acc4736f
  1. 4
      src/engine/gameManager/PowersManager.java
  2. 2
      src/engine/wpak/EffectsParser.java
  3. 2
      src/engine/wpak/PowerActionParser.java
  4. 2
      src/engine/wpak/PowersParser.java
  5. 22
      src/engine/wpakpowers/WpakPowerManager.java

4
src/engine/gameManager/PowersManager.java

@ -121,7 +121,7 @@ public enum PowersManager { @@ -121,7 +121,7 @@ public enum PowersManager {
// Add EffectsBase
ArrayList<EffectsBase> effectList = new ArrayList<>();
for (Effect entry : WpakPowerManager.effect_data.values()) {
for (Effect entry : WpakPowerManager._effectsLookup.values()) {
EffectsBase effectBase = new EffectsBase(entry);
effectList.add(effectBase);
PowersManager.effectsBaseByToken.put(effectBase.getToken(), effectBase);
@ -136,7 +136,7 @@ public enum PowersManager { @@ -136,7 +136,7 @@ public enum PowersManager {
HashMap<String, EffectsBase> effects = PowersManager.effectsBaseByIDString;
for (PowerAction powerAction : WpakPowerManager.power_actions.values()) {
for (PowerAction powerAction : WpakPowerManager._powerActionLookup.values()) {
AbstractPowerAction apa;
String type = powerAction.action_type;
String IDString = powerAction.action_id;

2
src/engine/wpak/EffectsParser.java

@ -56,7 +56,7 @@ public class EffectsParser { @@ -56,7 +56,7 @@ public class EffectsParser {
while (matcher.find()) {
try {
Effect effect = parseEffectEntry(matcher.group());
WpakPowerManager.effect_data.put(effect.effect_id, effect);
WpakPowerManager._effectsLookup.put(effect.effect_id, effect);
}catch(Exception e){
Logger.error("EFFECT PARSE FAILED: " + e);
}

2
src/engine/wpak/PowerActionParser.java

@ -54,7 +54,7 @@ public class PowerActionParser { @@ -54,7 +54,7 @@ public class PowerActionParser {
while (matcher.find()) {
PowerAction powerAction = parsePowerActionEntry(matcher.group().trim());
WpakPowerManager.power_actions.put(Hasher.SBStringHash(powerAction.action_id),powerAction);
WpakPowerManager._powerActionLookup.put(Hasher.SBStringHash(powerAction.action_id), powerAction);
}
}

2
src/engine/wpak/PowersParser.java

@ -52,7 +52,7 @@ public class PowersParser { @@ -52,7 +52,7 @@ public class PowersParser {
while (matcher.find()) {
Power power = parsePowerEntry(matcher.group().trim());
WpakPowerManager.powers.put(Hasher.SBStringHash(power.power_id),power);
WpakPowerManager._powersLookup.put(Hasher.SBStringHash(power.power_id), power);
}
}

22
src/engine/wpakpowers/WpakPowerManager.java

@ -41,9 +41,9 @@ import java.util.HashSet; @@ -41,9 +41,9 @@ import java.util.HashSet;
import static engine.math.FastMath.sqr;
public class WpakPowerManager {
public static HashMap<String, Effect> effect_data = new HashMap<>();
public static HashMap<Integer, PowerAction> power_actions = new HashMap<>();
public static HashMap<Integer, Power> powers = new HashMap<>();
public static HashMap<String, Effect> _effectsLookup = new HashMap<>();
public static HashMap<Integer, PowerAction> _powerActionLookup = new HashMap<>();
public static HashMap<Integer, Power> _powersLookup = new HashMap<>();
private static JobScheduler js;
@ -98,7 +98,7 @@ public class WpakPowerManager { @@ -98,7 +98,7 @@ public class WpakPowerManager {
}
//lookup the power that was cast
Power powerCast = powers.get(msg.getPowerUsedID());
Power powerCast = _powersLookup.get(msg.getPowerUsedID());
if (powerCast == null) {
ChatManager.chatSayInfo(playerCharacter, "This power is not implemented yet.");
return true;
@ -291,7 +291,7 @@ public class WpakPowerManager { @@ -291,7 +291,7 @@ public class WpakPowerManager {
}
public static void finishUsePower(PerformActionMsg msg, PlayerCharacter caster, AbstractWorldObject target) {
Power powerUsed = powers.get(msg.getPowerUsedID());
Power powerUsed = _powersLookup.get(msg.getPowerUsedID());
if (powerUsed == null)
return;
if (powerUsed.maxMobTargets > 1 || powerUsed.maxPlayerTargets > 1) {
@ -337,13 +337,17 @@ public class WpakPowerManager { @@ -337,13 +337,17 @@ public class WpakPowerManager {
for (ActionEntry actionEntry : power.actionEntries) {
Effect effect = effect_data.get(actionEntry.action_id);
PowerAction powerAction = _powerActionLookup.get(actionEntry.action_id);
if (effect == null) {
Logger.error("Null effect for " + actionEntry.action_id);
if (powerAction == null) {
Logger.error("Null PowerAction for " + actionEntry.action_id);
continue;
}
// Iterate effects for this powerAction and apply
for (Effect effect : powerAction.effects) {
// Create pojo to hold effect/modifiers stored in AWO
AppliedEffect appliedEffect = new AppliedEffect();
@ -364,7 +368,7 @@ public class WpakPowerManager { @@ -364,7 +368,7 @@ public class WpakPowerManager {
target._effects.put(effect, appliedEffect);
// target.updateBonuses()?
}
}
}
public static void sendPowerMsg(PlayerCharacter playerCharacter, int type, PerformActionMsg msg) {

Loading…
Cancel
Save