diff --git a/Mage.Sets/src/mage/sets/fatereforged/BrutalHordechief.java b/Mage.Sets/src/mage/sets/fatereforged/BrutalHordechief.java
new file mode 100644
index 00000000000..c2edd96856a
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/fatereforged/BrutalHordechief.java
@@ -0,0 +1,170 @@
+/*
+ * Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without modification, are
+ * permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice, this list of
+ * conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright notice, this list
+ * of conditions and the following disclaimer in the documentation and/or other materials
+ * provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * The views and conclusions contained in the software and documentation are those of the
+ * authors and should not be interpreted as representing official policies, either expressed
+ * or implied, of BetaSteward_at_googlemail.com.
+ */
+package mage.sets.fatereforged;
+
+import java.util.UUID;
+import mage.MageInt;
+import mage.abilities.Ability;
+import mage.abilities.TriggeredAbilityImpl;
+import mage.abilities.common.SimpleActivatedAbility;
+import mage.abilities.costs.mana.ManaCostsImpl;
+import mage.abilities.effects.ReplacementEffectImpl;
+import mage.abilities.effects.common.DamageTargetEffect;
+import mage.abilities.effects.common.GainLifeEffect;
+import mage.abilities.effects.common.combat.BlocksIfAbleAllEffect;
+import mage.cards.CardImpl;
+import mage.constants.CardType;
+import mage.constants.Duration;
+import mage.constants.Outcome;
+import mage.constants.Rarity;
+import mage.constants.TargetController;
+import mage.constants.Zone;
+import mage.filter.common.FilterCreaturePermanent;
+import mage.filter.predicate.permanent.ControllerPredicate;
+import mage.game.Game;
+import mage.game.events.GameEvent;
+import mage.game.permanent.Permanent;
+import mage.players.Player;
+import mage.target.targetpointer.FixedTarget;
+
+/**
+ *
+ * @author LevelX2
+ */
+public class BrutalHordechief extends CardImpl {
+
+ private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("Creature your opponents control");
+
+ static {
+ filter.add(new ControllerPredicate(TargetController.OPPONENT));
+ }
+
+ public BrutalHordechief(UUID ownerId) {
+ super(ownerId, 64, "Brutal Hordechief", Rarity.MYTHIC, new CardType[]{CardType.CREATURE}, "{3}{B}");
+ this.expansionSetCode = "FRF";
+ this.subtype.add("Orc");
+ this.subtype.add("Warrior");
+ this.power = new MageInt(3);
+ this.toughness = new MageInt(3);
+
+ // Whenever a creature you control attacks, defending player loses 1 life and you gain 1 life.
+ this.addAbility(new BrutalHordechiefTriggeredAbility());
+
+ // {3}{R/W}{R/W}: Creatures your opponents control block this turn if able, and you choose how those creatures block.
+ Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new BlocksIfAbleAllEffect(filter), new ManaCostsImpl("{3}{R/W}{R/W}"));
+ ability.addEffect(new BrutalHordechiefReplacementEffect());
+ this.addAbility(ability);
+ }
+
+ public BrutalHordechief(final BrutalHordechief card) {
+ super(card);
+ }
+
+ @Override
+ public BrutalHordechief copy() {
+ return new BrutalHordechief(this);
+ }
+}
+
+class BrutalHordechiefTriggeredAbility extends TriggeredAbilityImpl {
+
+ public BrutalHordechiefTriggeredAbility() {
+ super(Zone.BATTLEFIELD, new DamageTargetEffect(1));
+ this.addEffect(new GainLifeEffect(1));
+ }
+
+ public BrutalHordechiefTriggeredAbility(final BrutalHordechiefTriggeredAbility ability) {
+ super(ability);
+ }
+
+ @Override
+ public BrutalHordechiefTriggeredAbility copy() {
+ return new BrutalHordechiefTriggeredAbility(this);
+ }
+
+ @Override
+ public boolean checkTrigger(GameEvent event, Game game) {
+ if (event.getType() == GameEvent.EventType.ATTACKER_DECLARED) {
+ Permanent source = game.getPermanent(event.getSourceId());
+ if (source != null && source.getControllerId().equals(controllerId)) {
+ UUID defendingPlayerId = game.getCombat().getDefendingPlayerId(event.getSourceId(), game);
+ this.getEffects().get(0).setTargetPointer(new FixedTarget(defendingPlayerId));
+ return true;
+ }
+ }
+ return false;
+ }
+
+ @Override
+ public String getRule() {
+ return "Whenever a creature you control attacks, defending player loses 1 life and you gain 1 life.";
+ }
+}
+
+class BrutalHordechiefReplacementEffect extends ReplacementEffectImpl {
+
+ public BrutalHordechiefReplacementEffect() {
+ super(Duration.EndOfCombat, Outcome.Benefit);
+ staticText = ", and you choose how those creatures block";
+ }
+
+ public BrutalHordechiefReplacementEffect(final BrutalHordechiefReplacementEffect effect) {
+ super(effect);
+ }
+
+ @Override
+ public BrutalHordechiefReplacementEffect copy() {
+ return new BrutalHordechiefReplacementEffect(this);
+ }
+
+ @Override
+ public boolean apply(Game game, Ability source) {
+ return false;
+ }
+
+ @Override
+ public boolean replaceEvent(GameEvent event, Ability source, Game game) {
+ Player blockController = game.getPlayer(source.getControllerId());
+ if (blockController != null) {
+ game.getCombat().selectBlockers(blockController, game);
+ return true;
+ }
+ return false;
+ }
+
+ @Override
+ public boolean checksEventType(GameEvent event, Game game) {
+ return event.getType() == GameEvent.EventType.DECLARING_BLOCKERS;
+ }
+
+ @Override
+ public boolean applies(GameEvent event, Ability source, Game game) {
+ Player player = game.getPlayer(event.getPlayerId());
+ return player != null && game.isOpponent(player, source.getControllerId());
+ }
+}
\ No newline at end of file
diff --git a/Mage.Sets/src/mage/sets/fatereforged/CrucibleOfTheSpiritDragon.java b/Mage.Sets/src/mage/sets/fatereforged/CrucibleOfTheSpiritDragon.java
new file mode 100644
index 00000000000..6a065ebd932
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/fatereforged/CrucibleOfTheSpiritDragon.java
@@ -0,0 +1,123 @@
+/*
+ * Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without modification, are
+ * permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice, this list of
+ * conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright notice, this list
+ * of conditions and the following disclaimer in the documentation and/or other materials
+ * provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * The views and conclusions contained in the software and documentation are those of the
+ * authors and should not be interpreted as representing official policies, either expressed
+ * or implied, of BetaSteward_at_googlemail.com.
+ */
+package mage.sets.fatereforged;
+
+import java.util.UUID;
+import mage.ConditionalMana;
+import mage.MageObject;
+import mage.Mana;
+import mage.abilities.Ability;
+import mage.abilities.common.SimpleActivatedAbility;
+import mage.abilities.condition.Condition;
+import mage.abilities.costs.common.RemoveVariableCountersSourceCost;
+import mage.abilities.costs.common.TapSourceCost;
+import mage.abilities.costs.mana.GenericManaCost;
+import mage.abilities.dynamicvalue.common.RemovedCountersForCostValue;
+import mage.abilities.effects.common.counter.AddCountersSourceEffect;
+import mage.abilities.mana.ColorlessManaAbility;
+import mage.abilities.mana.ConditionalAnyColorManaAbility;
+import mage.abilities.mana.builder.ConditionalManaBuilder;
+import mage.cards.CardImpl;
+import mage.constants.CardType;
+import mage.constants.Rarity;
+import mage.constants.Zone;
+import mage.counters.CounterType;
+import mage.game.Game;
+
+/**
+ *
+ * @author LevelX2
+ */
+public class CrucibleOfTheSpiritDragon extends CardImpl {
+
+ public CrucibleOfTheSpiritDragon(UUID ownerId) {
+ super(ownerId, 167, "Crucible of the Spirit Dragon", Rarity.RARE, new CardType[]{CardType.LAND}, "");
+ this.expansionSetCode = "FRF";
+
+ // {T}: Add {1} to your mana pool.
+ this.addAbility(new ColorlessManaAbility());
+
+ // {1}, {T}: Put a storage counter on Crucible of the Spirit Dragon.
+ Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new AddCountersSourceEffect(CounterType.STORAGE.createInstance()),new GenericManaCost(1));
+ ability.addCost(new TapSourceCost());
+ this.addAbility(ability);
+
+ // {T}, Remove X storage counters from Crucible of the Spirit Dragon: Add X mana in any combination of colors to your mana pool. Spend this mana only to cast Dragon spells or activate abilities of Dragons.
+ ability = new ConditionalAnyColorManaAbility(
+ new TapSourceCost(),
+ new RemovedCountersForCostValue(),
+ new CrucibleOfTheSpiritDragonManaBuilder(),
+ false
+ );
+ ability.addCost(new RemoveVariableCountersSourceCost(CounterType.STORAGE.createInstance()));
+ this.addAbility(ability);
+ }
+
+ public CrucibleOfTheSpiritDragon(final CrucibleOfTheSpiritDragon card) {
+ super(card);
+ }
+
+ @Override
+ public CrucibleOfTheSpiritDragon copy() {
+ return new CrucibleOfTheSpiritDragon(this);
+ }
+}
+
+class CrucibleOfTheSpiritDragonManaBuilder extends ConditionalManaBuilder {
+
+ @Override
+ public ConditionalMana build(Object... options) {
+ return new CrucibleOfTheSpiritDragonConditionalMana(this.mana);
+ }
+
+ @Override
+ public String getRule() {
+ return "Spend this mana only to cast Dragon spells or activate abilities of Dragons";
+ }
+}
+
+class CrucibleOfTheSpiritDragonConditionalMana extends ConditionalMana {
+
+ public CrucibleOfTheSpiritDragonConditionalMana(Mana mana) {
+ super(mana);
+ this.staticText = "Spend this mana only to cast Dragon spells or activate abilities of Dragons";
+ addCondition(new CrucibleOfTheSpiritDragonManaCondition());
+ }
+}
+
+class CrucibleOfTheSpiritDragonManaCondition implements Condition {
+
+ @Override
+ public boolean apply(Game game, Ability source) {
+ MageObject object = game.getObject(source.getSourceId());
+ if (object != null && object.hasSubtype("Dragon")) {
+ return true;
+ }
+ return false;
+ }
+}
\ No newline at end of file
diff --git a/Mage.Sets/src/mage/sets/magic2013/OdricMasterTactician.java b/Mage.Sets/src/mage/sets/magic2013/OdricMasterTactician.java
index c4e614d3057..b73b61801a1 100644
--- a/Mage.Sets/src/mage/sets/magic2013/OdricMasterTactician.java
+++ b/Mage.Sets/src/mage/sets/magic2013/OdricMasterTactician.java
@@ -115,7 +115,7 @@ class OdricMasterTacticianTriggeredAbility extends TriggeredAbilityImpl {
@Override
public String getRule() {
- return "Whenever Odric, Master Tactician and at least three other creatures attack, you choose which creatures block this combat and how those creatures block.";
+ return "Whenever {this} and at least three other creatures attack, you choose which creatures block this combat and how those creatures block.";
}
}
@@ -150,17 +150,19 @@ class OdricMasterTacticianEffect extends ReplacementEffectImpl {
return false;
}
+ @Override
+ public boolean checksEventType(GameEvent event, Game game) {
+ return event.getType() == GameEvent.EventType.DECLARING_BLOCKERS;
+ }
+
@Override
public boolean applies(GameEvent event, Ability source, Game game) {
- if (event.getType() == GameEvent.EventType.DECLARING_BLOCKERS) {
- Object object = getValue("apply_" + source.getSourceId());
- if (object != null && object instanceof Boolean) {
- if ((Boolean)object) {
- return true; // replace event
- }
+ Object object = getValue("apply_" + source.getSourceId());
+ if (object != null && object instanceof Boolean) {
+ if ((Boolean)object) {
+ return true; // replace event
}
}
-
return false;
}
}
diff --git a/Mage.Tests/src/test/java/org/mage/test/cards/abilities/keywords/DeathtouchTest.java b/Mage.Tests/src/test/java/org/mage/test/cards/abilities/keywords/DeathtouchTest.java
index ed7cbf314fb..57593d88f01 100644
--- a/Mage.Tests/src/test/java/org/mage/test/cards/abilities/keywords/DeathtouchTest.java
+++ b/Mage.Tests/src/test/java/org/mage/test/cards/abilities/keywords/DeathtouchTest.java
@@ -90,7 +90,7 @@ public class DeathtouchTest extends CardTestPlayerBase {
activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Equip {2}", "Marath, Will of the Wild");
- activateAbility(1, PhaseStep.POSTCOMBAT_MAIN, playerA, "{X},Remove X +1/+1 counters from Marath: Choose one -
&bull Put X +1/+1 counters on target creature.
&bull {source} deals X damage to target creature or player.
&bull Put an X/X green Elemental creature token onto the battlefield.
", "Archangel of Thune");
+ activateAbility(1, PhaseStep.POSTCOMBAT_MAIN, playerA, "{X},Remove X +1/+1 counters from Marath: Choose one —
&bull Put X +1/+1 counters on target creature.
&bull {source} deals X damage to target creature or player.
&bull Put an X/X green Elemental creature token onto the battlefield.
", "Archangel of Thune");
setChoice(playerA, "X=3");
setModeChoice(playerA, "2"); // Marath deals X damage to target creature or player
diff --git a/Mage/src/mage/abilities/effects/common/AddConditionalManaOfAnyColorEffect.java b/Mage/src/mage/abilities/effects/common/AddConditionalManaOfAnyColorEffect.java
index 81659d90b47..946bbf9613e 100644
--- a/Mage/src/mage/abilities/effects/common/AddConditionalManaOfAnyColorEffect.java
+++ b/Mage/src/mage/abilities/effects/common/AddConditionalManaOfAnyColorEffect.java
@@ -29,6 +29,8 @@ package mage.abilities.effects.common;
import mage.Mana;
import mage.abilities.Ability;
+import mage.abilities.dynamicvalue.DynamicValue;
+import mage.abilities.dynamicvalue.common.StaticValue;
import mage.abilities.mana.builder.ConditionalManaBuilder;
import mage.choices.ChoiceColor;
import mage.game.Game;
@@ -39,20 +41,34 @@ import mage.players.Player;
*/
public class AddConditionalManaOfAnyColorEffect extends ManaEffect {
- private final int amount;
+ private final DynamicValue amount;
private final ConditionalManaBuilder manaBuilder;
+ private final boolean oneChoice;
public AddConditionalManaOfAnyColorEffect(int amount, ConditionalManaBuilder manaBuilder) {
+ this(new StaticValue(amount), manaBuilder);
+ }
+
+ public AddConditionalManaOfAnyColorEffect(DynamicValue amount, ConditionalManaBuilder manaBuilder) {
+ this(amount, manaBuilder, true);
+ }
+
+ public AddConditionalManaOfAnyColorEffect(DynamicValue amount, ConditionalManaBuilder manaBuilder, boolean oneChoice) {
super();
this.amount = amount;
this.manaBuilder = manaBuilder;
- staticText = "Add " + amount + " mana of any one color to your mana pool. " + manaBuilder.getRule();
+ this.oneChoice = oneChoice;
+ //
+ staticText = "Add " + amount + " mana of " +
+ (oneChoice ? "any one color":"in any combination of colors") +
+ " to your mana pool. " + manaBuilder.getRule();
}
public AddConditionalManaOfAnyColorEffect(final AddConditionalManaOfAnyColorEffect effect) {
super(effect);
this.amount = effect.amount;
this.manaBuilder = effect.manaBuilder;
+ this.oneChoice = effect.oneChoice;
}
@Override
@@ -62,15 +78,20 @@ public class AddConditionalManaOfAnyColorEffect extends ManaEffect {
@Override
public boolean apply(Game game, Ability source) {
- Player player = game.getPlayer(source.getControllerId());
- if (player == null) {
+ Player controller = game.getPlayer(source.getControllerId());
+ if (controller == null) {
return false;
}
+ int value = amount.calculate(game, source, this);
boolean result = false;
- for (int i = 0; i < amount; i++) {
- ChoiceColor choice = (ChoiceColor) source.getChoices().get(i);
-
+ ChoiceColor choice = new ChoiceColor();
+ for (int i = 0; i < value; i++) {
+ if (!choice.isChosen()) {
+ if (!controller.choose(outcome, choice, game)) {
+ return false;
+ }
+ }
Mana mana = null;
if (choice.getColor().isBlack()) {
mana = manaBuilder.setMana(Mana.BlackMana(1), source, game).build();
@@ -85,10 +106,12 @@ public class AddConditionalManaOfAnyColorEffect extends ManaEffect {
}
if (mana != null) {
- player.getManaPool().addMana(mana, game, source);
+ controller.getManaPool().addMana(mana, game, source);
result = true;
}
-
+ if (!oneChoice) {
+ choice.clearChoice();
+ }
}
diff --git a/Mage/src/mage/abilities/effects/common/AddManaInAnyCombinationEffect.java b/Mage/src/mage/abilities/effects/common/AddManaInAnyCombinationEffect.java
index 2bd0f6317a8..2e6ce2a8e41 100644
--- a/Mage/src/mage/abilities/effects/common/AddManaInAnyCombinationEffect.java
+++ b/Mage/src/mage/abilities/effects/common/AddManaInAnyCombinationEffect.java
@@ -90,7 +90,7 @@ public class AddManaInAnyCombinationEffect extends ManaEffect {
sb.append(CardUtil.numberToText(amount.toString()));
sb.append(" mana in any combination of ");
if (manaSymbols.size() == 5) {
- sb.append("of colors");
+ sb.append("colors");
} else {
int i = 0;
for (ColoredManaSymbol coloredManaSymbol: manaSymbols) {
diff --git a/Mage/src/mage/abilities/effects/common/combat/AttacksIfAbleAllEffect.java b/Mage/src/mage/abilities/effects/common/combat/AttacksIfAbleAllEffect.java
index 28fc7f2b62c..e2124a37bb9 100644
--- a/Mage/src/mage/abilities/effects/common/combat/AttacksIfAbleAllEffect.java
+++ b/Mage/src/mage/abilities/effects/common/combat/AttacksIfAbleAllEffect.java
@@ -22,8 +22,15 @@ public class AttacksIfAbleAllEffect extends RequirementEffect {
private final FilterCreaturePermanent filter;
public AttacksIfAbleAllEffect(FilterCreaturePermanent filter) {
- super(Duration.WhileOnBattlefield);
- staticText = new StringBuilder(filter.getMessage()).append(" attack each turn if able").toString();
+ this(filter, Duration.WhileOnBattlefield);
+ }
+
+ public AttacksIfAbleAllEffect(FilterCreaturePermanent filter, Duration duration) {
+ super(duration);
+ staticText = new StringBuilder(filter.getMessage())
+ .append(" attack ")
+ .append(duration.equals(Duration.EndOfTurn) ? "this":"each")
+ .append(" turn if able").toString();
this.filter = filter;
}
@@ -44,12 +51,12 @@ public class AttacksIfAbleAllEffect extends RequirementEffect {
@Override
public boolean mustAttack(Game game) {
- return true;
+ return false;
}
@Override
public boolean mustBlock(Game game) {
- return false;
+ return true;
}
}
diff --git a/Mage/src/mage/abilities/effects/common/combat/BlocksIfAbleAllEffect.java b/Mage/src/mage/abilities/effects/common/combat/BlocksIfAbleAllEffect.java
new file mode 100644
index 00000000000..5db653745c0
--- /dev/null
+++ b/Mage/src/mage/abilities/effects/common/combat/BlocksIfAbleAllEffect.java
@@ -0,0 +1,83 @@
+/*
+ * Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without modification, are
+ * permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice, this list of
+ * conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright notice, this list
+ * of conditions and the following disclaimer in the documentation and/or other materials
+ * provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * The views and conclusions contained in the software and documentation are those of the
+ * authors and should not be interpreted as representing official policies, either expressed
+ * or implied, of BetaSteward_at_googlemail.com.
+ */
+package mage.abilities.effects.common.combat;
+
+import mage.abilities.Ability;
+import mage.abilities.effects.RequirementEffect;
+import mage.constants.Duration;
+import mage.filter.common.FilterCreaturePermanent;
+import mage.game.Game;
+import mage.game.permanent.Permanent;
+
+/**
+ *
+ * @author LevelX2
+ */
+
+public class BlocksIfAbleAllEffect extends RequirementEffect {
+
+ private final FilterCreaturePermanent filter;
+
+ public BlocksIfAbleAllEffect(FilterCreaturePermanent filter) {
+ this(filter,Duration.WhileOnBattlefield);
+ }
+
+ public BlocksIfAbleAllEffect(FilterCreaturePermanent filter, Duration duration) {
+ super(Duration.WhileOnBattlefield);
+ staticText = new StringBuilder(filter.getMessage())
+ .append(" block ")
+ .append(duration.equals(Duration.EndOfTurn) ? "this":"each")
+ .append(" turn if able").toString();
+ this.filter = filter;
+ }
+ public BlocksIfAbleAllEffect(final BlocksIfAbleAllEffect effect) {
+ super(effect);
+ this.filter = effect.filter;
+ }
+
+ @Override
+ public BlocksIfAbleAllEffect copy() {
+ return new BlocksIfAbleAllEffect(this);
+ }
+
+ @Override
+ public boolean applies(Permanent permanent, Ability source, Game game) {
+ return filter.match(permanent, source.getSourceId(), source.getControllerId(), game);
+ }
+
+ @Override
+ public boolean mustAttack(Game game) {
+ return true;
+ }
+
+ @Override
+ public boolean mustBlock(Game game) {
+ return false;
+ }
+
+}
diff --git a/Mage/src/mage/abilities/mana/ConditionalAnyColorManaAbility.java b/Mage/src/mage/abilities/mana/ConditionalAnyColorManaAbility.java
index a5892859e28..5aa3331e23f 100644
--- a/Mage/src/mage/abilities/mana/ConditionalAnyColorManaAbility.java
+++ b/Mage/src/mage/abilities/mana/ConditionalAnyColorManaAbility.java
@@ -27,13 +27,16 @@
*/
package mage.abilities.mana;
+import java.util.List;
import mage.Mana;
import mage.abilities.costs.Cost;
import mage.abilities.costs.common.TapSourceCost;
+import mage.abilities.dynamicvalue.DynamicValue;
+import mage.abilities.dynamicvalue.common.StaticValue;
import mage.abilities.effects.common.AddConditionalManaOfAnyColorEffect;
import mage.abilities.mana.builder.ConditionalManaBuilder;
-import mage.choices.ChoiceColor;
import mage.constants.Zone;
+import mage.game.Game;
/**
* For cards like:
@@ -43,6 +46,8 @@ import mage.constants.Zone;
*/
public class ConditionalAnyColorManaAbility extends ManaAbility {
+ private DynamicValue amount;
+
public ConditionalAnyColorManaAbility(int amount, ConditionalManaBuilder manaBuilder) {
this(new TapSourceCost(), amount, manaBuilder);
}
@@ -52,22 +57,24 @@ public class ConditionalAnyColorManaAbility extends ManaAbility {
}
public ConditionalAnyColorManaAbility(Cost cost, int amount, ConditionalManaBuilder manaBuilder, boolean oneChoice) {
- super(Zone.BATTLEFIELD, new AddConditionalManaOfAnyColorEffect(oneChoice ? 1 :amount, manaBuilder), cost);
- int choices = amount;
- if (oneChoice) {
- for (int i = 1; i < amount; i++) {
- this.addEffect(new AddConditionalManaOfAnyColorEffect(1 , manaBuilder));
- }
- choices = 1;
- }
- for (int i = 0; i < choices; i++) {
- this.addChoice(new ChoiceColor());
- }
- this.netMana.add(new Mana(0,0,0,0,0,0,amount));
+ this(cost, new StaticValue(amount), manaBuilder, oneChoice);
+ }
+
+ public ConditionalAnyColorManaAbility(Cost cost, DynamicValue amount, ConditionalManaBuilder manaBuilder, boolean oneChoice) {
+ super(Zone.BATTLEFIELD, new AddConditionalManaOfAnyColorEffect(amount, manaBuilder, oneChoice), cost);
+ this.amount = amount;
}
public ConditionalAnyColorManaAbility(final ConditionalAnyColorManaAbility ability) {
super(ability);
+ this.amount = ability.amount;
+ }
+
+ @Override
+ public List getNetMana(Game game) {
+ this.netMana.clear();
+ this.netMana.add(new Mana(0,0,0,0,0,0, amount.calculate(game, this, null)));
+ return super.getNetMana(game);
}
@Override