From f1a05db32c841f6521661f75ad64d0acbd6cd4d2 Mon Sep 17 00:00:00 2001 From: jmlundeen Date: Mon, 7 Apr 2025 13:46:11 -0500 Subject: [PATCH] [TDM] Implement Scavenger Regent --- .../src/mage/cards/s/ScavengerRegent.java | 60 +++++++++++++++++++ .../src/mage/sets/TarkirDragonstorm.java | 1 + 2 files changed, 61 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/s/ScavengerRegent.java diff --git a/Mage.Sets/src/mage/cards/s/ScavengerRegent.java b/Mage.Sets/src/mage/cards/s/ScavengerRegent.java new file mode 100644 index 00000000000..3c4e6cb2996 --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/ScavengerRegent.java @@ -0,0 +1,60 @@ +package mage.cards.s; + +import java.util.UUID; +import mage.MageInt; +import mage.abilities.costs.common.DiscardCardCost; +import mage.abilities.dynamicvalue.DynamicValue; +import mage.abilities.dynamicvalue.common.GetXValue; +import mage.abilities.dynamicvalue.common.SignInversionDynamicValue; +import mage.abilities.effects.common.continuous.BoostAllEffect; +import mage.cards.OmenCard; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.abilities.keyword.FlyingAbility; +import mage.abilities.keyword.WardAbility; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.filter.common.FilterCreaturePermanent; +import mage.filter.predicate.Predicates; + +/** + * + * @author Jmlundeen + */ +public final class ScavengerRegent extends OmenCard { + + private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("each non-Dragon creature"); + private static final DynamicValue xValue = new SignInversionDynamicValue(GetXValue.instance); + + static { + filter.add(Predicates.not(SubType.DRAGON.getPredicate())); + } + + public ScavengerRegent(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, new CardType[]{CardType.SORCERY}, "{3}{B}", "Exude Toxin", "{X}{B}{B}"); + + this.subtype.add(SubType.DRAGON); + this.power = new MageInt(4); + this.toughness = new MageInt(4); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Ward--Discard a card. + this.addAbility(new WardAbility(new DiscardCardCost())); + + // Exude Toxin + // Each non-Dragon creature gets -X/-X until end of turn. + this.getSpellCard().getSpellAbility().addEffect(new BoostAllEffect(xValue, xValue, Duration.EndOfTurn, filter, false)); + this.finalizeOmen(); + } + + private ScavengerRegent(final ScavengerRegent card) { + super(card); + } + + @Override + public ScavengerRegent copy() { + return new ScavengerRegent(this); + } +} diff --git a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java index 50176a483c0..e1ec48d4f69 100644 --- a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java +++ b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java @@ -197,6 +197,7 @@ public final class TarkirDragonstorm extends ExpansionSet { cards.add(new SetCardInfo("Sandsteppe Citadel", 266, Rarity.UNCOMMON, mage.cards.s.SandsteppeCitadel.class)); cards.add(new SetCardInfo("Sarkhan's Resolve", 158, Rarity.COMMON, mage.cards.s.SarkhansResolve.class)); cards.add(new SetCardInfo("Sarkhan, Dragon Ascendant", 118, Rarity.RARE, mage.cards.s.SarkhanDragonAscendant.class)); + cards.add(new SetCardInfo("Scavenger Regent", 90, Rarity.RARE, mage.cards.s.ScavengerRegent.class)); cards.add(new SetCardInfo("Scoured Barrens", 267, Rarity.COMMON, mage.cards.s.ScouredBarrens.class)); cards.add(new SetCardInfo("Seize Opportunity", 119, Rarity.COMMON, mage.cards.s.SeizeOpportunity.class)); cards.add(new SetCardInfo("Shiko, Paragon of the Way", 223, Rarity.MYTHIC, mage.cards.s.ShikoParagonOfTheWay.class));