mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
Removed redundant Living End effect. Fixes #6385
This commit is contained in:
parent
7ad7d5f03d
commit
ddf007e6f1
3 changed files with 80 additions and 143 deletions
|
@ -1,23 +1,11 @@
|
||||||
package mage.cards.l;
|
package mage.cards.l;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.MageObject;
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.effects.common.LivingDeathEffect;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
|
||||||
import mage.cards.Card;
|
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.cards.CardSetInfo;
|
import mage.cards.CardSetInfo;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Outcome;
|
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.filter.StaticFilters;
|
|
||||||
import mage.game.Game;
|
|
||||||
import mage.game.permanent.Permanent;
|
|
||||||
import mage.players.Player;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -41,64 +29,3 @@ public final class LivingDeath extends CardImpl {
|
||||||
return new LivingDeath(this);
|
return new LivingDeath(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class LivingDeathEffect extends OneShotEffect {
|
|
||||||
|
|
||||||
public LivingDeathEffect() {
|
|
||||||
super(Outcome.Benefit);
|
|
||||||
this.staticText = "Each player exiles all creature cards from their graveyard, then sacrifices all creatures they control, then puts all cards they exiled this way onto the battlefield";
|
|
||||||
}
|
|
||||||
|
|
||||||
public LivingDeathEffect(final LivingDeathEffect effect) {
|
|
||||||
super(effect);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public LivingDeathEffect copy() {
|
|
||||||
return new LivingDeathEffect(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean apply(Game game, Ability source) {
|
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
|
||||||
MageObject sourceObject = game.getObject(source.getSourceId());
|
|
||||||
if (controller != null && sourceObject != null) {
|
|
||||||
Map<UUID, Set<Card>> exiledCards = new HashMap<>();
|
|
||||||
|
|
||||||
// Move creature cards from graveyard to exile
|
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
|
||||||
Player player = game.getPlayer(playerId);
|
|
||||||
if (player != null) {
|
|
||||||
Set<Card> cardsPlayer = player.getGraveyard().getCards(StaticFilters.FILTER_CARD_CREATURE, game);
|
|
||||||
if (!cardsPlayer.isEmpty()) {
|
|
||||||
exiledCards.put(player.getId(), cardsPlayer);
|
|
||||||
player.moveCards(cardsPlayer, Zone.EXILED, source, game);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
game.getState().processAction(game);
|
|
||||||
|
|
||||||
// Sacrifice all creatures
|
|
||||||
for (Permanent permanent : game.getBattlefield().getActivePermanents(StaticFilters.FILTER_PERMANENT_CREATURE, source.getControllerId(), game)) {
|
|
||||||
permanent.sacrifice(source.getSourceId(), game);
|
|
||||||
}
|
|
||||||
game.getState().processAction(game);
|
|
||||||
|
|
||||||
// Exiled cards are put onto the battlefield at the same time under their owner's control
|
|
||||||
Set<Card> cardsToReturnFromExile = new HashSet<>();
|
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
|
||||||
Player player = game.getPlayer(playerId);
|
|
||||||
if (player != null) {
|
|
||||||
Set<Card> cardsPlayer = exiledCards.get(playerId);
|
|
||||||
if (cardsPlayer != null
|
|
||||||
&& !cardsPlayer.isEmpty()) {
|
|
||||||
cardsToReturnFromExile.addAll(cardsPlayer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
controller.moveCards(cardsToReturnFromExile, Zone.BATTLEFIELD, source, game, false, false, true, null);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,24 +1,12 @@
|
||||||
package mage.cards.l;
|
package mage.cards.l;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.MageObject;
|
|
||||||
import mage.abilities.Ability;
|
|
||||||
import mage.abilities.costs.mana.ManaCostsImpl;
|
import mage.abilities.costs.mana.ManaCostsImpl;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.common.LivingDeathEffect;
|
||||||
import mage.abilities.keyword.SuspendAbility;
|
import mage.abilities.keyword.SuspendAbility;
|
||||||
import mage.cards.Card;
|
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.cards.CardSetInfo;
|
import mage.cards.CardSetInfo;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Outcome;
|
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.filter.StaticFilters;
|
|
||||||
import mage.game.Game;
|
|
||||||
import mage.game.permanent.Permanent;
|
|
||||||
import mage.players.Player;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -35,8 +23,7 @@ public final class LivingEnd extends CardImpl {
|
||||||
this.addAbility(new SuspendAbility(3, new ManaCostsImpl("{2}{B}{B}"), this));
|
this.addAbility(new SuspendAbility(3, new ManaCostsImpl("{2}{B}{B}"), this));
|
||||||
// Each player exiles all creature cards from their graveyard, then sacrifices all creatures
|
// Each player exiles all creature cards from their graveyard, then sacrifices all creatures
|
||||||
// they control, then puts all cards they exiled this way onto the battlefield.
|
// they control, then puts all cards they exiled this way onto the battlefield.
|
||||||
this.getSpellAbility().addEffect(new LivingEndEffect());
|
this.getSpellAbility().addEffect(new LivingDeathEffect());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public LivingEnd(final LivingEnd card) {
|
public LivingEnd(final LivingEnd card) {
|
||||||
|
@ -48,56 +35,3 @@ public final class LivingEnd extends CardImpl {
|
||||||
return new LivingEnd(this);
|
return new LivingEnd(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class LivingEndEffect extends OneShotEffect {
|
|
||||||
|
|
||||||
public LivingEndEffect() {
|
|
||||||
super(Outcome.Benefit);
|
|
||||||
this.staticText = "Each player exiles all creature cards from their graveyard, then sacrifices all creatures they control, then puts all cards they exiled this way onto the battlefield";
|
|
||||||
}
|
|
||||||
|
|
||||||
public LivingEndEffect(final LivingEndEffect effect) {
|
|
||||||
super(effect);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public LivingEndEffect copy() {
|
|
||||||
return new LivingEndEffect(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean apply(Game game, Ability source) {
|
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
|
||||||
MageObject sourceObject = game.getObject(source.getSourceId());
|
|
||||||
if (controller != null && sourceObject != null) {
|
|
||||||
Map<UUID, Set<Card>> exiledCards = new HashMap<>();
|
|
||||||
// move creature cards from graveyard to exile
|
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
|
||||||
Player player = game.getPlayer(playerId);
|
|
||||||
if (player != null) {
|
|
||||||
Set<Card> cardsPlayer = player.getGraveyard().getCards(StaticFilters.FILTER_CARD_CREATURE, game);
|
|
||||||
if (!cardsPlayer.isEmpty()) {
|
|
||||||
exiledCards.put(player.getId(), cardsPlayer);
|
|
||||||
player.moveCards(cardsPlayer, Zone.EXILED, source, game);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// sacrifice all creatures
|
|
||||||
for (Permanent permanent : game.getBattlefield().getActivePermanents(StaticFilters.FILTER_PERMANENT_CREATURE, source.getControllerId(), game)) {
|
|
||||||
permanent.sacrifice(source.getSourceId(), game);
|
|
||||||
}
|
|
||||||
// put exiled cards to battlefield
|
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
|
||||||
Player player = game.getPlayer(playerId);
|
|
||||||
if (player != null) {
|
|
||||||
Set<Card> cardsPlayer = exiledCards.get(playerId);
|
|
||||||
if (cardsPlayer != null && !cardsPlayer.isEmpty()) {
|
|
||||||
player.moveCards(cardsPlayer, Zone.BATTLEFIELD, source, game, false, false, false, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,76 @@
|
||||||
|
package mage.abilities.effects.common;
|
||||||
|
|
||||||
|
import mage.MageObject;
|
||||||
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.effects.OneShotEffect;
|
||||||
|
import mage.cards.Card;
|
||||||
|
import mage.constants.Outcome;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import mage.filter.StaticFilters;
|
||||||
|
import mage.game.Game;
|
||||||
|
import mage.game.permanent.Permanent;
|
||||||
|
import mage.players.Player;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public class LivingDeathEffect extends OneShotEffect {
|
||||||
|
|
||||||
|
public LivingDeathEffect() {
|
||||||
|
super(Outcome.Benefit);
|
||||||
|
this.staticText = "Each player exiles all creature cards from their graveyard, then sacrifices all creatures they control, then puts all cards they exiled this way onto the battlefield";
|
||||||
|
}
|
||||||
|
|
||||||
|
public LivingDeathEffect(final LivingDeathEffect effect) {
|
||||||
|
super(effect);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public LivingDeathEffect copy() {
|
||||||
|
return new LivingDeathEffect(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean apply(Game game, Ability source) {
|
||||||
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
|
MageObject sourceObject = game.getObject(source.getSourceId());
|
||||||
|
if (controller != null && sourceObject != null) {
|
||||||
|
Map<UUID, Set<Card>> exiledCards = new HashMap<>();
|
||||||
|
|
||||||
|
// Move creature cards from graveyard to exile
|
||||||
|
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
||||||
|
Player player = game.getPlayer(playerId);
|
||||||
|
if (player != null) {
|
||||||
|
Set<Card> cardsPlayer = player.getGraveyard().getCards(StaticFilters.FILTER_CARD_CREATURE, game);
|
||||||
|
if (!cardsPlayer.isEmpty()) {
|
||||||
|
exiledCards.put(player.getId(), cardsPlayer);
|
||||||
|
player.moveCards(cardsPlayer, Zone.EXILED, source, game);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
game.getState().processAction(game);
|
||||||
|
|
||||||
|
// Sacrifice all creatures
|
||||||
|
for (Permanent permanent : game.getBattlefield().getActivePermanents(StaticFilters.FILTER_PERMANENT_CREATURE, source.getControllerId(), game)) {
|
||||||
|
permanent.sacrifice(source.getSourceId(), game);
|
||||||
|
}
|
||||||
|
|
||||||
|
game.getState().processAction(game);
|
||||||
|
|
||||||
|
// Exiled cards are put onto the battlefield at the same time under their owner's control
|
||||||
|
Set<Card> cardsToReturnFromExile = new HashSet<>();
|
||||||
|
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
||||||
|
Player player = game.getPlayer(playerId);
|
||||||
|
if (player != null) {
|
||||||
|
Set<Card> cardsPlayer = exiledCards.get(playerId);
|
||||||
|
if (cardsPlayer != null
|
||||||
|
&& !cardsPlayer.isEmpty()) {
|
||||||
|
cardsToReturnFromExile.addAll(cardsPlayer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
controller.moveCards(cardsToReturnFromExile, Zone.BATTLEFIELD, source, game, false, false, true, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue