forked from External/mage
updated various cards to improve how they handle exiling with info (#7615)
This commit is contained in:
parent
bb0a995541
commit
bd3777997e
34 changed files with 349 additions and 442 deletions
|
|
@ -1,14 +1,15 @@
|
|||
|
||||
package mage.abilities.effects.common;
|
||||
|
||||
import java.util.Locale;
|
||||
import java.util.UUID;
|
||||
import mage.MageObject;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
import mage.cards.Cards;
|
||||
import mage.cards.CardsImpl;
|
||||
import mage.constants.Outcome;
|
||||
import mage.constants.Zone;
|
||||
import mage.filter.FilterCard;
|
||||
import mage.filter.StaticFilters;
|
||||
import mage.game.Game;
|
||||
import mage.players.Player;
|
||||
import mage.target.Target;
|
||||
|
|
@ -16,29 +17,32 @@ import mage.target.common.TargetCardInHand;
|
|||
import mage.target.common.TargetCardInYourGraveyard;
|
||||
import mage.util.CardUtil;
|
||||
|
||||
import java.util.Locale;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author BetaSteward_at_googlemail.com
|
||||
*/
|
||||
public class ExileFromZoneTargetEffect extends OneShotEffect {
|
||||
|
||||
private Zone zone;
|
||||
private FilterCard filter;
|
||||
private UUID exileId;
|
||||
private String exileName;
|
||||
private int amount;
|
||||
private final Zone zone;
|
||||
private final FilterCard filter;
|
||||
private final int amount;
|
||||
private final boolean withSource;
|
||||
|
||||
public ExileFromZoneTargetEffect(Zone zone, UUID exileId, String exileName, FilterCard filter) {
|
||||
this(zone, exileId, exileName, filter, 1);
|
||||
public ExileFromZoneTargetEffect(Zone zone, boolean withSource) {
|
||||
this(zone, StaticFilters.FILTER_CARD, withSource);
|
||||
}
|
||||
|
||||
public ExileFromZoneTargetEffect(Zone zone, UUID exileId, String exileName, FilterCard filter, int amount) {
|
||||
public ExileFromZoneTargetEffect(Zone zone, FilterCard filter, boolean withSource) {
|
||||
this(zone, filter, 1, withSource);
|
||||
}
|
||||
|
||||
public ExileFromZoneTargetEffect(Zone zone, FilterCard filter, int amount, boolean withSource) {
|
||||
super(Outcome.Exile);
|
||||
this.zone = zone;
|
||||
this.filter = filter;
|
||||
this.exileId = exileId;
|
||||
this.exileName = exileName;
|
||||
this.amount = amount;
|
||||
this.withSource = withSource;
|
||||
setText();
|
||||
}
|
||||
|
||||
|
|
@ -46,33 +50,36 @@ public class ExileFromZoneTargetEffect extends OneShotEffect {
|
|||
super(effect);
|
||||
this.zone = effect.zone;
|
||||
this.filter = effect.filter.copy();
|
||||
this.exileId = effect.exileId;
|
||||
this.exileName = effect.exileName;
|
||||
this.amount = effect.amount;
|
||||
this.withSource = effect.withSource;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
Player player = game.getPlayer(targetPointer.getFirst(game, source));
|
||||
if (player != null) {
|
||||
Target target = null;
|
||||
switch (zone) {
|
||||
case HAND:
|
||||
target = new TargetCardInHand(Math.min(player.getHand().count(filter, game), amount), filter);
|
||||
break;
|
||||
case GRAVEYARD:
|
||||
target = new TargetCardInYourGraveyard(Math.min(player.getGraveyard().count(filter, game), amount), filter);
|
||||
break;
|
||||
default:
|
||||
}
|
||||
if (target != null && target.canChoose(source.getSourceId(), player.getId(), game)) {
|
||||
if (target.chooseTarget(Outcome.Exile, player.getId(), source, game)) {
|
||||
player.moveCardsToExile(new CardsImpl(target.getTargets()).getCards(game), source, game, true, exileId, exileName);
|
||||
}
|
||||
}
|
||||
MageObject mageObject = source.getSourceObject(game);
|
||||
if (player == null) {
|
||||
return false;
|
||||
}
|
||||
Target target = null;
|
||||
switch (zone) {
|
||||
case HAND:
|
||||
target = new TargetCardInHand(Math.min(player.getHand().count(filter, game), amount), filter);
|
||||
break;
|
||||
case GRAVEYARD:
|
||||
target = new TargetCardInYourGraveyard(Math.min(player.getGraveyard().count(filter, game), amount), filter);
|
||||
break;
|
||||
default:
|
||||
}
|
||||
if (target == null || !target.canChoose(source.getSourceId(), player.getId(), game)) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
target.chooseTarget(Outcome.Exile, player.getId(), source, game);
|
||||
Cards cards = new CardsImpl(target.getTargets());
|
||||
if (withSource) {
|
||||
return player.moveCardsToExile(cards.getCards(game), source, game, true, CardUtil.getExileZoneId(game, source), mageObject.getName());
|
||||
}
|
||||
return player.moveCards(cards, Zone.EXILED, source, game);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
@ -81,6 +88,7 @@ public class ExileFromZoneTargetEffect extends OneShotEffect {
|
|||
}
|
||||
|
||||
private void setText() {
|
||||
staticText = "target player exiles " + CardUtil.numberToText(amount, "a") + ' ' + filter.getMessage() + " from their " + zone.toString().toLowerCase(Locale.ENGLISH);
|
||||
staticText = "target player exiles " + CardUtil.numberToText(amount, "a")
|
||||
+ ' ' + filter.getMessage() + " from their " + zone.toString().toLowerCase(Locale.ENGLISH);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue