From 7a4b358f8a580675c9f822618ec562121fce9a8c Mon Sep 17 00:00:00 2001 From: LevelX2 Date: Sat, 6 Aug 2016 13:16:49 +0200 Subject: [PATCH] * Fixed CMC for spells (Escalate is not calculated correctly when more than 1 mode is chosen) fixes #2143. --- Mage/src/main/java/mage/abilities/SpellAbility.java | 10 ++-------- Mage/src/main/java/mage/game/stack/Spell.java | 8 +++----- 2 files changed, 5 insertions(+), 13 deletions(-) diff --git a/Mage/src/main/java/mage/abilities/SpellAbility.java b/Mage/src/main/java/mage/abilities/SpellAbility.java index a0c89bea84..e12d0c472d 100644 --- a/Mage/src/main/java/mage/abilities/SpellAbility.java +++ b/Mage/src/main/java/mage/abilities/SpellAbility.java @@ -176,8 +176,7 @@ public class SpellAbility extends ActivatedAbilityImpl { return cardName; } - public int getConvertedManaCost() { - int cmc = 0; + public int getConvertedXManaCost() { int xMultiplier = 0; for (String symbolString : getManaCosts().getSymbols()) { int index = symbolString.indexOf("{X}"); @@ -187,12 +186,7 @@ public class SpellAbility extends ActivatedAbilityImpl { index = symbolString.indexOf("{X}"); } } - if (getSpellAbilityType().equals(SpellAbilityType.BASE_ALTERNATE)) { - cmc += getManaCostsToPay().getX() * xMultiplier; - } else { - cmc += getManaCosts().convertedManaCost() + getManaCostsToPay().getX() * xMultiplier; - } - return cmc; + return getManaCostsToPay().getX() * xMultiplier; } } diff --git a/Mage/src/main/java/mage/game/stack/Spell.java b/Mage/src/main/java/mage/game/stack/Spell.java index e6252d91ed..83eeccda9c 100644 --- a/Mage/src/main/java/mage/game/stack/Spell.java +++ b/Mage/src/main/java/mage/game/stack/Spell.java @@ -365,7 +365,7 @@ public class Spell extends StackObjImpl implements Card { } } } else { - card.removeFromZone(game, Zone.STACK, sourceId); + card.removeFromZone(game, Zone.STACK, sourceId); } } @@ -503,11 +503,9 @@ public class Spell extends StackObjImpl implements Card { return 0; } for (SpellAbility spellAbility : spellAbilities) { - cmc += spellAbility.getConvertedManaCost(); - } - if (this.getSpellAbility().getSpellAbilityType().equals(SpellAbilityType.BASE_ALTERNATE)) { - cmc += getCard().getManaCost().convertedManaCost(); + cmc += spellAbility.getConvertedXManaCost(); } + cmc += getCard().getManaCost().convertedManaCost(); return cmc; }