From 728a881f069b9173b3045486ba38c0f946dddf23 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Thu, 24 May 2018 11:34:31 -0400 Subject: [PATCH] Implemented Play of the Game --- Mage.Sets/src/mage/cards/p/PerilousVault.java | 48 +++----------- Mage.Sets/src/mage/cards/p/PlayOfTheGame.java | 62 +++++++++++++++++++ Mage.Sets/src/mage/sets/Battlebond.java | 1 + .../main/java/mage/filter/StaticFilters.java | 6 ++ 4 files changed, 77 insertions(+), 40 deletions(-) create mode 100644 Mage.Sets/src/mage/cards/p/PlayOfTheGame.java diff --git a/Mage.Sets/src/mage/cards/p/PerilousVault.java b/Mage.Sets/src/mage/cards/p/PerilousVault.java index 22b7457e156..b34e9e7e285 100644 --- a/Mage.Sets/src/mage/cards/p/PerilousVault.java +++ b/Mage.Sets/src/mage/cards/p/PerilousVault.java @@ -33,17 +33,12 @@ import mage.abilities.common.SimpleActivatedAbility; import mage.abilities.costs.common.ExileSourceCost; import mage.abilities.costs.common.TapSourceCost; import mage.abilities.costs.mana.GenericManaCost; -import mage.abilities.effects.OneShotEffect; +import mage.abilities.effects.common.ExileAllEffect; import mage.cards.CardImpl; import mage.cards.CardSetInfo; import mage.constants.CardType; -import mage.constants.Outcome; import mage.constants.Zone; -import mage.filter.FilterPermanent; -import mage.filter.common.FilterNonlandPermanent; -import mage.game.Game; -import mage.game.permanent.Permanent; -import mage.players.Player; +import mage.filter.StaticFilters; /** * @@ -52,10 +47,14 @@ import mage.players.Player; public class PerilousVault extends CardImpl { public PerilousVault(UUID ownerId, CardSetInfo setInfo) { - super(ownerId,setInfo,new CardType[]{CardType.ARTIFACT},"{4}"); + super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{4}"); // {5}, {T}, Exile Perilous Vault: Exile all nonland permanents. - Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new PerilousVaultEffect(), new GenericManaCost(5)); + Ability ability = new SimpleActivatedAbility( + Zone.BATTLEFIELD, + new ExileAllEffect(StaticFilters.FILTER_PERMANENTS_NON_LAND), + new GenericManaCost(5) + ); ability.addCost(new TapSourceCost()); ability.addCost(new ExileSourceCost()); this.addAbility(ability); @@ -70,34 +69,3 @@ public class PerilousVault extends CardImpl { return new PerilousVault(this); } } - -class PerilousVaultEffect extends OneShotEffect { - - private static final FilterPermanent filter = new FilterNonlandPermanent(); - - PerilousVaultEffect() { - super(Outcome.Exile); - this.staticText = "Exile all nonland permanents"; - } - - PerilousVaultEffect(final PerilousVaultEffect effect) { - super(effect); - } - - @Override - public PerilousVaultEffect copy() { - return new PerilousVaultEffect(this); - } - - @Override - public boolean apply(Game game, Ability source) { - Player controller = game.getPlayer(source.getControllerId()); - if (controller != null) { - for (Permanent permanent : game.getBattlefield().getActivePermanents(filter, source.getControllerId(), source.getSourceId(), game)) { - controller.moveCardToExileWithInfo(permanent, null, "", source.getSourceId(), game, Zone.HAND, true); - } - return true; - } - return false; - } -} diff --git a/Mage.Sets/src/mage/cards/p/PlayOfTheGame.java b/Mage.Sets/src/mage/cards/p/PlayOfTheGame.java new file mode 100644 index 00000000000..bc8648e68ae --- /dev/null +++ b/Mage.Sets/src/mage/cards/p/PlayOfTheGame.java @@ -0,0 +1,62 @@ +/* + * 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.cards.p; + +import java.util.UUID; +import mage.abilities.effects.common.ExileAllEffect; +import mage.abilities.keyword.AssistAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.filter.StaticFilters; + +/** + * + * @author TheElk801 + */ +public class PlayOfTheGame extends CardImpl { + + public PlayOfTheGame(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{6}{W}{W}"); + + // Assist + this.addAbility(new AssistAbility()); + + // Exile all nonland permanents. + this.getSpellAbility().addEffect(new ExileAllEffect(StaticFilters.FILTER_PERMANENTS_NON_LAND)); + } + + public PlayOfTheGame(final PlayOfTheGame card) { + super(card); + } + + @Override + public PlayOfTheGame copy() { + return new PlayOfTheGame(this); + } +} diff --git a/Mage.Sets/src/mage/sets/Battlebond.java b/Mage.Sets/src/mage/sets/Battlebond.java index 92781328714..b739ed03d7c 100644 --- a/Mage.Sets/src/mage/sets/Battlebond.java +++ b/Mage.Sets/src/mage/sets/Battlebond.java @@ -106,6 +106,7 @@ public class Battlebond extends ExpansionSet { cards.add(new SetCardInfo("Pir's Whim", 73, Rarity.RARE, mage.cards.p.PirsWhim.class)); cards.add(new SetCardInfo("Pir, Imaginative Rascal", 11, Rarity.RARE, mage.cards.p.PirImaginativeRascal.class)); cards.add(new SetCardInfo("Plains", 250, Rarity.LAND, mage.cards.basiclands.Plains.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Play of the Game", 29, Rarity.RARE, mage.cards.p.PlayOfTheGame.class)); cards.add(new SetCardInfo("Proud Mentor", 20, Rarity.UNCOMMON, mage.cards.p.ProudMentor.class)); cards.add(new SetCardInfo("Regna, the Redeemer", 3, Rarity.RARE, mage.cards.r.RegnaTheRedeemer.class)); cards.add(new SetCardInfo("Rowan Kenrith", 2, Rarity.MYTHIC, mage.cards.r.RowanKenrith.class)); diff --git a/Mage/src/main/java/mage/filter/StaticFilters.java b/Mage/src/main/java/mage/filter/StaticFilters.java index 7ef7ed806b9..e540945a421 100644 --- a/Mage/src/main/java/mage/filter/StaticFilters.java +++ b/Mage/src/main/java/mage/filter/StaticFilters.java @@ -357,6 +357,12 @@ public final class StaticFilters { FILTER_PERMANENT_NON_LAND.setLockedFilter(true); } + public static final FilterPermanent FILTER_PERMANENTS_NON_LAND = new FilterNonlandPermanent("nonland permanents"); + + static { + FILTER_PERMANENTS_NON_LAND.setLockedFilter(true); + } + public static final FilterCreatureSpell FILTER_SPELL_A_CREATURE = new FilterCreatureSpell("a creature spell"); static {