From c1a2a5a4e51beaa3c6557291e08cba0976ee9166 Mon Sep 17 00:00:00 2001 From: jackd149 <67557084+jackd149@users.noreply.github.com> Date: Fri, 27 Dec 2024 14:21:59 -0500 Subject: [PATCH 1/2] Implement Cryptid Inspector --- .../src/mage/cards/c/CryptidInspector.java | 59 +++++++++++++++++++ .../src/mage/sets/DuskmournHouseOfHorror.java | 1 + 2 files changed, 60 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..437c779b3d25 --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/CryptidInspector.java @@ -0,0 +1,59 @@ +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()); + + 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 28e8282694e8..b7f93b1c8b03 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)); From 3e797f669ff58ee6931749ebc27641b999be59e6 Mon Sep 17 00:00:00 2001 From: jackd149 <67557084+jackd149@users.noreply.github.com> Date: Thu, 2 Jan 2025 11:57:41 +0300 Subject: [PATCH 2/2] Added comment for ability --- Mage.Sets/src/mage/cards/c/CryptidInspector.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Mage.Sets/src/mage/cards/c/CryptidInspector.java b/Mage.Sets/src/mage/cards/c/CryptidInspector.java index 437c779b3d25..2481532b2ff2 100644 --- a/Mage.Sets/src/mage/cards/c/CryptidInspector.java +++ b/Mage.Sets/src/mage/cards/c/CryptidInspector.java @@ -37,6 +37,8 @@ public CryptidInspector(UUID ownerId, CardSetInfo setInfo) { 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()),