From 1dc421a545bac0d0f67726206986f2c6579f342c Mon Sep 17 00:00:00 2001 From: davidmfritz Date: Thu, 1 Nov 2018 10:13:57 +0100 Subject: [PATCH] Fixed to get the correct player list Refactor to reveal first, then take action --- Mage.Sets/src/mage/cards/c/ClearTheLand.java | 26 +++++++++----------- 1 file changed, 11 insertions(+), 15 deletions(-) diff --git a/Mage.Sets/src/mage/cards/c/ClearTheLand.java b/Mage.Sets/src/mage/cards/c/ClearTheLand.java index 1bc1f4ad01..13b9be2f02 100644 --- a/Mage.Sets/src/mage/cards/c/ClearTheLand.java +++ b/Mage.Sets/src/mage/cards/c/ClearTheLand.java @@ -14,7 +14,6 @@ import mage.constants.Zone; import mage.game.Game; import mage.players.Library; import mage.players.Player; -import mage.players.Players; /** * @@ -59,30 +58,27 @@ class ClearTheLandEffect extends OneShotEffect { @Override public boolean apply(Game game, Ability source) { - int numOfCardsToReveal = 5; boolean tapped = true; Player controller = game.getPlayer(source.getControllerId()); if (controller != null) { - Players allPlayers = game.getPlayers(); - for (Player player : allPlayers.values()) { + for (UUID playerId : game.getState().getPlayersInRange(controller.getId(), game)) { + Player player = game.getPlayer(playerId); if (player != null) { Library library = player.getLibrary(); Cards cardsToReveal = new CardsImpl(); - for (int i = 0; i < numOfCardsToReveal; i++) { - if (!library.hasCards()) { - break; - } - Card card = library.getFromTop(game); - cardsToReveal.add(card); - if (card.isLand()) { - player.moveCards(card, Zone.BATTLEFIELD, source, game, tapped, false, true, null); - } else { - player.moveCards(card, Zone.EXILED, source, game); + cardsToReveal.addAll(library.getTopCards(game, 5)); + if (!cardsToReveal.isEmpty()) { + player.revealCards(source, "Revealed cards for " + player.getName(), cardsToReveal, game); + for (Card card : cardsToReveal.getCards(game)) { + if (card.isLand()) { + player.moveCards(card, Zone.BATTLEFIELD, source, game, tapped, false, true, null); + } else { + player.moveCards(card, Zone.EXILED, source, game); + } } } - player.revealCards(source, "Revealed cards for " + player.getName(), cardsToReveal, game); } } return true;