From a366ec019fea2b8afe26c6bfee701d85c48844a1 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Thu, 5 Sep 2019 20:13:13 -0400 Subject: [PATCH] Implemented Savvy Hunter --- Mage.Sets/src/mage/cards/s/SavvyHunter.java | 52 +++++++++++++++++++ Mage.Sets/src/mage/sets/ThroneOfEldraine.java | 1 + .../common/TargetControlledPermanent.java | 11 ++-- 3 files changed, 60 insertions(+), 4 deletions(-) create mode 100644 Mage.Sets/src/mage/cards/s/SavvyHunter.java diff --git a/Mage.Sets/src/mage/cards/s/SavvyHunter.java b/Mage.Sets/src/mage/cards/s/SavvyHunter.java new file mode 100644 index 0000000000..3e184b35b9 --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/SavvyHunter.java @@ -0,0 +1,52 @@ +package mage.cards.s; + +import mage.MageInt; +import mage.abilities.common.AttacksOrBlocksTriggeredAbility; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.common.SacrificeTargetCost; +import mage.abilities.effects.common.CreateTokenEffect; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.filter.common.FilterControlledPermanent; +import mage.game.permanent.token.FoodToken; +import mage.target.common.TargetControlledPermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class SavvyHunter extends CardImpl { + + private static final FilterControlledPermanent filter = new FilterControlledPermanent(SubType.FOOD, "Foods"); + + public SavvyHunter(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{B}{G}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.WARRIOR); + this.power = new MageInt(3); + this.toughness = new MageInt(3); + + // Whenever Savvy Hunter attacks or blocks, create a Food token. + this.addAbility(new AttacksOrBlocksTriggeredAbility(new CreateTokenEffect(new FoodToken()), false)); + + // Sacrifice two Foods: Draw a card. + this.addAbility(new SimpleActivatedAbility( + new DrawCardSourceControllerEffect(1), + new SacrificeTargetCost(new TargetControlledPermanent(2, filter)) + )); + } + + private SavvyHunter(final SavvyHunter card) { + super(card); + } + + @Override + public SavvyHunter copy() { + return new SavvyHunter(this); + } +} diff --git a/Mage.Sets/src/mage/sets/ThroneOfEldraine.java b/Mage.Sets/src/mage/sets/ThroneOfEldraine.java index 763b3428a0..28410ac244 100644 --- a/Mage.Sets/src/mage/sets/ThroneOfEldraine.java +++ b/Mage.Sets/src/mage/sets/ThroneOfEldraine.java @@ -52,6 +52,7 @@ public final class ThroneOfEldraine extends ExpansionSet { cards.add(new SetCardInfo("Maraleaf Pixie", 196, Rarity.UNCOMMON, mage.cards.m.MaraleafPixie.class)); cards.add(new SetCardInfo("Rankle, Master of Pranks", 101, Rarity.MYTHIC, mage.cards.r.RankleMasterOfPranks.class)); cards.add(new SetCardInfo("Run Away Together", 62, Rarity.COMMON, mage.cards.r.RunAwayTogether.class)); + cards.add(new SetCardInfo("Savvy Hunter", 200, Rarity.UNCOMMON, mage.cards.s.SavvyHunter.class)); cards.add(new SetCardInfo("Shinechaser", 201, Rarity.UNCOMMON, mage.cards.s.Shinechaser.class)); cards.add(new SetCardInfo("Shining Armor", 29, Rarity.COMMON, mage.cards.s.ShiningArmor.class)); cards.add(new SetCardInfo("Silverflame Ritual", 30, Rarity.COMMON, mage.cards.s.SilverflameRitual.class)); diff --git a/Mage/src/main/java/mage/target/common/TargetControlledPermanent.java b/Mage/src/main/java/mage/target/common/TargetControlledPermanent.java index cbc3e687ab..39a538b782 100644 --- a/Mage/src/main/java/mage/target/common/TargetControlledPermanent.java +++ b/Mage/src/main/java/mage/target/common/TargetControlledPermanent.java @@ -5,21 +5,24 @@ import mage.filter.common.FilterControlledPermanent; import mage.target.TargetPermanent; /** - * * @author BetaSteward_at_googlemail.com */ public class TargetControlledPermanent extends TargetPermanent { public TargetControlledPermanent() { - this(1, 1, StaticFilters.FILTER_CONTROLLED_PERMANENT, false); + this(1); } public TargetControlledPermanent(int numTargets) { - this(numTargets, numTargets, StaticFilters.FILTER_CONTROLLED_PERMANENT, false); + this(numTargets, StaticFilters.FILTER_CONTROLLED_PERMANENT); } public TargetControlledPermanent(FilterControlledPermanent filter) { - this(1, 1, filter, false); + this(1, filter); + } + + public TargetControlledPermanent(int numTargets, FilterControlledPermanent filter) { + this(numTargets, numTargets, filter, false); } public TargetControlledPermanent(int minNumTargets, int maxNumTargets, FilterControlledPermanent filter, boolean notTarget) {