From b8e1266e39a4147b19da5cbe82038a22eb129306 Mon Sep 17 00:00:00 2001 From: jackd149 <67557084+jackd149@users.noreply.github.com> Date: Fri, 3 Jan 2025 04:04:13 +0300 Subject: [PATCH] [DSK] Implement Cryptid Inspector (#13189) --- .../src/mage/cards/c/CryptidInspector.java | 61 +++++++++++++++++++ .../src/mage/sets/DuskmournHouseOfHorror.java | 1 + 2 files changed, 62 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/c/CryptidInspector.java diff --git a/Mage.Sets/src/mage/cards/c/CryptidInspector.java b/Mage.Sets/src/mage/cards/c/CryptidInspector.java new file mode 100644 index 000000000000..2481532b2ff2 --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/CryptidInspector.java @@ -0,0 +1,61 @@ +package mage.cards.c; + +import java.util.UUID; + +import mage.MageInt; +import mage.abilities.common.EntersBattlefieldControlledTriggeredAbility; +import mage.abilities.common.TurnedFaceUpAllTriggeredAbility; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.abilities.keyword.VigilanceAbility; +import mage.abilities.meta.OrTriggeredAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.Zone; +import mage.counters.CounterType; +import mage.filter.FilterPermanent; +import mage.filter.common.FilterControlledPermanent; +import mage.filter.predicate.card.FaceDownPredicate; + +/** + * @author jackd149 + */ +public final class CryptidInspector extends CardImpl { + private static final FilterPermanent filter1 = new FilterPermanent("a face-down permanent"); + private static final FilterPermanent filter2 = new FilterControlledPermanent("Cryptid Inspector or another permanent you control"); + + static { + filter1.add(FaceDownPredicate.instance); + } + + public CryptidInspector(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{G}"); + this.power = new MageInt(2); + this.toughness = new MageInt(3); + this.subtype.add(SubType.ELF); + this.subtype.add(SubType.WARRIOR); + this.addAbility(VigilanceAbility.getInstance()); + + // Whenever a face-down permanent you control enters and whenever Cryptid Inspector or another permanent you control is turned face up, + // put a +1/+1 counter on Cryptid Inspector. + this.addAbility(new OrTriggeredAbility( + Zone.BATTLEFIELD, + new AddCountersSourceEffect(CounterType.P1P1.createInstance()), + false, + "Whenever a face-down permanent you control enters and " + + "whenever Cryptid Inspector or another permanent you control is turned face up, ", + new EntersBattlefieldControlledTriggeredAbility(null, filter1), + new TurnedFaceUpAllTriggeredAbility(null, filter2) + )); + } + + private CryptidInspector(final CryptidInspector card){ + super(card); + } + + @Override + public CryptidInspector copy() { + return new CryptidInspector(this); + } +} \ No newline at end of file diff --git a/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java b/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java index 08420c6897e7..eb2e87f70c32 100644 --- a/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java +++ b/Mage.Sets/src/mage/sets/DuskmournHouseOfHorror.java @@ -52,6 +52,7 @@ private DuskmournHouseOfHorror() { cards.add(new SetCardInfo("Conductive Machete", 244, Rarity.UNCOMMON, mage.cards.c.ConductiveMachete.class)); cards.add(new SetCardInfo("Coordinated Clobbering", 173, Rarity.UNCOMMON, mage.cards.c.CoordinatedClobbering.class)); cards.add(new SetCardInfo("Cracked Skull", 88, Rarity.COMMON, mage.cards.c.CrackedSkull.class)); + cards.add(new SetCardInfo("Cryptid Inspector", 174, Rarity.COMMON, mage.cards.c.CryptidInspector.class)); cards.add(new SetCardInfo("Cult Healer", 2, Rarity.COMMON, mage.cards.c.CultHealer.class)); cards.add(new SetCardInfo("Cursed Recording", 131, Rarity.RARE, mage.cards.c.CursedRecording.class)); cards.add(new SetCardInfo("Cursed Windbreaker", 47, Rarity.UNCOMMON, mage.cards.c.CursedWindbreaker.class));