From 517e92ec717dff92c7741a3175b2f60173b84baf Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Thu, 3 Oct 2019 21:21:10 -0400 Subject: [PATCH] Implemented Wall of Resistance --- .../src/mage/cards/w/WallOfResistance.java | 59 +++++++++++++++++++ Mage.Sets/src/mage/sets/Mirage.java | 1 + 2 files changed, 60 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/w/WallOfResistance.java diff --git a/Mage.Sets/src/mage/cards/w/WallOfResistance.java b/Mage.Sets/src/mage/cards/w/WallOfResistance.java new file mode 100644 index 00000000000..06099d7b1d9 --- /dev/null +++ b/Mage.Sets/src/mage/cards/w/WallOfResistance.java @@ -0,0 +1,59 @@ +package mage.cards.w; + +import mage.MageInt; +import mage.abilities.common.BeginningOfEndStepTriggeredAbility; +import mage.abilities.condition.Condition; +import mage.abilities.condition.common.SourceDealtDamageCondition; +import mage.abilities.decorator.ConditionalInterveningIfTriggeredAbility; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.abilities.keyword.DefenderAbility; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.TargetController; +import mage.counters.CounterType; +import mage.watchers.common.DamageDoneWatcher; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class WallOfResistance extends CardImpl { + + private static final Condition condition = new SourceDealtDamageCondition(1); + + public WallOfResistance(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{W}"); + + this.subtype.add(SubType.WALL); + this.power = new MageInt(0); + this.toughness = new MageInt(3); + + // Defender + this.addAbility(DefenderAbility.getInstance()); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // At the beginning of each end step, if Wall of Resistance was dealt damage this turn, put a +0/+1 counter on it. + this.addAbility(new ConditionalInterveningIfTriggeredAbility( + new BeginningOfEndStepTriggeredAbility( + new AddCountersSourceEffect(CounterType.P0P1.createInstance()), + TargetController.ANY, false + ), condition, "At the beginning of each end step, " + + "if {this} was dealt damage this turn, put a +0/+1 counter on it." + ), new DamageDoneWatcher()); + } + + private WallOfResistance(final WallOfResistance card) { + super(card); + } + + @Override + public WallOfResistance copy() { + return new WallOfResistance(this); + } +} diff --git a/Mage.Sets/src/mage/sets/Mirage.java b/Mage.Sets/src/mage/sets/Mirage.java index 9f348e37d71..e1190f3f873 100644 --- a/Mage.Sets/src/mage/sets/Mirage.java +++ b/Mage.Sets/src/mage/sets/Mirage.java @@ -328,6 +328,7 @@ public final class Mirage extends ExpansionSet { cards.add(new SetCardInfo("Volcanic Dragon", 201, Rarity.RARE, mage.cards.v.VolcanicDragon.class)); cards.add(new SetCardInfo("Volcanic Geyser", 202, Rarity.UNCOMMON, mage.cards.v.VolcanicGeyser.class)); cards.add(new SetCardInfo("Waiting in the Weeds", 252, Rarity.RARE, mage.cards.w.WaitingInTheWeeds.class)); + cards.add(new SetCardInfo("Wall of Resistance", 46, Rarity.COMMON, mage.cards.w.WallOfResistance.class)); cards.add(new SetCardInfo("Wall of Roots", 253, Rarity.COMMON, mage.cards.w.WallOfRoots.class)); cards.add(new SetCardInfo("Ward of Lights", 47, Rarity.COMMON, mage.cards.w.WardOfLights.class)); cards.add(new SetCardInfo("Warping Wurm", 287, Rarity.RARE, mage.cards.w.WarpingWurm.class));