From 15c0bd9c38586b1294df433f67dd35e6e2f6e669 Mon Sep 17 00:00:00 2001 From: fireshoes Date: Tue, 8 Sep 2015 22:37:15 -0500 Subject: [PATCH] [BFZ] Implemented Smothering Abomination, Tandem Tactics, and Ob Nixilis Reignited. --- .../sets/battleforzendikar/FathomFeeder.java | 6 +- .../battleforzendikar/ObNixilisReignited.java | 131 ++++++++++++++++++ .../SmotheringAbomination.java | 116 ++++++++++++++++ .../sets/battleforzendikar/TandemTactics.java | 66 +++++++++ .../sets/dissension/PillarOfTheParuns.java | 4 +- 5 files changed, 317 insertions(+), 6 deletions(-) create mode 100644 Mage.Sets/src/mage/sets/battleforzendikar/ObNixilisReignited.java create mode 100644 Mage.Sets/src/mage/sets/battleforzendikar/SmotheringAbomination.java create mode 100644 Mage.Sets/src/mage/sets/battleforzendikar/TandemTactics.java diff --git a/Mage.Sets/src/mage/sets/battleforzendikar/FathomFeeder.java b/Mage.Sets/src/mage/sets/battleforzendikar/FathomFeeder.java index 91a4bcf5dfc..7b2034d276a 100644 --- a/Mage.Sets/src/mage/sets/battleforzendikar/FathomFeeder.java +++ b/Mage.Sets/src/mage/sets/battleforzendikar/FathomFeeder.java @@ -64,12 +64,12 @@ public class FathomFeeder extends CardImpl { // Devoid this.addAbility(new DevoidAbility(this.color)); - // Ingest - this.addAbility(new IngestAbility()); - // Deathtouch this.addAbility(DeathtouchAbility.getInstance()); + // Ingest + this.addAbility(new IngestAbility()); + // {3}{U}{B}: Draw a card. Each opponent exiles the top card of his or her library. Effect effect = new FathomFeederEffect(); Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new DrawCardSourceControllerEffect(1), new ManaCostsImpl("{3}{U}{B}")); diff --git a/Mage.Sets/src/mage/sets/battleforzendikar/ObNixilisReignited.java b/Mage.Sets/src/mage/sets/battleforzendikar/ObNixilisReignited.java new file mode 100644 index 00000000000..82ea5a1df23 --- /dev/null +++ b/Mage.Sets/src/mage/sets/battleforzendikar/ObNixilisReignited.java @@ -0,0 +1,131 @@ +/* + * 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.battleforzendikar; + +import java.util.UUID; +import mage.abilities.LoyaltyAbility; +import mage.abilities.TriggeredAbilityImpl; +import mage.abilities.common.EntersBattlefieldAbility; +import mage.abilities.effects.Effect; +import mage.abilities.effects.common.DestroyTargetEffect; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.abilities.effects.common.GetEmblemTargetPlayerEffect; +import mage.abilities.effects.common.LoseLifeSourceControllerEffect; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.cards.CardImpl; +import mage.constants.CardType; +import mage.constants.Rarity; +import mage.constants.Zone; +import mage.counters.CounterType; +import mage.game.Game; +import mage.game.command.Emblem; +import mage.game.events.GameEvent; +import mage.game.events.GameEvent.EventType; +import mage.target.common.TargetCreaturePermanent; +import mage.target.common.TargetOpponent; + +/** + * + * @author fireshoes + */ +public class ObNixilisReignited extends CardImpl { + + public ObNixilisReignited(UUID ownerId) { + super(ownerId, 119, "Ob Nixilis Reignited", Rarity.MYTHIC, new CardType[]{CardType.PLANESWALKER}, "{3}{B}{B}"); + this.expansionSetCode = "BFZ"; + this.subtype.add("Nixilis"); + + this.addAbility(new EntersBattlefieldAbility(new AddCountersSourceEffect(CounterType.LOYALTY.createInstance(5)), false)); + + // +1: You draw a card and you lose 1 life. + LoyaltyAbility ability1 = new LoyaltyAbility(new DrawCardSourceControllerEffect(1), 1); + ability1.addEffect(new LoseLifeSourceControllerEffect(1)); + this.addAbility(ability1); + + // -3: Destroy target creature. + LoyaltyAbility ability2 = new LoyaltyAbility(new DestroyTargetEffect(), -3); + ability2.addTarget(new TargetCreaturePermanent()); + this.addAbility(ability2); + + // -8: Target opponent gets an emblem with "Whenever a player draws a card, you lose 2 life." + Effect effect = new GetEmblemTargetPlayerEffect(new ObNixilisReignitedEmblem()); + effect.setText("Target opponent gets an emblem with \"Whenever a player draws a card, you lose 2 life.\""); + LoyaltyAbility ability3 = new LoyaltyAbility(effect, -8); + ability3.addTarget(new TargetOpponent()); + this.addAbility(ability3); + } + + public ObNixilisReignited(final ObNixilisReignited card) { + super(card); + } + + @Override + public ObNixilisReignited copy() { + return new ObNixilisReignited(this); + } +} + +class ObNixilisReignitedEmblem extends Emblem { + + public ObNixilisReignitedEmblem() { + setName("EMBLEM: Ob Nixilis Reignited"); + + this.getAbilities().add(new ObNixilisEmblemTriggeredAbility(new LoseLifeSourceControllerEffect(2), false)); + } +} + +class ObNixilisEmblemTriggeredAbility extends TriggeredAbilityImpl { + + public ObNixilisEmblemTriggeredAbility(Effect effect, boolean optional) { + super(Zone.COMMAND, effect, optional); + } + + public ObNixilisEmblemTriggeredAbility(final ObNixilisEmblemTriggeredAbility ability) { + super(ability); + } + + @Override + public boolean checkEventType(GameEvent event, Game game) { + return event.getType() == EventType.DREW_CARD; + } + + @Override + public boolean checkTrigger(GameEvent event, Game game) { + return event.getPlayerId() != null; + } + + @Override + public String getRule() { + return "Whenever a player draws a card, you lose 2 life."; + } + + @Override + public ObNixilisEmblemTriggeredAbility copy() { + return new ObNixilisEmblemTriggeredAbility(this); + } +} \ No newline at end of file diff --git a/Mage.Sets/src/mage/sets/battleforzendikar/SmotheringAbomination.java b/Mage.Sets/src/mage/sets/battleforzendikar/SmotheringAbomination.java new file mode 100644 index 00000000000..93158d66475 --- /dev/null +++ b/Mage.Sets/src/mage/sets/battleforzendikar/SmotheringAbomination.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.battleforzendikar; + +import java.util.UUID; +import mage.MageInt; +import mage.abilities.TriggeredAbilityImpl; +import mage.abilities.common.BeginningOfUpkeepTriggeredAbility; +import mage.abilities.effects.common.DrawCardSourceControllerEffect; +import mage.abilities.effects.common.SacrificeControllerEffect; +import mage.abilities.keyword.DevoidAbility; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.constants.CardType; +import mage.constants.Rarity; +import mage.constants.TargetController; +import mage.constants.Zone; +import mage.filter.common.FilterCreaturePermanent; +import mage.game.Game; +import mage.game.events.GameEvent; +import mage.game.events.GameEvent.EventType; + +/** + * + * @author fireshoes + */ +public class SmotheringAbomination extends CardImpl { + + public SmotheringAbomination(UUID ownerId) { + super(ownerId, 99, "Smothering Abomination", Rarity.RARE, new CardType[]{CardType.CREATURE}, "{2}{B}{B}"); + this.expansionSetCode = "BFZ"; + this.subtype.add("Eldrazi"); + this.power = new MageInt(4); + this.toughness = new MageInt(3); + + // Devoid + this.addAbility(new DevoidAbility(this.color)); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // At the beginning of your upkeep, sacrifice a creature + this.addAbility(new BeginningOfUpkeepTriggeredAbility(new SacrificeControllerEffect( + new FilterCreaturePermanent(), 1, null), TargetController.YOU, false)); + + // Whenever you sacrifice a creature, draw a card. + this.addAbility(new SmotheringAbominationTriggeredAbility()); + } + + public SmotheringAbomination(final SmotheringAbomination card) { + super(card); + } + + @Override + public SmotheringAbomination copy() { + return new SmotheringAbomination(this); + } +} + +class SmotheringAbominationTriggeredAbility extends TriggeredAbilityImpl { + + public SmotheringAbominationTriggeredAbility() { + super(Zone.BATTLEFIELD, new DrawCardSourceControllerEffect(1)); + } + + public SmotheringAbominationTriggeredAbility(final SmotheringAbominationTriggeredAbility ability) { + super(ability); + } + + @Override + public SmotheringAbominationTriggeredAbility copy() { + return new SmotheringAbominationTriggeredAbility(this); + } + + @Override + public boolean checkEventType(GameEvent event, Game game) { + return event.getType() == EventType.SACRIFICED_PERMANENT; + } + + @Override + public boolean checkTrigger(GameEvent event, Game game) { + return event.getPlayerId().equals(this.getControllerId()) + && game.getLastKnownInformation(event.getTargetId(), Zone.BATTLEFIELD).getCardType().contains(CardType.CREATURE); + } + + @Override + public String getRule() { + return "Whenever you sacrifice a creature, " + super.getRule(); + } +} + diff --git a/Mage.Sets/src/mage/sets/battleforzendikar/TandemTactics.java b/Mage.Sets/src/mage/sets/battleforzendikar/TandemTactics.java new file mode 100644 index 00000000000..d766749c509 --- /dev/null +++ b/Mage.Sets/src/mage/sets/battleforzendikar/TandemTactics.java @@ -0,0 +1,66 @@ +/* + * 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.battleforzendikar; + +import java.util.UUID; +import mage.abilities.effects.Effect; +import mage.abilities.effects.common.GainLifeEffect; +import mage.abilities.effects.common.continuous.BoostTargetEffect; +import mage.cards.CardImpl; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.Rarity; +import mage.target.common.TargetCreaturePermanent; + +/** + * + * @author fireshoes + */ +public class TandemTactics extends CardImpl { + + public TandemTactics(UUID ownerId) { + super(ownerId, 52, "Tandem Tactics", Rarity.COMMON, new CardType[]{CardType.INSTANT}, "{1}{W}"); + this.expansionSetCode = "BFZ"; + + // Up to two target creatures each get +1/+2 until end of turn. You gain 2 life. + Effect effect = new BoostTargetEffect(1, 2, Duration.EndOfTurn); + effect.setText("Up to two target creatures each get +1/+2 until end of turn"); + this.getSpellAbility().addEffect(effect); + this.getSpellAbility().addTarget(new TargetCreaturePermanent(0, 2)); + this.getSpellAbility().addEffect(new GainLifeEffect(2)); + } + + public TandemTactics(final TandemTactics card) { + super(card); + } + + @Override + public TandemTactics copy() { + return new TandemTactics(this); + } +} diff --git a/Mage.Sets/src/mage/sets/dissension/PillarOfTheParuns.java b/Mage.Sets/src/mage/sets/dissension/PillarOfTheParuns.java index 8278800e994..629823f495a 100644 --- a/Mage.Sets/src/mage/sets/dissension/PillarOfTheParuns.java +++ b/Mage.Sets/src/mage/sets/dissension/PillarOfTheParuns.java @@ -27,6 +27,7 @@ */ package mage.sets.dissension; +import java.util.UUID; import mage.ConditionalMana; import mage.MageObject; import mage.Mana; @@ -39,11 +40,8 @@ import mage.abilities.mana.conditional.ManaCondition; import mage.cards.CardImpl; import mage.constants.CardType; import mage.constants.Rarity; -import mage.filter.predicate.mageobject.MulticoloredPredicate; import mage.game.Game; -import java.util.UUID; - /** * * @author noxx