From 64ce8d3587f08bc6d2e11667c60e2a799fd9d8d1 Mon Sep 17 00:00:00 2001 From: Susucre <34709007+Susucre@users.noreply.github.com> Date: Sat, 30 Mar 2024 17:59:12 +0100 Subject: [PATCH] [OTJ] Implement Boneyard Desecrator --- .../src/mage/cards/b/BoneyardDesecrator.java | 104 ++++++++++++++++++ .../mage/sets/OutlawsOfThunderJunction.java | 1 + 2 files changed, 105 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/b/BoneyardDesecrator.java diff --git a/Mage.Sets/src/mage/cards/b/BoneyardDesecrator.java b/Mage.Sets/src/mage/cards/b/BoneyardDesecrator.java new file mode 100644 index 00000000000..ca044a1a900 --- /dev/null +++ b/Mage.Sets/src/mage/cards/b/BoneyardDesecrator.java @@ -0,0 +1,104 @@ +package mage.cards.b; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.SimpleActivatedAbility; +import mage.abilities.costs.Cost; +import mage.abilities.costs.common.SacrificeTargetCost; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.Effect; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.effects.common.CreateTokenEffect; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.abilities.keyword.MenaceAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.constants.SubType; +import mage.constants.Zone; +import mage.counters.CounterType; +import mage.filter.FilterPermanent; +import mage.filter.StaticFilters; +import mage.filter.predicate.mageobject.OutlawPredicate; +import mage.game.Game; +import mage.game.permanent.Permanent; +import mage.game.permanent.token.TreasureToken; + +import java.util.List; +import java.util.UUID; + +/** + * @author Susucr + */ +public final class BoneyardDesecrator extends CardImpl { + + public BoneyardDesecrator(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{3}{B}"); + + this.subtype.add(SubType.ZOMBIE); + this.subtype.add(SubType.MERCENARY); + this.power = new MageInt(3); + this.toughness = new MageInt(4); + + // Menace + this.addAbility(new MenaceAbility()); + + // {1}{B}, Sacrifice another creature: Put a +1/+1 counter on Boneyard Desecrator. If an outlaw was sacrificed this way, create a Treasure token. + Effect effect = new AddCountersSourceEffect(CounterType.P1P1.createInstance()); + Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, effect, new ManaCostsImpl<>("{1}{B}")); + ability.addCost(new SacrificeTargetCost(StaticFilters.FILTER_CONTROLLED_ANOTHER_CREATURE)); + ability.addEffect(new BoneyardDesecratorEffect()); + this.addAbility(ability); + } + + private BoneyardDesecrator(final BoneyardDesecrator card) { + super(card); + } + + @Override + public BoneyardDesecrator copy() { + return new BoneyardDesecrator(this); + } +} + +// Inspired by Thallid Omnivore +class BoneyardDesecratorEffect extends OneShotEffect { + + private static final FilterPermanent filter = new FilterPermanent("an outlaw"); + + static { + filter.add(OutlawPredicate.instance); + } + + BoneyardDesecratorEffect() { + super(Outcome.GainLife); + this.staticText = "If an outlaw was sacrificed this way, create a Treasure token"; + } + + private BoneyardDesecratorEffect(final BoneyardDesecratorEffect effect) { + super(effect); + } + + @Override + public BoneyardDesecratorEffect copy() { + return new BoneyardDesecratorEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + for (Cost cost : source.getCosts()) { + if (cost instanceof SacrificeTargetCost) { + SacrificeTargetCost sacrificeCost = (SacrificeTargetCost) cost; + List permanents = sacrificeCost.getPermanents(); + for (Permanent permanent : permanents) { + if (!filter.match(permanent, source.getControllerId(), source, game)) { + continue; + } + return new CreateTokenEffect(new TreasureToken()).apply(game, source); + } + } + } + return false; + } +} diff --git a/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java b/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java index cb63fc07f2c..59f47a6998d 100644 --- a/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java +++ b/Mage.Sets/src/mage/sets/OutlawsOfThunderJunction.java @@ -38,6 +38,7 @@ public final class OutlawsOfThunderJunction extends ExpansionSet { cards.add(new SetCardInfo("Blacksnag Buzzard", 79, Rarity.COMMON, mage.cards.b.BlacksnagBuzzard.class)); cards.add(new SetCardInfo("Blood Hustler", 80, Rarity.UNCOMMON, mage.cards.b.BloodHustler.class)); cards.add(new SetCardInfo("Blooming Marsh", 266, Rarity.RARE, mage.cards.b.BloomingMarsh.class)); + cards.add(new SetCardInfo("Boneyard Desecrator", 81, Rarity.COMMON, mage.cards.b.BoneyardDesecrator.class)); cards.add(new SetCardInfo("Boom Box", 241, Rarity.UNCOMMON, mage.cards.b.BoomBox.class)); cards.add(new SetCardInfo("Botanical Sanctum", 267, Rarity.RARE, mage.cards.b.BotanicalSanctum.class)); cards.add(new SetCardInfo("Bounding Felidar", 5, Rarity.UNCOMMON, mage.cards.b.BoundingFelidar.class));