From 29f38c752c20deab373a30f19ff5909d3168fab1 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Fri, 11 Jan 2019 16:34:13 -0500 Subject: [PATCH] Implemented Consign to the Pit --- .../src/mage/cards/c/ConsignToThePit.java | 69 +++++++++++++++++++ .../src/mage/sets/RavnicaAllegiance.java | 1 + 2 files changed, 70 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/c/ConsignToThePit.java diff --git a/Mage.Sets/src/mage/cards/c/ConsignToThePit.java b/Mage.Sets/src/mage/cards/c/ConsignToThePit.java new file mode 100644 index 00000000000..18a9df9d95a --- /dev/null +++ b/Mage.Sets/src/mage/cards/c/ConsignToThePit.java @@ -0,0 +1,69 @@ +package mage.cards.c; + +import mage.abilities.Ability; +import mage.abilities.effects.OneShotEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.game.Game; +import mage.game.permanent.Permanent; +import mage.players.Player; +import mage.target.common.TargetCreaturePermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class ConsignToThePit extends CardImpl { + + public ConsignToThePit(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{5}{B}"); + + // Destroy target creature. Consign to the Pit deals 2 damage to that creature's controller. + this.getSpellAbility().addEffect(new ConsignToThePitEffect()); + this.getSpellAbility().addTarget(new TargetCreaturePermanent()); + } + + private ConsignToThePit(final ConsignToThePit card) { + super(card); + } + + @Override + public ConsignToThePit copy() { + return new ConsignToThePit(this); + } +} + +class ConsignToThePitEffect extends OneShotEffect { + + ConsignToThePitEffect() { + super(Outcome.Benefit); + staticText = "Destroy target creature. {this} deals 2 damage to that creature's controller."; + } + + private ConsignToThePitEffect(final ConsignToThePitEffect effect) { + super(effect); + } + + @Override + public ConsignToThePitEffect copy() { + return new ConsignToThePitEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Permanent permanent = game.getPermanent(source.getFirstTarget()); + if (permanent == null) { + return false; + } + Player player = game.getPlayer(permanent.getControllerId()); + if (player == null) { + return false; + } + permanent.destroy(source.getSourceId(), game, false); + player.damage(2, source.getSourceId(), game); + return true; + } +} \ No newline at end of file diff --git a/Mage.Sets/src/mage/sets/RavnicaAllegiance.java b/Mage.Sets/src/mage/sets/RavnicaAllegiance.java index a60020ec9a1..07d70e4fe72 100644 --- a/Mage.Sets/src/mage/sets/RavnicaAllegiance.java +++ b/Mage.Sets/src/mage/sets/RavnicaAllegiance.java @@ -76,6 +76,7 @@ public final class RavnicaAllegiance extends ExpansionSet { cards.add(new SetCardInfo("Combine Guildmage", 163, Rarity.UNCOMMON, mage.cards.c.CombineGuildmage.class)); cards.add(new SetCardInfo("Consecrate // Consume", 224, Rarity.UNCOMMON, mage.cards.c.ConsecrateConsume.class)); cards.add(new SetCardInfo("Concordia Pegasus", 7, Rarity.COMMON, mage.cards.c.ConcordiaPegasus.class)); + cards.add(new SetCardInfo("Consign to the Pit", 69, Rarity.COMMON, mage.cards.c.ConsignToThePit.class)); cards.add(new SetCardInfo("Coral Commando", 36, Rarity.COMMON, mage.cards.c.CoralCommando.class)); cards.add(new SetCardInfo("Cry of the Carnarium", 70, Rarity.UNCOMMON, mage.cards.c.CryOfTheCarnarium.class)); cards.add(new SetCardInfo("Cult Guildmage", 164, Rarity.UNCOMMON, mage.cards.c.CultGuildmage.class));