From 8456d8f86858e718cc4fd618237c1edbaa718b8d Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Wed, 3 Nov 2021 21:14:07 -0400 Subject: [PATCH] [VOW] Implemented Sawblade Stinger --- .../src/mage/cards/s/SawbladeSlinger.java | 63 +++++++++++++++++++ .../src/mage/sets/InnistradCrimsonVow.java | 1 + 2 files changed, 64 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/s/SawbladeSlinger.java diff --git a/Mage.Sets/src/mage/cards/s/SawbladeSlinger.java b/Mage.Sets/src/mage/cards/s/SawbladeSlinger.java new file mode 100644 index 0000000000..e0dcf412ad --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/SawbladeSlinger.java @@ -0,0 +1,63 @@ +package mage.cards.s; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.Mode; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.effects.common.DestroyTargetEffect; +import mage.abilities.effects.common.FightTargetSourceEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.TargetController; +import mage.filter.FilterPermanent; +import mage.filter.common.FilterArtifactPermanent; +import mage.target.TargetPermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class SawbladeSlinger extends CardImpl { + + private static final FilterPermanent filter = new FilterArtifactPermanent("artifact an opponent controls"); + private static final FilterPermanent filter2 = new FilterPermanent(SubType.ZOMBIE, "Zombie and opponent controls"); + + static { + filter.add(TargetController.OPPONENT.getControllerPredicate()); + filter2.add(TargetController.OPPONENT.getControllerPredicate()); + } + + public SawbladeSlinger(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{3}{G}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.ARCHER); + this.power = new MageInt(4); + this.toughness = new MageInt(3); + + // When Sawblade Slinger enters the battlefield, choose up to one — + // • Destroy target artifact an opponent controls. + Ability ability = new EntersBattlefieldTriggeredAbility(new DestroyTargetEffect()); + ability.addTarget(new TargetPermanent(filter)); + ability.getModes().setMinModes(0); + ability.getModes().setMaxModes(1); + + // • Sawblade Slinger fights target Zombie an opponent controls. + Mode mode = new Mode(new FightTargetSourceEffect()); + mode.addTarget(new TargetPermanent(filter2)); + ability.addMode(mode); + this.addAbility(ability); + } + + private SawbladeSlinger(final SawbladeSlinger card) { + super(card); + } + + @Override + public SawbladeSlinger copy() { + return new SawbladeSlinger(this); + } +} diff --git a/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java b/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java index b52906afe3..f7f9f10b07 100644 --- a/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java +++ b/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java @@ -115,6 +115,7 @@ public final class InnistradCrimsonVow extends ExpansionSet { cards.add(new SetCardInfo("Rot-Tide Gargantua", 129, Rarity.COMMON, mage.cards.r.RotTideGargantua.class)); cards.add(new SetCardInfo("Runebound Wolf", 176, Rarity.UNCOMMON, mage.cards.r.RuneboundWolf.class)); cards.add(new SetCardInfo("Sanctify", 33, Rarity.COMMON, mage.cards.s.Sanctify.class)); + cards.add(new SetCardInfo("Sawblade Slinger", 217, Rarity.UNCOMMON, mage.cards.s.SawbladeSlinger.class)); cards.add(new SetCardInfo("Scattered Thoughts", 74, Rarity.COMMON, mage.cards.s.ScatteredThoughts.class)); cards.add(new SetCardInfo("Shattered Sanctum", 264, Rarity.RARE, mage.cards.s.ShatteredSanctum.class)); cards.add(new SetCardInfo("Sigarda's Imprisonment", 35, Rarity.COMMON, mage.cards.s.SigardasImprisonment.class));