From 27d30edcb75af16e07f1149958ce7229e89a8832 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Thu, 17 Aug 2023 14:56:49 -0400 Subject: [PATCH] [WOE] Implement Howling Galefang --- .../src/mage/cards/h/HowlingGalefang.java | 70 +++++++++++++++++++ Mage.Sets/src/mage/sets/WildsOfEldraine.java | 1 + 2 files changed, 71 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/h/HowlingGalefang.java diff --git a/Mage.Sets/src/mage/cards/h/HowlingGalefang.java b/Mage.Sets/src/mage/cards/h/HowlingGalefang.java new file mode 100644 index 00000000000..6a4634a1715 --- /dev/null +++ b/Mage.Sets/src/mage/cards/h/HowlingGalefang.java @@ -0,0 +1,70 @@ +package mage.cards.h; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.condition.Condition; +import mage.abilities.decorator.ConditionalContinuousEffect; +import mage.abilities.effects.common.continuous.GainAbilitySourceEffect; +import mage.abilities.hint.ConditionHint; +import mage.abilities.hint.Hint; +import mage.abilities.keyword.HasteAbility; +import mage.abilities.keyword.VigilanceAbility; +import mage.cards.AdventureCard; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.game.Game; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class HowlingGalefang extends CardImpl { + + public HowlingGalefang(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{G}{G}"); + + this.subtype.add(SubType.BEAST); + this.power = new MageInt(4); + this.toughness = new MageInt(4); + + // Vigilance + this.addAbility(VigilanceAbility.getInstance()); + + // Howling Galefang has haste as long as you own a card in exile that has an Adventure. + this.addAbility(new SimpleStaticAbility(new ConditionalContinuousEffect( + new GainAbilitySourceEffect(HasteAbility.getInstance()), HowlingGalefangCondition.instance, + "{this} has haste as long as you own a card in exile that has an Adventure" + )).addHint(HowlingGalefangCondition.getHint())); + } + + private HowlingGalefang(final HowlingGalefang card) { + super(card); + } + + @Override + public HowlingGalefang copy() { + return new HowlingGalefang(this); + } +} + +enum HowlingGalefangCondition implements Condition { + instance; + private static final Hint hint = new ConditionHint(instance, "You have an Adventure in exile"); + + @Override + public boolean apply(Game game, Ability source) { + return game + .getExile() + .getAllCards(game, source.getControllerId()) + .stream() + .anyMatch(AdventureCard.class::isInstance); + } + + public static Hint getHint() { + return hint; + } +} \ No newline at end of file diff --git a/Mage.Sets/src/mage/sets/WildsOfEldraine.java b/Mage.Sets/src/mage/sets/WildsOfEldraine.java index b35eacd3a65..ae1f3e5b079 100644 --- a/Mage.Sets/src/mage/sets/WildsOfEldraine.java +++ b/Mage.Sets/src/mage/sets/WildsOfEldraine.java @@ -38,6 +38,7 @@ public final class WildsOfEldraine extends ExpansionSet { cards.add(new SetCardInfo("Gallant Pie-Wielder", 15, Rarity.UNCOMMON, mage.cards.g.GallantPieWielder.class)); cards.add(new SetCardInfo("Glass Casket", 16, Rarity.UNCOMMON, mage.cards.g.GlassCasket.class)); cards.add(new SetCardInfo("Greta, Sweettooth Scourge", 205, Rarity.UNCOMMON, mage.cards.g.GretaSweettoothScourge.class)); + cards.add(new SetCardInfo("Howling Galefang", 175, Rarity.UNCOMMON, mage.cards.h.HowlingGalefang.class)); cards.add(new SetCardInfo("Island", 263, Rarity.LAND, mage.cards.basiclands.Island.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Knight of Doves", 19, Rarity.UNCOMMON, mage.cards.k.KnightOfDoves.class)); cards.add(new SetCardInfo("Living Lectern", 59, Rarity.COMMON, mage.cards.l.LivingLectern.class));