From e2c89f9aabc0b8b7437a7d7cf1474ab03e5283b5 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Fri, 9 Jan 2026 17:00:09 -0500 Subject: [PATCH] [ECL] Implement Moonlit Lamenter --- .../src/mage/cards/m/MoonlitLamenter.java | 54 +++++++++++++++++++ Mage.Sets/src/mage/sets/LorwynEclipsed.java | 1 + 2 files changed, 55 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/m/MoonlitLamenter.java diff --git a/Mage.Sets/src/mage/cards/m/MoonlitLamenter.java b/Mage.Sets/src/mage/cards/m/MoonlitLamenter.java new file mode 100644 index 00000000000..039f80ab19d --- /dev/null +++ b/Mage.Sets/src/mage/cards/m/MoonlitLamenter.java @@ -0,0 +1,54 @@ +package mage.cards.m; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.ActivateAsSorceryActivatedAbility; +import mage.abilities.common.EntersBattlefieldAbility; +import mage.abilities.costs.common.RemoveCountersSourceCost; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.counters.CounterType; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class MoonlitLamenter extends CardImpl { + + public MoonlitLamenter(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{W}"); + + this.subtype.add(SubType.TREEFOLK); + this.subtype.add(SubType.CLERIC); + this.power = new MageInt(2); + this.toughness = new MageInt(5); + + // This creature enters with a -1/-1 counter on it. + this.addAbility(new EntersBattlefieldAbility( + new AddCountersSourceEffect(CounterType.M1M1.createInstance(1)), + "with a -1/-1 counter on it" + )); + + // {1}{W}, Remove a counter from this creature: Draw a card. Activate only as a sorcery. + Ability ability = new ActivateAsSorceryActivatedAbility( + new DrawCardSourceControllerEffect(1), new ManaCostsImpl<>("{1}{W}") + ); + ability.addCost(new RemoveCountersSourceCost(1)); + this.addAbility(ability); + } + + private MoonlitLamenter(final MoonlitLamenter card) { + super(card); + } + + @Override + public MoonlitLamenter copy() { + return new MoonlitLamenter(this); + } +} diff --git a/Mage.Sets/src/mage/sets/LorwynEclipsed.java b/Mage.Sets/src/mage/sets/LorwynEclipsed.java index c9eeda86aa4..fbc86bbac00 100644 --- a/Mage.Sets/src/mage/sets/LorwynEclipsed.java +++ b/Mage.Sets/src/mage/sets/LorwynEclipsed.java @@ -199,6 +199,7 @@ public final class LorwynEclipsed extends ExpansionSet { cards.add(new SetCardInfo("Mischievous Sneakling", 235, Rarity.COMMON, mage.cards.m.MischievousSneakling.class)); cards.add(new SetCardInfo("Mistmeadow Council", 183, Rarity.COMMON, mage.cards.m.MistmeadowCouncil.class)); cards.add(new SetCardInfo("Moonglove Extractor", 109, Rarity.COMMON, mage.cards.m.MoongloveExtractor.class)); + cards.add(new SetCardInfo("Moonlit Lamenter", 26, Rarity.UNCOMMON, mage.cards.m.MoonlitLamenter.class)); cards.add(new SetCardInfo("Morningtide's Light", 27, Rarity.MYTHIC, mage.cards.m.MorningtidesLight.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Morningtide's Light", 301, Rarity.MYTHIC, mage.cards.m.MorningtidesLight.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Mountain", 272, Rarity.LAND, mage.cards.basiclands.Mountain.class, NON_FULL_USE_VARIOUS));