From c671a48efa66a136d8fdd85ff1a5fe20a9237211 Mon Sep 17 00:00:00 2001 From: PurpleCrowbar <26198472+PurpleCrowbar@users.noreply.github.com> Date: Thu, 9 Feb 2023 16:38:20 +0000 Subject: [PATCH] [ONE] Implement Cruel Grimnarch --- .../src/mage/cards/c/CruelGrimnarch.java | 101 ++++++++++++++++++ .../src/mage/sets/PhyrexiaAllWillBeOne.java | 1 + 2 files changed, 102 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/c/CruelGrimnarch.java diff --git a/Mage.Sets/src/mage/cards/c/CruelGrimnarch.java b/Mage.Sets/src/mage/cards/c/CruelGrimnarch.java new file mode 100644 index 00000000000..9a2b49e581d --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/CruelGrimnarch.java @@ -0,0 +1,101 @@ +package mage.cards.c; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.keyword.DeathtouchAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.cards.Cards; +import mage.cards.CardsImpl; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.constants.SubType; +import mage.filter.StaticFilters; +import mage.game.Game; +import mage.players.Player; +import mage.target.Target; +import mage.target.common.TargetDiscard; + +import java.util.HashMap; +import java.util.Map; +import java.util.UUID; + +/** + * @author PurpleCrowbar + */ +public final class CruelGrimnarch extends CardImpl { + + public CruelGrimnarch(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{5}{B}"); + this.subtype.add(SubType.PHYREXIAN, SubType.CLERIC); + this.power = new MageInt(5); + this.toughness = new MageInt(5); + + // Deathtouch + this.addAbility(DeathtouchAbility.getInstance()); + + // When Cruel Grimnarch enters the battlefield, each opponent discards a card. For each opponent who can't, you gain 4 life. + this.addAbility(new EntersBattlefieldTriggeredAbility(new CruelGrimnarchEffect())); + } + + private CruelGrimnarch(final CruelGrimnarch card) { + super(card); + } + + @Override + public CruelGrimnarch copy() { + return new CruelGrimnarch(this); + } +} + +class CruelGrimnarchEffect extends OneShotEffect { + + CruelGrimnarchEffect() { + super(Outcome.Benefit); + this.staticText = "each opponent discards a card. For each opponent who can't, you gain 4 life"; + } + + private CruelGrimnarchEffect(final CruelGrimnarchEffect effect) { + super(effect); + } + + @Override + public CruelGrimnarchEffect copy() { + return new CruelGrimnarchEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Player controller = game.getPlayer(source.getControllerId()); + Map cardsToDiscard = new HashMap<>(); + + // choose cards to discard + for (UUID playerId : game.getOpponents(source.getControllerId(), true)) { + Player player = game.getPlayer(playerId); + if (player == null) { + continue; + } + int numberOfCardsToDiscard = Math.min(1, player.getHand().size()); + Cards cards = new CardsImpl(); + Target target = new TargetDiscard(numberOfCardsToDiscard, numberOfCardsToDiscard, StaticFilters.FILTER_CARD, playerId); + player.chooseTarget(outcome, target, source, game); + cards.addAll(target.getTargets()); + cardsToDiscard.put(playerId, cards); + } + + // discard all chosen cards + for (UUID playerId : game.getOpponents(source.getControllerId(), true)) { + Player player = game.getPlayer(playerId); + if (player == null) { + continue; + } + int amountDiscarded = player.discard(cardsToDiscard.get(playerId), false, source, game).size(); + if (amountDiscarded == 0 && controller != null) { + controller.gainLife(4, game, source); + } + } + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/PhyrexiaAllWillBeOne.java b/Mage.Sets/src/mage/sets/PhyrexiaAllWillBeOne.java index 1bfd2599c0a..738b60855c1 100644 --- a/Mage.Sets/src/mage/sets/PhyrexiaAllWillBeOne.java +++ b/Mage.Sets/src/mage/sets/PhyrexiaAllWillBeOne.java @@ -57,6 +57,7 @@ public final class PhyrexiaAllWillBeOne extends ExpansionSet { cards.add(new SetCardInfo("Copper Longlegs", 165, Rarity.COMMON, mage.cards.c.CopperLonglegs.class)); cards.add(new SetCardInfo("Copperline Gorge", 249, Rarity.RARE, mage.cards.c.CopperlineGorge.class)); cards.add(new SetCardInfo("Crawling Chorus", 8, Rarity.COMMON, mage.cards.c.CrawlingChorus.class)); + cards.add(new SetCardInfo("Cruel Grimnarch", 88, Rarity.COMMON, mage.cards.c.CruelGrimnarch.class)); cards.add(new SetCardInfo("Cutthroat Centurion", 89, Rarity.COMMON, mage.cards.c.CutthroatCenturion.class)); cards.add(new SetCardInfo("Darkslick Shores", 250, Rarity.RARE, mage.cards.d.DarkslickShores.class)); cards.add(new SetCardInfo("Distorted Curiosity", 46, Rarity.UNCOMMON, mage.cards.d.DistortedCuriosity.class));