From 1911e09802be5d4018d82f83026615979d5d45f0 Mon Sep 17 00:00:00 2001
From: LevelX2 <ludwig.hirth@online.de>
Date: Sun, 21 Oct 2012 00:21:29 +0200
Subject: [PATCH] [RTR] Destroy the Evidence, Grave Betrayal, Necropolis Regent

---
 .../returntoravnica/DestroyTheEvidence.java   | 117 ++++++++++
 .../sets/returntoravnica/GraveBetrayal.java   | 214 ++++++++++++++++++
 .../returntoravnica/NecropolisRegent.java     | 116 ++++++++++
 3 files changed, 447 insertions(+)
 create mode 100644 Mage.Sets/src/mage/sets/returntoravnica/DestroyTheEvidence.java
 create mode 100644 Mage.Sets/src/mage/sets/returntoravnica/GraveBetrayal.java
 create mode 100644 Mage.Sets/src/mage/sets/returntoravnica/NecropolisRegent.java

diff --git a/Mage.Sets/src/mage/sets/returntoravnica/DestroyTheEvidence.java b/Mage.Sets/src/mage/sets/returntoravnica/DestroyTheEvidence.java
new file mode 100644
index 0000000000..189ca11a7c
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/returntoravnica/DestroyTheEvidence.java
@@ -0,0 +1,117 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  The views and conclusions contained in the software and documentation are those of the
+ *  authors and should not be interpreted as representing official policies, either expressed
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+package mage.sets.returntoravnica;
+
+import java.util.UUID;
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.Constants.Zone;
+import mage.abilities.Ability;
+import mage.abilities.effects.OneShotEffect;
+import mage.abilities.effects.common.DestroyTargetEffect;
+import mage.cards.Card;
+import mage.cards.CardImpl;
+import mage.game.Game;
+import mage.game.permanent.Permanent;
+import mage.players.Player;
+import mage.target.common.TargetLandPermanent;
+
+/**
+ *
+ * @author LevelX2
+ */
+public class DestroyTheEvidence extends CardImpl<DestroyTheEvidence> {
+
+    public DestroyTheEvidence(UUID ownerId) {
+        super(ownerId, 64, "Destroy the Evidence", Rarity.COMMON, new CardType[]{CardType.SORCERY}, "{4}{B}");
+        this.expansionSetCode = "RTR";
+
+        this.color.setBlack(true);
+
+        // Destroy target land. Its controller reveals cards from the top of his
+        // or her library until he or she reveals a land card, then puts those cards into his or her graveyard.
+        TargetLandPermanent target = new TargetLandPermanent();
+        target.setRequired(true);
+        this.getSpellAbility().addTarget(target);
+        this.getSpellAbility().addEffect(new DestroyTargetEffect());
+        this.getSpellAbility().addEffect(new DestroyTheEvidenceEffect());
+    }
+
+    public DestroyTheEvidence(final DestroyTheEvidence card) {
+        super(card);
+    }
+
+    @Override
+    public DestroyTheEvidence copy() {
+        return new DestroyTheEvidence(this);
+    }
+}
+
+class DestroyTheEvidenceEffect extends OneShotEffect<DestroyTheEvidenceEffect> {
+
+    public DestroyTheEvidenceEffect() {
+        super(Constants.Outcome.Discard);
+        this.staticText = "Its controller reveals cards from the top of his or her library until he or she reveals a land card, then puts those cards into his or her graveyard";
+    }
+
+    public DestroyTheEvidenceEffect(final DestroyTheEvidenceEffect effect) {
+        super(effect);
+    }
+
+    @Override
+    public DestroyTheEvidenceEffect copy() {
+        return new DestroyTheEvidenceEffect(this);
+    }
+
+    @Override
+    public boolean apply(Game game, Ability source) {
+        UUID landTarget = source.getFirstTarget();
+        Permanent landPermanent = (Permanent) game.getLastKnownInformation(landTarget, Zone.BATTLEFIELD);
+        Card landCard = game.getCard(landTarget);
+        if (landPermanent != null && landCard != null) {
+            Player player = game.getPlayer(landPermanent.getControllerId());
+            if (player == null) {
+                return false;
+            }
+
+            boolean landFound = false;
+            while (player.getLibrary().size() > 0 && !landFound) {
+                Card card = player.getLibrary().removeFromTop(game);
+                if (card != null) {
+                    card.moveToZone(Constants.Zone.GRAVEYARD, source.getId(), game, false);
+                    if (card.getCardType().contains(CardType.LAND)) {
+                        landFound = true;
+                    }
+                }
+            }
+            return true;
+        }
+        return false;
+    }
+}
diff --git a/Mage.Sets/src/mage/sets/returntoravnica/GraveBetrayal.java b/Mage.Sets/src/mage/sets/returntoravnica/GraveBetrayal.java
new file mode 100644
index 0000000000..dc03f3f41e
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/returntoravnica/GraveBetrayal.java
@@ -0,0 +1,214 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  The views and conclusions contained in the software and documentation are those of the
+ *  authors and should not be interpreted as representing official policies, either expressed
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+
+package mage.sets.returntoravnica;
+
+import java.util.UUID;
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Duration;
+import mage.Constants.Rarity;
+import mage.Constants.Zone;
+import mage.abilities.Ability;
+import mage.abilities.DelayedTriggeredAbility;
+import mage.abilities.TriggeredAbilityImpl;
+import mage.abilities.common.delayed.AtEndOfTurnDelayedTriggeredAbility;
+import mage.abilities.effects.ContinuousEffectImpl;
+import mage.abilities.effects.Effect;
+import mage.abilities.effects.OneShotEffect;
+import mage.cards.Card;
+import mage.cards.CardImpl;
+import mage.counters.CounterType;
+import mage.game.Game;
+import mage.game.events.GameEvent;
+import mage.game.events.ZoneChangeEvent;
+import mage.game.permanent.Permanent;
+import mage.target.targetpointer.FixedTarget;
+
+/**
+ *
+ * @author LevelX2
+ */
+
+public class GraveBetrayal extends CardImpl<GraveBetrayal> {
+
+    public GraveBetrayal (UUID ownerId) {
+        super(ownerId, 67, "Grave Betrayal", Rarity.RARE, new CardType[]{CardType.ENCHANTMENT}, "{5}{B}{B}");
+        this.expansionSetCode = "RTR";
+        this.color.setBlack(true);
+
+        // Whenever a creature you don't control dies, return it to the battlefield under
+        // your control with an additional +1/+1 counter on it at the beginning of the
+        // next end step. That creature is a black Zombie in addition to its other colors and types.
+        this.addAbility(new GraveBetrayalTriggeredAbility());
+    }
+
+    public GraveBetrayal (final GraveBetrayal card) {
+        super(card);
+    }
+
+    @Override
+    public GraveBetrayal copy() {
+        return new GraveBetrayal(this);
+    }
+}
+
+class GraveBetrayalTriggeredAbility extends TriggeredAbilityImpl<GraveBetrayalTriggeredAbility> {
+
+    public GraveBetrayalTriggeredAbility() {
+        super(Constants.Zone.BATTLEFIELD, null);
+    }
+
+    public GraveBetrayalTriggeredAbility(final GraveBetrayalTriggeredAbility ability) {
+        super(ability);
+    }
+
+    @Override
+    public GraveBetrayalTriggeredAbility copy() {
+        return new GraveBetrayalTriggeredAbility(this);
+    }
+
+    @Override
+    public boolean checkTrigger(GameEvent event, Game game) {
+        if (event.getType() == GameEvent.EventType.ZONE_CHANGE
+                && ((ZoneChangeEvent) event).getToZone() == Constants.Zone.GRAVEYARD
+                && ((ZoneChangeEvent) event).getFromZone() == Constants.Zone.BATTLEFIELD) {
+            Permanent permanent = (Permanent) game.getLastKnownInformation(event.getTargetId(), Constants.Zone.BATTLEFIELD);
+            if (permanent != null && !permanent.getControllerId().equals(this.getControllerId()) && permanent.getCardType().contains(CardType.CREATURE)) {
+                Card card = (Card)game.getObject(permanent.getId());
+                if (card != null) {
+                    Effect effect = new GraveBetrayalEffect();
+                    effect.setTargetPointer(new FixedTarget(card.getId()));
+                    Integer zoneChanges = new Integer(card.getZoneChangeCounter());
+                    effect.setValue("zoneChanges", zoneChanges);
+
+                    DelayedTriggeredAbility delayedAbility = new AtEndOfTurnDelayedTriggeredAbility(effect);
+                    delayedAbility.setSourceId(this.getSourceId());
+                    delayedAbility.setControllerId(this.getControllerId());
+                    game.addDelayedTriggeredAbility(delayedAbility);
+                    return true;
+                }
+            }
+        }
+        return false;
+    }
+
+    @Override
+    public String getRule() {
+        return "Whenever a creature you don't control dies, return it to the battlefield under your control with an additional +1/+1 counter on it at the beginning of the next end step. That creature is a black Zombie in addition to its other colors and types.";
+    }
+}
+
+class GraveBetrayalEffect extends OneShotEffect<GraveBetrayalEffect> {
+
+    public GraveBetrayalEffect() {
+        super(Constants.Outcome.PutCreatureInPlay);
+        staticText = " return the creature to the battlefield under your control with an additional +1/+1 counter. That creature is a black Zombie in addition to its other colors and types";
+    }
+
+    public GraveBetrayalEffect(final GraveBetrayalEffect effect) {
+        super(effect);
+    }
+
+    @Override
+    public GraveBetrayalEffect copy() {
+        return new GraveBetrayalEffect(this);
+    }
+
+    @Override
+    public boolean apply(Game game, Ability source) {
+        Card card = game.getCard(targetPointer.getFirst(game, source));
+        if (card != null) {
+            Integer zoneChanges = (Integer) getValue("zoneChanges");
+            if (card.getZoneChangeCounter() == zoneChanges) {
+                Zone currentZone = game.getState().getZone(card.getId());
+                if (card.putOntoBattlefield(game, currentZone, source.getId(), source.getControllerId())) {
+                    Permanent creature = game.getPermanent(card.getId());
+                    creature.addCounters(CounterType.P1P1.createInstance(), game);
+                    ContinuousEffectImpl effect = new GraveBetrayalContiniousEffect();
+                    effect.setTargetPointer(new FixedTarget(creature.getId()));
+                    game.addEffect(effect, source);
+                    return true;
+                }
+            }
+        }
+        return false;
+    }
+
+}
+
+class GraveBetrayalContiniousEffect extends ContinuousEffectImpl<GraveBetrayalContiniousEffect> {
+
+    public GraveBetrayalContiniousEffect() {
+        super(Duration.Custom, Constants.Outcome.Neutral);
+        staticText = "That creature is a black Zombie in addition to its other colors and types";
+    }
+
+    public GraveBetrayalContiniousEffect(final GraveBetrayalContiniousEffect effect) {
+        super(effect);
+    }
+
+    @Override
+    public GraveBetrayalContiniousEffect copy() {
+        return new GraveBetrayalContiniousEffect(this);
+    }
+
+    @Override
+    public boolean apply(Constants.Layer layer, Constants.SubLayer sublayer, Ability source, Game game) {
+        Permanent creature = game.getPermanent(targetPointer.getFirst(game, source));
+        if (creature != null) {
+            switch (layer) {
+                case TypeChangingEffects_4:
+                    if (sublayer == Constants.SubLayer.NA) {
+                        creature.getSubtype().add("Zombie");
+                    }
+                    break;
+                case ColorChangingEffects_5:
+                    if (sublayer == Constants.SubLayer.NA) {
+                        creature.getColor().setBlack(true);
+                    }
+                    break;
+            }
+            return true;
+        } else {
+            this.used = true;
+        }
+        return false;
+    }
+
+    @Override
+    public boolean apply(Game game, Ability source) {
+        return false;
+    }
+
+    @Override
+    public boolean hasLayer(Constants.Layer layer) {
+        return layer == Constants.Layer.ColorChangingEffects_5 || layer == Constants.Layer.TypeChangingEffects_4;
+    }
+
+}
\ No newline at end of file
diff --git a/Mage.Sets/src/mage/sets/returntoravnica/NecropolisRegent.java b/Mage.Sets/src/mage/sets/returntoravnica/NecropolisRegent.java
new file mode 100644
index 0000000000..db4b38b853
--- /dev/null
+++ b/Mage.Sets/src/mage/sets/returntoravnica/NecropolisRegent.java
@@ -0,0 +1,116 @@
+/*
+ *  Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without modification, are
+ *  permitted provided that the following conditions are met:
+ *
+ *     1. Redistributions of source code must retain the above copyright notice, this list of
+ *        conditions and the following disclaimer.
+ *
+ *     2. Redistributions in binary form must reproduce the above copyright notice, this list
+ *        of conditions and the following disclaimer in the documentation and/or other materials
+ *        provided with the distribution.
+ *
+ *  THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ *  FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
+ *  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ *  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ *  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ *  ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ *  The views and conclusions contained in the software and documentation are those of the
+ *  authors and should not be interpreted as representing official policies, either expressed
+ *  or implied, of BetaSteward_at_googlemail.com.
+ */
+package mage.sets.returntoravnica;
+
+import java.util.UUID;
+import mage.Constants;
+import mage.Constants.CardType;
+import mage.Constants.Rarity;
+import mage.MageInt;
+import mage.abilities.TriggeredAbilityImpl;
+import mage.abilities.effects.Effect;
+import mage.abilities.effects.common.counter.AddCountersSourceEffect;
+import mage.abilities.effects.common.counter.AddCountersTargetEffect;
+import mage.abilities.keyword.FlyingAbility;
+import mage.cards.CardImpl;
+import mage.counters.CounterType;
+import mage.game.Game;
+import mage.game.events.DamagedPlayerEvent;
+import mage.game.events.GameEvent;
+import mage.game.permanent.Permanent;
+import mage.target.targetpointer.FixedTarget;
+
+/**
+ *
+ * @author LevelX2
+ */
+public class NecropolisRegent extends CardImpl<NecropolisRegent> {
+
+    public NecropolisRegent(UUID ownerId) {
+        super(ownerId, 71, "Necropolis Regent", Rarity.MYTHIC, new CardType[]{CardType.CREATURE}, "{3}{B}{B}{B}");
+        this.expansionSetCode = "RTR";
+        this.subtype.add("Vampire");
+        this.color.setBlack(true);
+
+        this.power = new MageInt(6);
+        this.toughness = new MageInt(5);
+
+        // Flying
+        this.addAbility(FlyingAbility.getInstance());
+
+        // Whenever a creature you control deals combat damage to a player, put that many +1/+1 counters on it.
+        this.addAbility(new NecropolisRegentTriggeredAbility());
+    }
+
+    public NecropolisRegent(final NecropolisRegent card) {
+        super(card);
+    }
+
+    @Override
+    public NecropolisRegent copy() {
+        return new NecropolisRegent(this);
+    }
+}
+
+class NecropolisRegentTriggeredAbility extends TriggeredAbilityImpl<NecropolisRegentTriggeredAbility> {
+
+    public NecropolisRegentTriggeredAbility() {
+        super(Constants.Zone.BATTLEFIELD, new AddCountersSourceEffect(CounterType.QUEST.createInstance()), false);
+    }
+
+    public NecropolisRegentTriggeredAbility(final NecropolisRegentTriggeredAbility ability) {
+        super(ability);
+    }
+
+    @Override
+    public NecropolisRegentTriggeredAbility copy() {
+        return new NecropolisRegentTriggeredAbility(this);
+    }
+
+    @Override
+    public boolean checkTrigger(GameEvent event, Game game) {
+        if (event.getType() == GameEvent.EventType.DAMAGED_PLAYER) {
+            if (((DamagedPlayerEvent) event).isCombatDamage()) {
+                Permanent creature = game.getPermanent(event.getSourceId());
+                if (creature != null && creature.getControllerId().equals(controllerId)) {
+                    this.getEffects().clear();
+                    Effect effect = new AddCountersTargetEffect(CounterType.P1P1.createInstance(event.getAmount()));
+                    effect.setTargetPointer(new FixedTarget(creature.getId()));
+                    this.addEffect(effect);
+                    return true;
+                }
+            }
+        }
+        return false;
+    }
+
+    @Override
+    public String getRule() {
+        return "Whenever a creature you control deals combat damage to a player, put that many +1/+1 counters on it.";
+    }
+}
\ No newline at end of file