From 250ffd1b6f2cce34ac87642b3df06f53ea7a7e7f Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Thu, 3 Nov 2022 20:39:33 -0400 Subject: [PATCH] [BRO] Implement Defabricate --- Mage.Sets/src/mage/cards/d/Defabricate.java | 52 +++++++++++++++++++++ Mage.Sets/src/mage/sets/TheBrothersWar.java | 1 + 2 files changed, 53 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/d/Defabricate.java diff --git a/Mage.Sets/src/mage/cards/d/Defabricate.java b/Mage.Sets/src/mage/cards/d/Defabricate.java new file mode 100644 index 00000000000..96c07647220 --- /dev/null +++ b/Mage.Sets/src/mage/cards/d/Defabricate.java @@ -0,0 +1,52 @@ +package mage.cards.d; + +import mage.abilities.Mode; +import mage.abilities.effects.common.CounterTargetEffect; +import mage.abilities.effects.common.CounterTargetWithReplacementEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.PutCards; +import mage.filter.FilterSpell; +import mage.filter.predicate.Predicates; +import mage.target.TargetSpell; +import mage.target.common.TargetActivatedOrTriggeredAbility; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class Defabricate extends CardImpl { + + private static final FilterSpell filter = new FilterSpell("artifact or enchantment spell"); + + static { + filter.add(Predicates.or( + CardType.ARTIFACT.getPredicate(), + CardType.ENCHANTMENT.getPredicate() + )); + } + + public Defabricate(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{1}{U}"); + + // Choose one -- + // * Counter target artifact or enchantment spell. If a spell is countered this way, exile it instead of putting it into its owner's graveyard. + this.getSpellAbility().addEffect(new CounterTargetWithReplacementEffect(PutCards.EXILED)); + this.getSpellAbility().addTarget(new TargetSpell(filter)); + + // * Counter target activated or triggered ability. + this.getSpellAbility().addMode(new Mode(new CounterTargetEffect()) + .addTarget(new TargetActivatedOrTriggeredAbility())); + } + + private Defabricate(final Defabricate card) { + super(card); + } + + @Override + public Defabricate copy() { + return new Defabricate(this); + } +} diff --git a/Mage.Sets/src/mage/sets/TheBrothersWar.java b/Mage.Sets/src/mage/sets/TheBrothersWar.java index f2ee0c072d4..c34c6cd90d7 100644 --- a/Mage.Sets/src/mage/sets/TheBrothersWar.java +++ b/Mage.Sets/src/mage/sets/TheBrothersWar.java @@ -48,6 +48,7 @@ public final class TheBrothersWar extends ExpansionSet { cards.add(new SetCardInfo("Clay Revenant", 118, Rarity.COMMON, mage.cards.c.ClayRevenant.class)); cards.add(new SetCardInfo("Combat Thresher", 35, Rarity.UNCOMMON, mage.cards.c.CombatThresher.class)); cards.add(new SetCardInfo("Corrupt", 88, Rarity.UNCOMMON, mage.cards.c.Corrupt.class)); + cards.add(new SetCardInfo("Defabricate", 45, Rarity.UNCOMMON, mage.cards.d.Defabricate.class)); cards.add(new SetCardInfo("Depth Charge Colossus", 78, Rarity.COMMON, mage.cards.d.DepthChargeColossus.class)); cards.add(new SetCardInfo("Diabolic Intent", 89, Rarity.RARE, mage.cards.d.DiabolicIntent.class)); cards.add(new SetCardInfo("Disciples of Gix", 90, Rarity.UNCOMMON, mage.cards.d.DisciplesOfGix.class));