From 9f87839ca64a069842da287f9276560cb535c496 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Sat, 23 Jan 2021 19:59:29 -0500 Subject: [PATCH] [KHC] Implemented Stoic Farmer --- Mage.Sets/src/mage/cards/s/StoicFarmer.java | 67 +++++++++++++++++++ .../src/mage/sets/KaldheimCommander.java | 1 + 2 files changed, 68 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/s/StoicFarmer.java diff --git a/Mage.Sets/src/mage/cards/s/StoicFarmer.java b/Mage.Sets/src/mage/cards/s/StoicFarmer.java new file mode 100644 index 0000000000..b4fc3af55d --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/StoicFarmer.java @@ -0,0 +1,67 @@ +package mage.cards.s; + +import mage.MageInt; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.condition.Condition; +import mage.abilities.condition.common.OpponentControlsMoreCondition; +import mage.abilities.decorator.ConditionalOneShotEffect; +import mage.abilities.effects.common.search.SearchLibraryPutInHandEffect; +import mage.abilities.effects.common.search.SearchLibraryPutInPlayEffect; +import mage.abilities.keyword.ForetellAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.filter.FilterCard; +import mage.filter.StaticFilters; +import mage.target.common.TargetCardInLibrary; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class StoicFarmer extends CardImpl { + + private static final FilterCard filter = new FilterCard("a basic Plains card"); + + static { + filter.add(SuperType.BASIC.getPredicate()); + filter.add(SubType.PLAINS.getPredicate()); + } + + private static final Condition condition = new OpponentControlsMoreCondition(StaticFilters.FILTER_LANDS); + + public StoicFarmer(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{3}{W}"); + + this.subtype.add(SubType.DWARF); + this.subtype.add(SubType.PEASANT); + this.power = new MageInt(3); + this.toughness = new MageInt(3); + + // When Stoic Farmer enters the battlefield, search your library for a basic Plains card and reveal it. If an opponent controls more lands than you, put it onto the battlefield tapped. Otherwise, put it into your hand. Then shuffle your library. + this.addAbility(new EntersBattlefieldTriggeredAbility( + new ConditionalOneShotEffect( + new SearchLibraryPutInPlayEffect(new TargetCardInLibrary(filter), true), + new SearchLibraryPutInHandEffect(new TargetCardInLibrary(filter)), + condition, "search your library for a basic Plains card and reveal it. " + + "If an opponent controls more lands than you, put it onto the battlefield tapped. " + + "Otherwise, put it into your hand. Then shuffle your library" + ) + )); + + // Foretell {1}{W} + this.addAbility(new ForetellAbility(this, "{1}{W}")); + } + + private StoicFarmer(final StoicFarmer card) { + super(card); + } + + @Override + public StoicFarmer copy() { + return new StoicFarmer(this); + } +} diff --git a/Mage.Sets/src/mage/sets/KaldheimCommander.java b/Mage.Sets/src/mage/sets/KaldheimCommander.java index 51f945ec40..8e9d86ac06 100644 --- a/Mage.Sets/src/mage/sets/KaldheimCommander.java +++ b/Mage.Sets/src/mage/sets/KaldheimCommander.java @@ -27,5 +27,6 @@ public final class KaldheimCommander extends ExpansionSet { cards.add(new SetCardInfo("Ruthless Winnower", 10, Rarity.RARE, mage.cards.r.RuthlessWinnower.class)); cards.add(new SetCardInfo("Sage of the Beyond", 6, Rarity.RARE, mage.cards.s.SageOfTheBeyond.class)); cards.add(new SetCardInfo("Spectral Deluge", 7, Rarity.RARE, mage.cards.s.SpectralDeluge.class)); + cards.add(new SetCardInfo("Stoic Farmer", 5, Rarity.RARE, mage.cards.s.StoicFarmer.class)); } }