From 03d4fb70a66f2e1438603b2e5c8ffa87b3329e4f Mon Sep 17 00:00:00 2001 From: theelk801 Date: Fri, 29 Aug 2025 22:21:33 -0400 Subject: [PATCH] [SPM] Implement Prowler, Clawed Thief --- .../src/mage/cards/p/ProwlerClawedThief.java | 55 +++++++++++++++++++ Mage.Sets/src/mage/sets/MarvelsSpiderMan.java | 1 + 2 files changed, 56 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/p/ProwlerClawedThief.java diff --git a/Mage.Sets/src/mage/cards/p/ProwlerClawedThief.java b/Mage.Sets/src/mage/cards/p/ProwlerClawedThief.java new file mode 100644 index 00000000000..cd3983cd176 --- /dev/null +++ b/Mage.Sets/src/mage/cards/p/ProwlerClawedThief.java @@ -0,0 +1,55 @@ +package mage.cards.p; + +import mage.MageInt; +import mage.abilities.common.EntersBattlefieldAllTriggeredAbility; +import mage.abilities.effects.keyword.ConniveSourceEffect; +import mage.abilities.keyword.MenaceAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.filter.FilterPermanent; +import mage.filter.common.FilterControlledPermanent; +import mage.filter.predicate.mageobject.AnotherPredicate; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class ProwlerClawedThief extends CardImpl { + + private static final FilterPermanent filter + = new FilterControlledPermanent(SubType.VILLAIN, "another Villain you control"); + + static { + filter.add(AnotherPredicate.instance); + } + + public ProwlerClawedThief(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{U}{B}"); + + this.supertype.add(SuperType.LEGENDARY); + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.ROGUE); + this.subtype.add(SubType.VILLAIN); + this.power = new MageInt(2); + this.toughness = new MageInt(3); + + // Menace + this.addAbility(new MenaceAbility()); + + // Whenever another Villain you control enters, Prowler connives. + this.addAbility(new EntersBattlefieldAllTriggeredAbility(new ConniveSourceEffect("{this}"), filter)); + } + + private ProwlerClawedThief(final ProwlerClawedThief card) { + super(card); + } + + @Override + public ProwlerClawedThief copy() { + return new ProwlerClawedThief(this); + } +} diff --git a/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java b/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java index ff537374882..36d157a1381 100644 --- a/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java +++ b/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java @@ -70,6 +70,7 @@ public final class MarvelsSpiderMan extends ExpansionSet { cards.add(new SetCardInfo("Oscorp Research Team", 40, Rarity.COMMON, mage.cards.o.OscorpResearchTeam.class)); cards.add(new SetCardInfo("Plains", 189, Rarity.LAND, mage.cards.basiclands.Plains.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Plains", 194, Rarity.LAND, mage.cards.basiclands.Plains.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Prowler, Clawed Thief", 138, Rarity.UNCOMMON, mage.cards.p.ProwlerClawedThief.class)); cards.add(new SetCardInfo("Raging Goblinoids", 85, Rarity.UNCOMMON, mage.cards.r.RagingGoblinoids.class)); cards.add(new SetCardInfo("Risky Research", 62, Rarity.COMMON, mage.cards.r.RiskyResearch.class)); cards.add(new SetCardInfo("Romantic Rendezvous", 86, Rarity.COMMON, mage.cards.r.RomanticRendezvous.class));