diff --git a/Mage.Sets/src/mage/cards/s/SabotageStrategist.java b/Mage.Sets/src/mage/cards/s/SabotageStrategist.java new file mode 100644 index 00000000000..75f6fa15714 --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/SabotageStrategist.java @@ -0,0 +1,92 @@ +package mage.cards.s; + +import mage.MageInt; +import mage.abilities.TriggeredAbilityImpl; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.common.continuous.BoostTargetEffect; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.abilities.keyword.ExhaustAbility; +import mage.abilities.keyword.FlyingAbility; +import mage.abilities.keyword.VigilanceAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.Zone; +import mage.counters.CounterType; +import mage.game.Game; +import mage.game.events.DefenderAttackedEvent; +import mage.game.events.GameEvent; +import mage.target.targetpointer.FixedTargets; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class SabotageStrategist extends CardImpl { + + public SabotageStrategist(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{U}{U}"); + + this.subtype.add(SubType.VEDALKEN); + this.subtype.add(SubType.RANGER); + this.power = new MageInt(2); + this.toughness = new MageInt(2); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Vigilance + this.addAbility(VigilanceAbility.getInstance()); + + // Whenever one or more creatures attack you, those creatures get -1/-0 until end of turn. + this.addAbility(new SabotageStrategistTriggeredAbility()); + + // Exhaust -- {5}{U}{U}: Put three +1/+1 counters on this creature. + this.addAbility(new ExhaustAbility( + new AddCountersSourceEffect(CounterType.P1P1.createInstance(3)), new ManaCostsImpl<>("{5}{U}{U}") + )); + } + + private SabotageStrategist(final SabotageStrategist card) { + super(card); + } + + @Override + public SabotageStrategist copy() { + return new SabotageStrategist(this); + } +} + +class SabotageStrategistTriggeredAbility extends TriggeredAbilityImpl { + + SabotageStrategistTriggeredAbility() { + super(Zone.BATTLEFIELD, new BoostTargetEffect(-1, 0)); + this.setTriggerPhrase("Whenever one or more creatures attack you, "); + } + + private SabotageStrategistTriggeredAbility(final SabotageStrategistTriggeredAbility ability) { + super(ability); + } + + @Override + public SabotageStrategistTriggeredAbility copy() { + return new SabotageStrategistTriggeredAbility(this); + } + + @Override + public boolean checkEventType(GameEvent event, Game game) { + return event.getType() == GameEvent.EventType.DEFENDER_ATTACKED; + } + + @Override + public boolean checkTrigger(GameEvent event, Game game) { + DefenderAttackedEvent dEvent = (DefenderAttackedEvent) event; + if (!isControlledBy(dEvent.getTargetId())) { + return false; + } + this.getEffects().setTargetPointer(new FixedTargets(dEvent.getAttackers(game), game)); + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/Aetherdrift.java b/Mage.Sets/src/mage/sets/Aetherdrift.java index f7805ae7a70..cb375f8f4fe 100644 --- a/Mage.Sets/src/mage/sets/Aetherdrift.java +++ b/Mage.Sets/src/mage/sets/Aetherdrift.java @@ -181,6 +181,7 @@ public final class Aetherdrift extends ExpansionSet { cards.add(new SetCardInfo("Rugged Highlands", 262, Rarity.COMMON, mage.cards.r.RuggedHighlands.class)); cards.add(new SetCardInfo("Run Over", 179, Rarity.COMMON, mage.cards.r.RunOver.class)); cards.add(new SetCardInfo("Sab-Sunen, Luxa Embodied", 221, Rarity.MYTHIC, mage.cards.s.SabSunenLuxaEmbodied.class)); + cards.add(new SetCardInfo("Sabotage Strategist", 59, Rarity.UNCOMMON, mage.cards.s.SabotageStrategist.class)); cards.add(new SetCardInfo("Salvation Engine", 27, Rarity.MYTHIC, mage.cards.s.SalvationEngine.class)); cards.add(new SetCardInfo("Scoured Barrens", 263, Rarity.COMMON, mage.cards.s.ScouredBarrens.class)); cards.add(new SetCardInfo("Scrap Compactor", 242, Rarity.COMMON, mage.cards.s.ScrapCompactor.class));