From b76102b0cdb911c7217fc2f510b4de86651f91d2 Mon Sep 17 00:00:00 2001 From: LevelX2 Date: Mon, 22 Sep 2014 07:44:14 +0200 Subject: [PATCH] * Price of glory - Fixed that ability only triggers if the non active player uses a land to produce a mana (intervening if clause). --- Mage.Sets/src/mage/sets/odyssey/PriceOfGlory.java | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/Mage.Sets/src/mage/sets/odyssey/PriceOfGlory.java b/Mage.Sets/src/mage/sets/odyssey/PriceOfGlory.java index 419f9cc9a6..5ce893fce9 100644 --- a/Mage.Sets/src/mage/sets/odyssey/PriceOfGlory.java +++ b/Mage.Sets/src/mage/sets/odyssey/PriceOfGlory.java @@ -39,6 +39,7 @@ import mage.constants.Zone; import mage.game.Game; import mage.game.events.GameEvent; import mage.game.permanent.Permanent; +import mage.players.Player; import mage.target.targetpointer.FixedTarget; /** @@ -86,7 +87,8 @@ class PriceOfGloryAbility extends TriggeredAbilityImpl { if (permanent == null) { permanent = (Permanent) game.getLastKnownInformation(event.getSourceId(), Zone.BATTLEFIELD); } - if (permanent != null && permanent.getCardType().contains(CardType.LAND)) { + if (permanent != null && permanent.getCardType().contains(CardType.LAND) + && !permanent.getControllerId().equals(game.getActivePlayerId())) { // intervening if clause getEffects().get(0).setTargetPointer(new FixedTarget(permanent.getId())); return true; } @@ -118,9 +120,12 @@ class PriceOfGloryEffect extends OneShotEffect { @Override public boolean apply(Game game, Ability source) { - Permanent land = game.getPermanent(this.targetPointer.getFirst(game, source)); - if (land != null && !land.getControllerId().equals(game.getActivePlayerId())) { - land.destroy(source.getSourceId(), game, false); + Player controller = game.getPlayer(source.getControllerId()); + if (controller != null) { + Permanent land = game.getPermanentOrLKIBattlefield(this.targetPointer.getFirst(game, source)); + if (land != null && !land.getControllerId().equals(game.getActivePlayerId())) { // intervening if clause has to be checked again + land.destroy(source.getSourceId(), game, false); + } return true; } return false;