From ebea097e1cada41159ba192a0a5ff5db1dab0006 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Sun, 16 Apr 2023 19:04:54 -0400 Subject: [PATCH] [MOC] Implement Filigree Vector --- .../src/mage/cards/f/FiligreeVector.java | 63 +++++++++++++++++++ .../mage/sets/MarchOfTheMachineCommander.java | 1 + .../main/java/mage/filter/StaticFilters.java | 8 +++ 3 files changed, 72 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/f/FiligreeVector.java diff --git a/Mage.Sets/src/mage/cards/f/FiligreeVector.java b/Mage.Sets/src/mage/cards/f/FiligreeVector.java new file mode 100644 index 00000000000..725101bf989 --- /dev/null +++ b/Mage.Sets/src/mage/cards/f/FiligreeVector.java @@ -0,0 +1,63 @@ +package mage.cards.f; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.common.SacrificeTargetCost; +import mage.abilities.costs.common.TapSourceCost; +import mage.abilities.costs.mana.GenericManaCost; +import mage.abilities.effects.common.counter.AddCountersTargetEffect; +import mage.abilities.effects.common.counter.ProliferateEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.counters.CounterType; +import mage.filter.StaticFilters; +import mage.target.common.TargetArtifactPermanent; +import mage.target.common.TargetCreaturePermanent; +import mage.target.targetpointer.SecondTargetPointer; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class FiligreeVector extends CardImpl { + + public FiligreeVector(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT, CardType.CREATURE}, "{3}{W}"); + + this.subtype.add(SubType.PHYREXIAN); + this.subtype.add(SubType.CONSTRUCT); + this.power = new MageInt(1); + this.toughness = new MageInt(1); + + // When Filigree Vector enters the battlefield, put a +1/+1 counter on each of any number of target creatures and a charge counter on each of any number of target artifacts. + Ability ability = new EntersBattlefieldTriggeredAbility( + new AddCountersTargetEffect(CounterType.P1P1.createInstance()) + ); + ability.addEffect(new AddCountersTargetEffect(CounterType.CHARGE.createInstance()) + .setText("and a charge counter on each of any number of target artifacts") + .setTargetPointer(new SecondTargetPointer())); + ability.addTarget(new TargetCreaturePermanent(0, Integer.MAX_VALUE)); + ability.addTarget(new TargetArtifactPermanent(0, Integer.MAX_VALUE)); + this.addAbility(ability); + + // {1}, {T}, Sacrifice another artifact: Proliferate. + ability = new SimpleActivatedAbility(new ProliferateEffect(), new GenericManaCost(1)); + ability.addCost(new TapSourceCost()); + ability.addCost(new SacrificeTargetCost(StaticFilters.FILTER_CONTROLLED_ANOTHER_ARTIFACT_SHORT_TEXT)); + this.addAbility(ability); + } + + private FiligreeVector(final FiligreeVector card) { + super(card); + } + + @Override + public FiligreeVector copy() { + return new FiligreeVector(this); + } +} diff --git a/Mage.Sets/src/mage/sets/MarchOfTheMachineCommander.java b/Mage.Sets/src/mage/sets/MarchOfTheMachineCommander.java index 823382f830b..7c7b58b9249 100644 --- a/Mage.Sets/src/mage/sets/MarchOfTheMachineCommander.java +++ b/Mage.Sets/src/mage/sets/MarchOfTheMachineCommander.java @@ -113,6 +113,7 @@ public final class MarchOfTheMachineCommander extends ExpansionSet { cards.add(new SetCardInfo("Fetid Heath", 399, Rarity.RARE, mage.cards.f.FetidHeath.class)); cards.add(new SetCardInfo("Field of Ruin", 400, Rarity.UNCOMMON, mage.cards.f.FieldOfRuin.class)); cards.add(new SetCardInfo("Fiery Confluence", 278, Rarity.RARE, mage.cards.f.FieryConfluence.class)); + cards.add(new SetCardInfo("Filigree Vector", 15, Rarity.RARE, mage.cards.f.FiligreeVector.class)); cards.add(new SetCardInfo("First-Sphere Gargantua", 248, Rarity.COMMON, mage.cards.f.FirstSphereGargantua.class)); cards.add(new SetCardInfo("Flamerush Rider", 279, Rarity.RARE, mage.cards.f.FlamerushRider.class)); cards.add(new SetCardInfo("Flameshadow Conjuring", 280, Rarity.RARE, mage.cards.f.FlameshadowConjuring.class)); diff --git a/Mage/src/main/java/mage/filter/StaticFilters.java b/Mage/src/main/java/mage/filter/StaticFilters.java index 46949cbfccd..f6f57361ee6 100644 --- a/Mage/src/main/java/mage/filter/StaticFilters.java +++ b/Mage/src/main/java/mage/filter/StaticFilters.java @@ -431,6 +431,14 @@ public final class StaticFilters { FILTER_CONTROLLED_ANOTHER_ARTIFACT.setLockedFilter(true); } + public static final FilterControlledPermanent FILTER_CONTROLLED_ANOTHER_ARTIFACT_SHORT_TEXT = new FilterControlledPermanent("another artifact"); + + static { + FILTER_CONTROLLED_ANOTHER_ARTIFACT_SHORT_TEXT.add(AnotherPredicate.instance); + FILTER_CONTROLLED_ANOTHER_ARTIFACT_SHORT_TEXT.add(CardType.ARTIFACT.getPredicate()); + FILTER_CONTROLLED_ANOTHER_ARTIFACT_SHORT_TEXT.setLockedFilter(true); + } + public static final FilterControlledPermanent FILTER_CONTROLLED_ANOTHER_ARTIFACT_OR_CREATURE = new FilterControlledPermanent("another creature or artifact you control"); static {