From ec9cb2745d25903953f53ce62b95f1b3a6e3ee09 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Thu, 25 Jan 2024 18:02:59 -0500 Subject: [PATCH] [MKM] Implement Pick Your Poison --- .../src/mage/cards/p/PickYourPoison.java | 49 +++++++++++++++++++ .../src/mage/sets/MurdersAtKarlovManor.java | 1 + 2 files changed, 50 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/p/PickYourPoison.java diff --git a/Mage.Sets/src/mage/cards/p/PickYourPoison.java b/Mage.Sets/src/mage/cards/p/PickYourPoison.java new file mode 100644 index 00000000000..b7ec2909e29 --- /dev/null +++ b/Mage.Sets/src/mage/cards/p/PickYourPoison.java @@ -0,0 +1,49 @@ +package mage.cards.p; + +import mage.abilities.Mode; +import mage.abilities.effects.common.SacrificeOpponentsEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.filter.FilterPermanent; +import mage.filter.StaticFilters; +import mage.filter.common.FilterCreaturePermanent; +import mage.filter.predicate.mageobject.AbilityPredicate; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class PickYourPoison extends CardImpl { + + private static final FilterPermanent filter = new FilterCreaturePermanent("creature with flying"); + + static { + filter.add(new AbilityPredicate(FlyingAbility.class)); + } + + public PickYourPoison(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{G}"); + + // Choose one -- + // * Each opponent sacrifices an artifact. + this.getSpellAbility().addEffect(new SacrificeOpponentsEffect(StaticFilters.FILTER_PERMANENT_ARTIFACT)); + + // * Each opponent sacrifices an enchantment. + this.getSpellAbility().addMode(new Mode(new SacrificeOpponentsEffect(StaticFilters.FILTER_PERMANENT_ENCHANTMENT))); + + // * Each opponent sacrifices a creature with flying. + this.getSpellAbility().addMode(new Mode(new SacrificeOpponentsEffect(filter))); + } + + private PickYourPoison(final PickYourPoison card) { + super(card); + } + + @Override + public PickYourPoison copy() { + return new PickYourPoison(this); + } +} diff --git a/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java b/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java index d51e3c7cdde..d9fd8a257e1 100644 --- a/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java +++ b/Mage.Sets/src/mage/sets/MurdersAtKarlovManor.java @@ -116,6 +116,7 @@ public final class MurdersAtKarlovManor extends ExpansionSet { cards.add(new SetCardInfo("On the Job", 30, Rarity.COMMON, mage.cards.o.OnTheJob.class)); cards.add(new SetCardInfo("Out Cold", 66, Rarity.COMMON, mage.cards.o.OutCold.class)); cards.add(new SetCardInfo("Persuasive Interrogators", 98, Rarity.UNCOMMON, mage.cards.p.PersuasiveInterrogators.class)); + cards.add(new SetCardInfo("Pick Your Poison", 170, Rarity.COMMON, mage.cards.p.PickYourPoison.class)); cards.add(new SetCardInfo("Plains", 272, Rarity.LAND, mage.cards.basiclands.Plains.class, FULL_ART_BFZ_VARIOUS)); cards.add(new SetCardInfo("Private Eye", 223, Rarity.UNCOMMON, mage.cards.p.PrivateEye.class)); cards.add(new SetCardInfo("Public Thoroughfare", 265, Rarity.COMMON, mage.cards.p.PublicThoroughfare.class));