From 797bc89c4bf784441f09cff6ee759782c55344bd Mon Sep 17 00:00:00 2001 From: jmlundeen Date: Mon, 7 Apr 2025 14:41:12 -0500 Subject: [PATCH] [TDM] Implement StormShriek Feral --- .../src/mage/cards/s/StormshriekFeral.java | 58 +++++++++++++++++++ .../src/mage/sets/TarkirDragonstorm.java | 1 + 2 files changed, 59 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/s/StormshriekFeral.java diff --git a/Mage.Sets/src/mage/cards/s/StormshriekFeral.java b/Mage.Sets/src/mage/cards/s/StormshriekFeral.java new file mode 100644 index 00000000000..c6957a0f554 --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/StormshriekFeral.java @@ -0,0 +1,58 @@ +package mage.cards.s; + +import java.util.UUID; +import mage.MageInt; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.common.DiscardCardCost; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.common.DoIfCostPaid; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.abilities.effects.common.continuous.BoostSourceEffect; +import mage.cards.OmenCard; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.abilities.keyword.FlyingAbility; +import mage.abilities.keyword.HasteAbility; +import mage.cards.CardSetInfo; +import mage.constants.CardType; + +/** + * + * @author Jmlundeen + */ +public final class StormshriekFeral extends OmenCard { + + public StormshriekFeral(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, new CardType[]{CardType.SORCERY}, "{4}{R}", "Flush Out", "{1}{R}"); + + this.subtype.add(SubType.DRAGON); + this.power = new MageInt(3); + this.toughness = new MageInt(3); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Haste + this.addAbility(HasteAbility.getInstance()); + + // {1}{R}: This creature gets +1/+0 until end of turn. + this.addAbility(new SimpleActivatedAbility(new BoostSourceEffect(1, 0 , Duration.EndOfTurn), new ManaCostsImpl<>("{1}{R}"))); + + // Flush Out + // Discard a card. If you do, draw two cards. + this.getSpellCard().getSpellAbility().addEffect(new DoIfCostPaid( + new DrawCardSourceControllerEffect(2), + null, new DiscardCardCost(), false + )); + this.finalizeOmen(); + } + + private StormshriekFeral(final StormshriekFeral card) { + super(card); + } + + @Override + public StormshriekFeral copy() { + return new StormshriekFeral(this); + } +} diff --git a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java index e1ec48d4f69..f537d79046d 100644 --- a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java +++ b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java @@ -220,6 +220,7 @@ public final class TarkirDragonstorm extends ExpansionSet { cards.add(new SetCardInfo("Stormbeacon Blade", 27, Rarity.UNCOMMON, mage.cards.s.StormbeaconBlade.class)); cards.add(new SetCardInfo("Stormplain Detainment", 28, Rarity.COMMON, mage.cards.s.StormplainDetainment.class)); cards.add(new SetCardInfo("Stormscale Scion", 123, Rarity.MYTHIC, mage.cards.s.StormscaleScion.class)); + cards.add(new SetCardInfo("Stormshriek Feral", 124, Rarity.COMMON, mage.cards.s.StormshriekFeral.class)); cards.add(new SetCardInfo("Strategic Betrayal", 94, Rarity.UNCOMMON, mage.cards.s.StrategicBetrayal.class)); cards.add(new SetCardInfo("Sultai Devotee", 160, Rarity.COMMON, mage.cards.s.SultaiDevotee.class)); cards.add(new SetCardInfo("Sultai Monument", 247, Rarity.UNCOMMON, mage.cards.s.SultaiMonument.class));