From 22e7780a888ab1dfee3bf47808e772bc3fe84776 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Wed, 26 Mar 2025 13:08:38 -0400 Subject: [PATCH] [TDM] Implement Sinkhole Surveyor --- .../src/mage/cards/s/SinkholeSurveyor.java | 46 +++++++++++++++++++ .../src/mage/sets/TarkirDragonstorm.java | 1 + 2 files changed, 47 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/s/SinkholeSurveyor.java diff --git a/Mage.Sets/src/mage/cards/s/SinkholeSurveyor.java b/Mage.Sets/src/mage/cards/s/SinkholeSurveyor.java new file mode 100644 index 00000000000..f6fe5ad7989 --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/SinkholeSurveyor.java @@ -0,0 +1,46 @@ +package mage.cards.s; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.AttacksTriggeredAbility; +import mage.abilities.effects.common.LoseLifeSourceControllerEffect; +import mage.abilities.effects.keyword.EndureSourceEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class SinkholeSurveyor extends CardImpl { + + public SinkholeSurveyor(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{B}"); + + this.subtype.add(SubType.BIRD); + this.subtype.add(SubType.SCOUT); + this.power = new MageInt(1); + this.toughness = new MageInt(3); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Whenever this creature attacks, you lose 1 life and this creature endures 1. + Ability ability = new AttacksTriggeredAbility(new LoseLifeSourceControllerEffect(1)); + ability.addEffect(new EndureSourceEffect(1, "{this}").concatBy("and")); + this.addAbility(ability); + } + + private SinkholeSurveyor(final SinkholeSurveyor card) { + super(card); + } + + @Override + public SinkholeSurveyor copy() { + return new SinkholeSurveyor(this); + } +} diff --git a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java index 7028a44b67b..ac44152ab90 100644 --- a/Mage.Sets/src/mage/sets/TarkirDragonstorm.java +++ b/Mage.Sets/src/mage/sets/TarkirDragonstorm.java @@ -115,6 +115,7 @@ public final class TarkirDragonstorm extends ExpansionSet { 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)); cards.add(new SetCardInfo("Shock Brigade", 120, Rarity.COMMON, mage.cards.s.ShockBrigade.class)); + cards.add(new SetCardInfo("Sinkhole Surveyor", 93, Rarity.RARE, mage.cards.s.SinkholeSurveyor.class)); cards.add(new SetCardInfo("Skirmish Rhino", 224, Rarity.UNCOMMON, mage.cards.s.SkirmishRhino.class)); cards.add(new SetCardInfo("Smile at Death", 24, Rarity.MYTHIC, mage.cards.s.SmileAtDeath.class)); cards.add(new SetCardInfo("Snakeskin Veil", 159, Rarity.COMMON, mage.cards.s.SnakeskinVeil.class));