From 5f2325d4ef94d6abebe0787ac9cd64139c47b513 Mon Sep 17 00:00:00 2001 From: Susucre <34709007+Susucre@users.noreply.github.com> Date: Wed, 1 Nov 2023 16:55:02 +0100 Subject: [PATCH] [LCI] Implement Hoverstone Pilgrim --- .../src/mage/cards/h/HoverstonePilgrim.java | 54 +++++++++++++++++++ .../src/mage/sets/TheLostCavernsOfIxalan.java | 1 + 2 files changed, 55 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/h/HoverstonePilgrim.java diff --git a/Mage.Sets/src/mage/cards/h/HoverstonePilgrim.java b/Mage.Sets/src/mage/cards/h/HoverstonePilgrim.java new file mode 100644 index 00000000000..d2897538a49 --- /dev/null +++ b/Mage.Sets/src/mage/cards/h/HoverstonePilgrim.java @@ -0,0 +1,54 @@ +package mage.cards.h; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.mana.GenericManaCost; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.common.PutOnLibraryTargetEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.abilities.keyword.WardAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.target.common.TargetCardInGraveyard; + +import java.util.UUID; + +/** + * @author Susucr + */ +public final class HoverstonePilgrim extends CardImpl { + + public HoverstonePilgrim(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT, CardType.CREATURE}, "{5}"); + + this.subtype.add(SubType.GOLEM); + this.power = new MageInt(2); + this.toughness = new MageInt(5); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // Ward {2} + this.addAbility(new WardAbility(new ManaCostsImpl<>("{2}"))); + + // {2}: Put target card from a graveyard on the bottom of its owner's library. + Ability ability = new SimpleActivatedAbility( + new PutOnLibraryTargetEffect(false), + new GenericManaCost(2) + ); + ability.addTarget(new TargetCardInGraveyard()); + this.addAbility(ability); + } + + private HoverstonePilgrim(final HoverstonePilgrim card) { + super(card); + } + + @Override + public HoverstonePilgrim copy() { + return new HoverstonePilgrim(this); + } +} diff --git a/Mage.Sets/src/mage/sets/TheLostCavernsOfIxalan.java b/Mage.Sets/src/mage/sets/TheLostCavernsOfIxalan.java index f49c13fda9f..15d1ac349d6 100644 --- a/Mage.Sets/src/mage/sets/TheLostCavernsOfIxalan.java +++ b/Mage.Sets/src/mage/sets/TheLostCavernsOfIxalan.java @@ -93,6 +93,7 @@ public final class TheLostCavernsOfIxalan extends ExpansionSet { cards.add(new SetCardInfo("Hidden Nursery", 276, Rarity.COMMON, mage.cards.h.HiddenNursery.class)); cards.add(new SetCardInfo("Hidden Volcano", 277, Rarity.COMMON, mage.cards.h.HiddenVolcano.class)); cards.add(new SetCardInfo("Hit the Mother Lode", 153, Rarity.RARE, mage.cards.h.HitTheMotherLode.class)); + cards.add(new SetCardInfo("Hoverstone Pilgrim", 254, Rarity.UNCOMMON, mage.cards.h.HoverstonePilgrim.class)); cards.add(new SetCardInfo("Huatli, Poet of Unity", 189, Rarity.MYTHIC, mage.cards.h.HuatliPoetOfUnity.class)); cards.add(new SetCardInfo("Hurl into History", 59, Rarity.UNCOMMON, mage.cards.h.HurlIntoHistory.class)); cards.add(new SetCardInfo("Idol of the Deep King", 155, Rarity.COMMON, mage.cards.i.IdolOfTheDeepKing.class));