From b0c3371f7f30daa9e73babdb53d9ea44d5717427 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Sun, 25 Feb 2024 09:56:18 -0500 Subject: [PATCH] [OTJ] Implement Hell to Pay --- Mage.Sets/src/mage/cards/h/HellToPay.java | 72 +++++++++++++++++++ .../mage/sets/OutlawsOfThunderJunction.java | 1 + 2 files changed, 73 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/h/HellToPay.java diff --git a/Mage.Sets/src/mage/cards/h/HellToPay.java b/Mage.Sets/src/mage/cards/h/HellToPay.java new file mode 100644 index 00000000000..5a034e66356 --- /dev/null +++ b/Mage.Sets/src/mage/cards/h/HellToPay.java @@ -0,0 +1,72 @@ +package mage.cards.h; + +import mage.abilities.Ability; +import mage.abilities.effects.OneShotEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.game.Game; +import mage.game.permanent.Permanent; +import mage.game.permanent.token.TreasureToken; +import mage.target.common.TargetCreaturePermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class HellToPay extends CardImpl { + + public HellToPay(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{X}{R}"); + + // Hell to Pay deals X damage to target creature. Create a number of tapped Treasure tokens equal to the amount of excess damage dealt to that creature this way. + this.getSpellAbility().addEffect(new HellToPayEffect()); + this.getSpellAbility().addTarget(new TargetCreaturePermanent()); + } + + private HellToPay(final HellToPay card) { + super(card); + } + + @Override + public HellToPay copy() { + return new HellToPay(this); + } +} + +class HellToPayEffect extends OneShotEffect { + + HellToPayEffect() { + super(Outcome.Benefit); + staticText = "{this} deals X damage to target creature. Create a number of tapped " + + "Treasure tokens equal to the amount of excess damage dealt to that creature this way"; + } + + private HellToPayEffect(final HellToPayEffect effect) { + super(effect); + } + + @Override + public HellToPayEffect copy() { + return new HellToPayEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source)); + if (permanent == null) { + return false; + } + int damage = source.getManaCostsToPay().getX(); + int lethal = Math.min(permanent.getLethalDamage(source.getSourceId(), game), damage); + permanent.damage(lethal, source.getSourceId(), source, game); + if (damage > lethal) { + new TreasureToken().putOntoBattlefield( + damage - lethal, game, source, source.getControllerId(), true, false + ); + } + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java b/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java index 92d8c0a0a02..f45f1059597 100644 --- a/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java +++ b/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java @@ -22,6 +22,7 @@ public final class OutlawsOfThunderJunction extends ExpansionSet { this.hasBoosters = false; // temporary cards.add(new SetCardInfo("Forest", 276, Rarity.LAND, mage.cards.basiclands.Forest.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Hell to Pay", 126, Rarity.RARE, mage.cards.h.HellToPay.class)); cards.add(new SetCardInfo("Island", 273, Rarity.LAND, mage.cards.basiclands.Island.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Mountain", 275, Rarity.LAND, mage.cards.basiclands.Mountain.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Plains", 272, Rarity.LAND, mage.cards.basiclands.Plains.class, NON_FULL_USE_VARIOUS));