From 0d9d4aad3a6b1287fb38d4d90edd4d920b2cbdd7 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Wed, 1 Jun 2022 18:29:38 -0400 Subject: [PATCH] [CLB] Implemented Harper Recruiter --- .../src/mage/cards/h/HarperRecruiter.java | 139 ++++++++++++++++++ .../CommanderLegendsBattleForBaldursGate.java | 1 + 2 files changed, 140 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/h/HarperRecruiter.java diff --git a/Mage.Sets/src/mage/cards/h/HarperRecruiter.java b/Mage.Sets/src/mage/cards/h/HarperRecruiter.java new file mode 100644 index 00000000000..38f3154dcac --- /dev/null +++ b/Mage.Sets/src/mage/cards/h/HarperRecruiter.java @@ -0,0 +1,139 @@ +package mage.cards.h; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.AttacksTriggeredAbility; +import mage.abilities.dynamicvalue.common.SubTypeAssignment; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.*; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.constants.SubType; +import mage.constants.Zone; +import mage.filter.FilterCard; +import mage.filter.predicate.Predicates; +import mage.game.Game; +import mage.players.Player; +import mage.target.TargetCard; +import mage.target.common.TargetCardInLibrary; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class HarperRecruiter extends CardImpl { + + public HarperRecruiter(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{W}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.WARRIOR); + this.power = new MageInt(3); + this.toughness = new MageInt(1); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Whenever Harper Recruiter attacks, look at the top four cards of your library. You may reveal a Cleric card, a Rogue card, a Warrior card, and/or a Wizard card from among them and put those cards into your hand. Put the rest on the bottom of your library in a random order. + this.addAbility(new AttacksTriggeredAbility(new HarperRecruiterEffect())); + } + + private HarperRecruiter(final HarperRecruiter card) { + super(card); + } + + @Override + public HarperRecruiter copy() { + return new HarperRecruiter(this); + } +} + +class HarperRecruiterEffect extends OneShotEffect { + + HarperRecruiterEffect() { + super(Outcome.Benefit); + staticText = "look at the top four cards of your library. You may reveal a Cleric card, a Rogue card, " + + "a Warrior card, and/or a Wizard card from among them and put those cards into your hand. " + + "Put the rest on the bottom of your library in a random order"; + } + + private HarperRecruiterEffect(final HarperRecruiterEffect effect) { + super(effect); + } + + @Override + public HarperRecruiterEffect copy() { + return new HarperRecruiterEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Player player = game.getPlayer(source.getControllerId()); + if (player == null) { + return false; + } + Cards cards = new CardsImpl(player.getLibrary().getTopCards(game, 4)); + TargetCard target = new HarperRecruiterTarget(); + player.choose(outcome, cards, target, game); + Cards toHand = new CardsImpl(target.getTargets()); + player.revealCards(source, toHand, game); + player.moveCards(toHand, Zone.HAND, source, game); + cards.retainZone(Zone.LIBRARY, game); + player.putCardsOnBottomOfLibrary(cards, game, source, false); + return true; + } +} + +class HarperRecruiterTarget extends TargetCardInLibrary { + + private static final FilterCard filter + = new FilterCard("a Cleric card, a Rogue card, a Warrior card, and/or a Wizard card"); + + static { + filter.add(Predicates.or( + SubType.CLERIC.getPredicate(), + SubType.ROGUE.getPredicate(), + SubType.WARRIOR.getPredicate(), + SubType.WIZARD.getPredicate() + )); + } + + private static final SubTypeAssignment subTypeAssigner = new SubTypeAssignment( + SubType.CLERIC, + SubType.ROGUE, + SubType.WARRIOR, + SubType.WIZARD + ); + + HarperRecruiterTarget() { + super(0, 4, filter); + } + + private HarperRecruiterTarget(final HarperRecruiterTarget target) { + super(target); + } + + @Override + public HarperRecruiterTarget copy() { + return new HarperRecruiterTarget(this); + } + + @Override + public boolean canTarget(UUID playerId, UUID id, Ability source, Game game) { + if (!super.canTarget(playerId, id, source, game)) { + return false; + } + Card card = game.getCard(id); + if (card == null) { + return false; + } + if (this.getTargets().isEmpty()) { + return true; + } + Cards cards = new CardsImpl(this.getTargets()); + cards.add(card); + return subTypeAssigner.getRoleCount(cards, game) >= cards.size(); + } +} diff --git a/Mage.Sets/src/mage/sets/CommanderLegendsBattleForBaldursGate.java b/Mage.Sets/src/mage/sets/CommanderLegendsBattleForBaldursGate.java index bfa898267bb..af2040c5308 100644 --- a/Mage.Sets/src/mage/sets/CommanderLegendsBattleForBaldursGate.java +++ b/Mage.Sets/src/mage/sets/CommanderLegendsBattleForBaldursGate.java @@ -165,6 +165,7 @@ public final class CommanderLegendsBattleForBaldursGate extends ExpansionSet { cards.add(new SetCardInfo("Halsin, Emerald Archdruid", 234, Rarity.UNCOMMON, mage.cards.h.HalsinEmeraldArchdruid.class)); cards.add(new SetCardInfo("Hammers of Moradin", 25, Rarity.UNCOMMON, mage.cards.h.HammersOfMoradin.class)); cards.add(new SetCardInfo("Hardy Outlander", 235, Rarity.UNCOMMON, mage.cards.h.HardyOutlander.class)); + cards.add(new SetCardInfo("Harper Recruiter", 659, Rarity.RARE, mage.cards.h.HarperRecruiter.class)); cards.add(new SetCardInfo("Heap Gate", 354, Rarity.COMMON, mage.cards.h.HeapGate.class)); cards.add(new SetCardInfo("Hoarding Ogre", 181, Rarity.COMMON, mage.cards.h.HoardingOgre.class)); cards.add(new SetCardInfo("Horn of Valhalla", 26, Rarity.RARE, mage.cards.h.HornOfValhalla.class));