From 64aeba659e0639ab724af286d5b4e7c887e63373 Mon Sep 17 00:00:00 2001 From: xenohedron Date: Fri, 6 Sep 2024 22:46:37 -0400 Subject: [PATCH] implement [ACR] Eivor, Wolf-Kissed closes #12499 --- .../src/mage/cards/e/EivorWolfKissed.java | 88 +++++++++++++++++++ Mage.Sets/src/mage/sets/AssassinsCreed.java | 1 + .../target/common/TargetCardAndOrCard.java | 2 +- 3 files changed, 90 insertions(+), 1 deletion(-) create mode 100644 Mage.Sets/src/mage/cards/e/EivorWolfKissed.java diff --git a/Mage.Sets/src/mage/cards/e/EivorWolfKissed.java b/Mage.Sets/src/mage/cards/e/EivorWolfKissed.java new file mode 100644 index 00000000000..96cfaf761cf --- /dev/null +++ b/Mage.Sets/src/mage/cards/e/EivorWolfKissed.java @@ -0,0 +1,88 @@ +package mage.cards.e; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.DealsCombatDamageTriggeredAbility; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.keyword.HasteAbility; +import mage.abilities.keyword.TrampleAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.cards.Cards; +import mage.cards.CardsImpl; +import mage.constants.*; +import mage.game.Game; +import mage.players.Player; +import mage.target.TargetCard; +import mage.target.common.TargetCardAndOrCard; + +import java.util.UUID; + +/** + * @author TheElk801, xenohedron + */ +public final class EivorWolfKissed extends CardImpl { + + public EivorWolfKissed(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{3}{R}{G}{W}"); + + this.supertype.add(SuperType.LEGENDARY); + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.ASSASSIN); + this.subtype.add(SubType.WARRIOR); + this.power = new MageInt(7); + this.toughness = new MageInt(6); + + // Trample + this.addAbility(TrampleAbility.getInstance()); + + // Haste + this.addAbility(HasteAbility.getInstance()); + + // Whenever Eivor, Wolf-Kissed deals combat damage to a player, you mill that many cards. You may put a Saga card and/or a land card from among them onto the battlefield. + this.addAbility(new DealsCombatDamageTriggeredAbility(new EivorWolfKissedEffect(), false)); + } + + private EivorWolfKissed(final EivorWolfKissed card) { + super(card); + } + + @Override + public EivorWolfKissed copy() { + return new EivorWolfKissed(this); + } +} + +class EivorWolfKissedEffect extends OneShotEffect { + + EivorWolfKissedEffect() { + super(Outcome.Benefit); + staticText = "you mill that many cards. You may put a Saga card " + + "and/or a land card from among them onto the battlefield"; + } + + private EivorWolfKissedEffect(final EivorWolfKissedEffect effect) { + super(effect); + } + + @Override + public EivorWolfKissedEffect copy() { + return new EivorWolfKissedEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Player player = game.getPlayer(source.getControllerId()); + int damage = (Integer) getValue("damage"); + if (player == null || damage < 1) { + return false; + } + Cards cards = player.millCards(damage, source, game); + TargetCard target = new TargetCardAndOrCard(SubType.SAGA.getPredicate(), + CardType.LAND.getPredicate(), + "a Saga card and/or a land card"); + player.choose(outcome, cards, target, source, game); + player.moveCards(new CardsImpl(target.getTargets()), Zone.BATTLEFIELD, source, game); + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/AssassinsCreed.java b/Mage.Sets/src/mage/sets/AssassinsCreed.java index caa026c735f..009c7a7f53e 100644 --- a/Mage.Sets/src/mage/sets/AssassinsCreed.java +++ b/Mage.Sets/src/mage/sets/AssassinsCreed.java @@ -55,6 +55,7 @@ public final class AssassinsCreed extends ExpansionSet { cards.add(new SetCardInfo("Distract the Guards", 3, Rarity.UNCOMMON, mage.cards.d.DistractTheGuards.class)); cards.add(new SetCardInfo("Eagle Vision", 17, Rarity.UNCOMMON, mage.cards.e.EagleVision.class)); cards.add(new SetCardInfo("Eivor, Battle-Ready", 274, Rarity.MYTHIC, mage.cards.e.EivorBattleReady.class)); + cards.add(new SetCardInfo("Eivor, Wolf-Kissed", 54, Rarity.MYTHIC, mage.cards.e.EivorWolfKissed.class)); cards.add(new SetCardInfo("Escape Detection", 18, Rarity.UNCOMMON, mage.cards.e.EscapeDetection.class)); cards.add(new SetCardInfo("Escarpment Fortress", 278, Rarity.RARE, mage.cards.e.EscarpmentFortress.class)); cards.add(new SetCardInfo("Evie Frye", 19, Rarity.RARE, mage.cards.e.EvieFrye.class)); diff --git a/Mage/src/main/java/mage/target/common/TargetCardAndOrCard.java b/Mage/src/main/java/mage/target/common/TargetCardAndOrCard.java index 9b6160a1f4d..d5c01e5f4b7 100644 --- a/Mage/src/main/java/mage/target/common/TargetCardAndOrCard.java +++ b/Mage/src/main/java/mage/target/common/TargetCardAndOrCard.java @@ -45,7 +45,7 @@ public class TargetCardAndOrCard extends TargetCard { /** * a [firstType] card and/or a [secondType] card */ - protected TargetCardAndOrCard(Predicate firstPredicate, Predicate secondPredicate, String filterText) { + public TargetCardAndOrCard(Predicate firstPredicate, Predicate secondPredicate, String filterText) { super(0, 2, Zone.ALL, makeFilter(firstPredicate, secondPredicate, filterText)); this.assignment = new PredicateCardAssignment(firstPredicate, secondPredicate); }