mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
updated a few cards which replace draws and which draw and reveal
This commit is contained in:
parent
f4da18df89
commit
57dba8c02a
6 changed files with 114 additions and 103 deletions
|
@ -1,15 +1,12 @@
|
||||||
|
|
||||||
package mage.cards.b;
|
package mage.cards.b;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
import mage.abilities.costs.common.PayLifeCost;
|
import mage.abilities.costs.common.PayLifeCost;
|
||||||
import mage.abilities.effects.ReplacementEffectImpl;
|
import mage.abilities.effects.ReplacementEffectImpl;
|
||||||
import mage.cards.Card;
|
import mage.cards.*;
|
||||||
import mage.cards.CardImpl;
|
|
||||||
import mage.cards.CardSetInfo;
|
|
||||||
import mage.cards.Cards;
|
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Duration;
|
import mage.constants.Duration;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
|
@ -19,7 +16,6 @@ import mage.game.events.GameEvent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @author jeffwadsworth
|
* @author jeffwadsworth
|
||||||
*/
|
*/
|
||||||
public final class BreathstealersCrypt extends CardImpl {
|
public final class BreathstealersCrypt extends CardImpl {
|
||||||
|
@ -28,8 +24,7 @@ public final class BreathstealersCrypt extends CardImpl {
|
||||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{U}{B}");
|
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{U}{B}");
|
||||||
|
|
||||||
// If a player would draw a card, instead they draw a card and reveals it. If it's a creature card, that player discards it unless they pay 3 life.
|
// If a player would draw a card, instead they draw a card and reveals it. If it's a creature card, that player discards it unless they pay 3 life.
|
||||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new BreathstealersCryptEffect()));
|
this.addAbility(new SimpleStaticAbility(new BreathstealersCryptEffect()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public BreathstealersCrypt(final BreathstealersCrypt card) {
|
public BreathstealersCrypt(final BreathstealersCrypt card) {
|
||||||
|
@ -44,12 +39,13 @@ public final class BreathstealersCrypt extends CardImpl {
|
||||||
|
|
||||||
class BreathstealersCryptEffect extends ReplacementEffectImpl {
|
class BreathstealersCryptEffect extends ReplacementEffectImpl {
|
||||||
|
|
||||||
public BreathstealersCryptEffect() {
|
BreathstealersCryptEffect() {
|
||||||
super(Duration.WhileOnBattlefield, Outcome.LoseLife);
|
super(Duration.WhileOnBattlefield, Outcome.LoseLife);
|
||||||
staticText = "If a player would draw a card, instead they draw a card and reveal it. If it's a creature card, that player discards it unless they pay 3 life";
|
staticText = "If a player would draw a card, instead they draw a card and reveal it. " +
|
||||||
|
"If it's a creature card, that player discards it unless they pay 3 life";
|
||||||
}
|
}
|
||||||
|
|
||||||
public BreathstealersCryptEffect(final BreathstealersCryptEffect effect) {
|
private BreathstealersCryptEffect(final BreathstealersCryptEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -66,29 +62,28 @@ class BreathstealersCryptEffect extends ReplacementEffectImpl {
|
||||||
@Override
|
@Override
|
||||||
public boolean replaceEvent(GameEvent event, Ability source, Game game) {
|
public boolean replaceEvent(GameEvent event, Ability source, Game game) {
|
||||||
Player player = game.getPlayer(event.getPlayerId());
|
Player player = game.getPlayer(event.getPlayerId());
|
||||||
if (player != null) {
|
if (player == null) {
|
||||||
Cards oldHand = player.getHand().copy();
|
return false;
|
||||||
if (player.drawCards(1, event.getSourceId(), game, event.getAppliedEffects()) > 0) {
|
|
||||||
Cards drawnCards = player.getHand().copy();
|
|
||||||
drawnCards.removeAll(oldHand);
|
|
||||||
player.revealCards(source, "The card drawn from " + player.getName() + "'s library.", drawnCards, game);
|
|
||||||
for (Card cardDrawn : drawnCards.getCards(game)) {
|
|
||||||
if (cardDrawn.isCreature()) {
|
|
||||||
game.informPlayers("The card drawn by " + player.getName() + " is a creature card. He/she must pay 3 life or that card gets discarded.");
|
|
||||||
PayLifeCost cost = new PayLifeCost(3);
|
|
||||||
if (cost.canPay(source, source.getSourceId(), player.getId(), game)
|
|
||||||
&& player.chooseUse(outcome, "Do you wish to pay 3 life to keep the card " + cardDrawn.getIdName() + "? If not, you discard it.", source, game)) {
|
|
||||||
cost.pay(source, game, source.getSourceId(), player.getId(), true, cost);
|
|
||||||
} else {
|
|
||||||
game.informPlayers("The cost of 3 life was not paid by " + player.getName() + ", so " + cardDrawn.getIdName() + " will be discarded.");
|
|
||||||
player.discard(cardDrawn, source, game);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Card cardDrawn = player.getLibrary().getFromTop(game);
|
||||||
|
// Gatherer ruling (2007-02-01)
|
||||||
|
// If the draw is replaced by another effect, none of the rest of Fa’adiyah Seer’s ability applies,
|
||||||
|
// even if the draw is replaced by another draw (such as with Enduring Renewal).
|
||||||
|
if (cardDrawn == null || player.drawCards(1, event.getSourceId(), game, event.getAppliedEffects()) != 1) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
player.revealCards(source, new CardsImpl(cardDrawn), game);
|
||||||
|
if (!cardDrawn.isCreature()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
game.informPlayers("The card drawn by " + player.getName() + " is a creature card. They discard that card unless they pay 3 life.");
|
||||||
|
PayLifeCost cost = new PayLifeCost(3);
|
||||||
|
if (!cost.canPay(source, source.getSourceId(), player.getId(), game)
|
||||||
|
|| !player.chooseUse(outcome, "Pay 3 life or discard " + cardDrawn.getIdName() + "?", null, "Pay 3 life", "Discard", source, game)
|
||||||
|
|| !cost.pay(source, game, source.getSourceId(), player.getId(), true, cost)) {
|
||||||
|
player.discard(cardDrawn, source, game);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
package mage.cards.e;
|
package mage.cards.e;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import mage.MageObject;
|
import mage.MageObject;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.PutIntoGraveFromBattlefieldAllTriggeredAbility;
|
import mage.abilities.common.PutIntoGraveFromBattlefieldAllTriggeredAbility;
|
||||||
|
@ -21,7 +21,6 @@ import mage.game.permanent.Permanent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @author anonymous
|
* @author anonymous
|
||||||
*/
|
*/
|
||||||
public final class EnduringRenewal extends CardImpl {
|
public final class EnduringRenewal extends CardImpl {
|
||||||
|
@ -86,8 +85,11 @@ class EnduringRenewalReplacementEffect extends ReplacementEffectImpl {
|
||||||
controller.revealCards("Top card of " + controller.getName() + "'s library", cards, game);
|
controller.revealCards("Top card of " + controller.getName() + "'s library", cards, game);
|
||||||
if (card.isCreature()) {
|
if (card.isCreature()) {
|
||||||
controller.moveCards(card, Zone.GRAVEYARD, source, game);
|
controller.moveCards(card, Zone.GRAVEYARD, source, game);
|
||||||
return true;
|
} else {
|
||||||
|
// This is still replacing the draw, so we still return true
|
||||||
|
controller.drawCards(1, source.getSourceId(), game, event.getAppliedEffects());
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
package mage.cards.f;
|
package mage.cards.f;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import mage.MageInt;
|
import mage.MageInt;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleActivatedAbility;
|
import mage.abilities.common.SimpleActivatedAbility;
|
||||||
|
@ -21,7 +22,6 @@ import mage.game.Game;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
public final class FaadiyahSeer extends CardImpl {
|
public final class FaadiyahSeer extends CardImpl {
|
||||||
|
@ -69,15 +69,20 @@ class FaadiyahSeerEffect extends OneShotEffect {
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null) {
|
if (controller == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
Card card = controller.getLibrary().getFromTop(game);
|
Card card = controller.getLibrary().getFromTop(game);
|
||||||
controller.drawCards(1, source.getSourceId(), game);
|
// Gatherer ruling (2007-02-01)
|
||||||
controller.revealCards("Fa'adiyah Seer", new CardsImpl(card), game);
|
// If the draw is replaced by another effect, none of the rest of Fa’adiyah Seer’s ability applies,
|
||||||
if (!filter.match(card, game)) {
|
// even if the draw is replaced by another draw (such as with Enduring Renewal).
|
||||||
|
if (controller.drawCards(1, source.getSourceId(), game) != 1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
controller.revealCards(source, new CardsImpl(card), game);
|
||||||
|
if (!card.isLand()) {
|
||||||
controller.discard(card, source, game);
|
controller.discard(card, source, game);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -113,14 +113,18 @@ class JaceMirrorMageDrawEffect extends OneShotEffect {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
// TODO: Make this and similar effects work with draw replacement correctly
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
Player player = game.getPlayer(source.getControllerId());
|
if (controller == null) {
|
||||||
if (player == null) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
Card card = player.getLibrary().getFromTop(game);
|
Card card = controller.getLibrary().getFromTop(game);
|
||||||
player.drawCards(1, source.getSourceId(), game);
|
// Gatherer ruling (2007-02-01)
|
||||||
player.revealCards(source, new CardsImpl(card), game);
|
// If the draw is replaced by another effect, none of the rest of Fa’adiyah Seer’s ability applies,
|
||||||
|
// even if the draw is replaced by another draw (such as with Enduring Renewal).
|
||||||
|
if (controller.drawCards(1, source.getSourceId(), game) != 1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
controller.revealCards(source, new CardsImpl(card), game);
|
||||||
if (card == null || card.getConvertedManaCost() == 0) {
|
if (card == null || card.getConvertedManaCost() == 0) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
package mage.cards.s;
|
package mage.cards.s;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import mage.MageInt;
|
import mage.MageInt;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleActivatedAbility;
|
import mage.abilities.common.SimpleActivatedAbility;
|
||||||
|
@ -21,7 +21,6 @@ import mage.game.Game;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @author MarcoMarin
|
* @author MarcoMarin
|
||||||
*/
|
*/
|
||||||
public final class Sindbad extends CardImpl {
|
public final class Sindbad extends CardImpl {
|
||||||
|
@ -34,7 +33,6 @@ public final class Sindbad extends CardImpl {
|
||||||
|
|
||||||
// {tap}: Draw a card and reveal it. If it isn't a land card, discard it.
|
// {tap}: Draw a card and reveal it. If it isn't a land card, discard it.
|
||||||
this.addAbility(new SimpleActivatedAbility(Zone.BATTLEFIELD, new SindbadEffect(), new TapSourceCost()));
|
this.addAbility(new SimpleActivatedAbility(Zone.BATTLEFIELD, new SindbadEffect(), new TapSourceCost()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Sindbad(final Sindbad card) {
|
public Sindbad(final Sindbad card) {
|
||||||
|
@ -46,16 +44,15 @@ public final class Sindbad extends CardImpl {
|
||||||
return new Sindbad(this);
|
return new Sindbad(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class SindbadEffect extends OneShotEffect {
|
class SindbadEffect extends OneShotEffect {
|
||||||
|
|
||||||
private static final FilterCard filter = new FilterLandCard();
|
SindbadEffect() {
|
||||||
|
|
||||||
public SindbadEffect() {
|
|
||||||
super(Outcome.DrawCard);
|
super(Outcome.DrawCard);
|
||||||
this.staticText = "Draw a card and reveal it. If it isn't a land card, discard it";
|
this.staticText = "Draw a card and reveal it. If it isn't a land card, discard it";
|
||||||
}
|
}
|
||||||
|
|
||||||
public SindbadEffect(final SindbadEffect effect) {
|
private SindbadEffect(final SindbadEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,15 +64,20 @@ class SindbadEffect extends OneShotEffect {
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null) {
|
if (controller == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
Card card = controller.getLibrary().getFromTop(game);
|
Card card = controller.getLibrary().getFromTop(game);
|
||||||
controller.drawCards(1, source.getSourceId(), game);
|
// Gatherer ruling (2007-02-01)
|
||||||
controller.revealCards("Sindbad", new CardsImpl(card), game);
|
// If the draw is replaced by another effect, none of the rest of Fa’adiyah Seer’s ability applies,
|
||||||
if (!filter.match(card, game)) {
|
// even if the draw is replaced by another draw (such as with Enduring Renewal).
|
||||||
|
if (controller.drawCards(1, source.getSourceId(), game) != 1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
controller.revealCards(source, new CardsImpl(card), game);
|
||||||
|
if (!card.isLand()) {
|
||||||
controller.discard(card, source, game);
|
controller.discard(card, source, game);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
package mage.cards.z;
|
package mage.cards.z;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import mage.MageObject;
|
import mage.MageObject;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
|
@ -22,7 +22,6 @@ import mage.game.events.GameEvent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @author Quercitron
|
* @author Quercitron
|
||||||
*/
|
*/
|
||||||
public final class ZursWeirding extends CardImpl {
|
public final class ZursWeirding extends CardImpl {
|
||||||
|
@ -49,12 +48,12 @@ public final class ZursWeirding extends CardImpl {
|
||||||
|
|
||||||
class ZursWeirdingReplacementEffect extends ReplacementEffectImpl {
|
class ZursWeirdingReplacementEffect extends ReplacementEffectImpl {
|
||||||
|
|
||||||
public ZursWeirdingReplacementEffect() {
|
ZursWeirdingReplacementEffect() {
|
||||||
super(Duration.WhileOnBattlefield, Outcome.Neutral);
|
super(Duration.WhileOnBattlefield, Outcome.Neutral);
|
||||||
this.staticText = "If a player would draw a card, they reveal it instead. Then any other player may pay 2 life. If a player does, put that card into its owner's graveyard. Otherwise, that player draws a card.";
|
this.staticText = "If a player would draw a card, they reveal it instead. Then any other player may pay 2 life. If a player does, put that card into its owner's graveyard. Otherwise, that player draws a card.";
|
||||||
}
|
}
|
||||||
|
|
||||||
public ZursWeirdingReplacementEffect(final ZursWeirdingReplacementEffect effect) {
|
private ZursWeirdingReplacementEffect(final ZursWeirdingReplacementEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,10 +82,14 @@ class ZursWeirdingReplacementEffect extends ReplacementEffectImpl {
|
||||||
boolean paid = false;
|
boolean paid = false;
|
||||||
Player player = game.getPlayer(event.getTargetId());
|
Player player = game.getPlayer(event.getTargetId());
|
||||||
MageObject sourceObject = source.getSourceObject(game);
|
MageObject sourceObject = source.getSourceObject(game);
|
||||||
if (player != null
|
if (player == null
|
||||||
&& sourceObject != null) {
|
|| sourceObject == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
Card card = player.getLibrary().getFromTop(game);
|
Card card = player.getLibrary().getFromTop(game);
|
||||||
if (card != null) {
|
if (card == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
// Reveals it instead
|
// Reveals it instead
|
||||||
player.revealCards(sourceObject.getIdName() + " next draw of " + player.getName() + " (" + game.getTurnNum() + '|' + game.getPhase().getType() + ')', new CardsImpl(card), game);
|
player.revealCards(sourceObject.getIdName() + " next draw of " + player.getName() + " (" + game.getTurnNum() + '|' + game.getPhase().getType() + ')', new CardsImpl(card), game);
|
||||||
|
|
||||||
|
@ -112,8 +115,8 @@ class ZursWeirdingReplacementEffect extends ReplacementEffectImpl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
// This is still replacing the draw, so we still return true
|
||||||
}
|
player.drawCards(1, source.getSourceId(), game, event.getAppliedEffects());
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue