Some rework of Spell Rupture and CounterUnlessPaysEffect.

This commit is contained in:
LevelX2 2013-03-30 01:55:17 +01:00
parent 5a68ba33da
commit 4212e5cfb6
2 changed files with 15 additions and 20 deletions

View file

@ -31,6 +31,7 @@ import java.util.UUID;
import mage.Constants; import mage.Constants;
import mage.Constants.CardType; import mage.Constants.CardType;
import mage.Constants.Rarity; import mage.Constants.Rarity;
import mage.MageObject;
import mage.abilities.Ability; import mage.abilities.Ability;
import mage.abilities.Mode; import mage.abilities.Mode;
import mage.abilities.costs.mana.GenericManaCost; import mage.abilities.costs.mana.GenericManaCost;
@ -39,9 +40,7 @@ import mage.abilities.effects.OneShotEffect;
import mage.cards.CardImpl; import mage.cards.CardImpl;
import mage.filter.common.FilterControlledCreaturePermanent; import mage.filter.common.FilterControlledCreaturePermanent;
import mage.game.Game; import mage.game.Game;
import mage.game.events.GameEvent;
import mage.game.permanent.Permanent; import mage.game.permanent.Permanent;
import mage.game.stack.Spell;
import mage.game.stack.StackObject; import mage.game.stack.StackObject;
import mage.players.Player; import mage.players.Player;
import mage.target.TargetSpell; import mage.target.TargetSpell;
@ -94,25 +93,21 @@ class SpellRuptureCounterUnlessPaysEffect extends OneShotEffect<SpellRuptureCoun
if (spell != null) { if (spell != null) {
Player player = game.getPlayer(spell.getControllerId()); Player player = game.getPlayer(spell.getControllerId());
Player controller = game.getPlayer(source.getControllerId()); Player controller = game.getPlayer(source.getControllerId());
int amount = new greatestPowerCountCreatureYouControl().calculate(game, source); MageObject sourceObject = game.getObject(source.getSourceId());
if (player != null && controller != null) { if (player != null && controller != null && sourceObject != null) {
if (amount > 0) { int amount = new greatestPowerCountCreatureYouControl().calculate(game, source);
GenericManaCost cost = new GenericManaCost(amount); GenericManaCost cost = new GenericManaCost(amount);
if (!cost.pay(source, game, spell.getControllerId(), spell.getControllerId(), false)) { StringBuilder sb = new StringBuilder("Pay {").append(amount).append("}? (otherwise ").append(spell.getName()).append(" will be countered)");
if (player.chooseUse(Constants.Outcome.Benefit, sb.toString(), game)) {
StackObject stackObject = game.getStack().getStackObject(source.getFirstTarget()); cost.pay(source, game, source.getSourceId(), player.getId(), false);
if (stackObject != null && !game.replaceEvent(GameEvent.getEvent(GameEvent.EventType.COUNTER, source.getFirstTarget(), source.getSourceId(), stackObject.getControllerId()))) { }
game.informPlayers("Spell Rupture: cost wasn't payed - countering " + stackObject.getName()); if (!cost.isPaid()) {
if (stackObject instanceof Spell) { if (game.getStack().counter(source.getFirstTarget(), source.getSourceId(), game)) {
game.rememberLKI(source.getFirstTarget(), Constants.Zone.STACK, (Spell) stackObject); game.informPlayers(new StringBuilder(sourceObject.getName()).append(": cost wasn't payed - countering ").append(spell.getName()).toString());
} return true;
game.getStack().counter(source.getFirstTarget(), source.getSourceId(), game);
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.COUNTERED, source.getFirstTarget(), source.getSourceId(), stackObject.getControllerId()));
return true;
}
return false;
} }
} }
} }
} }
return false; return false;

View file

@ -84,7 +84,7 @@ public class CounterUnlessPaysEffect extends OneShotEffect<CounterUnlessPaysEffe
costToPay = new GenericManaCost(genericMana.calculate(game, source)); costToPay = new GenericManaCost(genericMana.calculate(game, source));
} }
costToPay.clearPaid(); costToPay.clearPaid();
if (!costToPay.pay(source, game, spell.getControllerId(), spell.getControllerId(), false)) { if (!costToPay.pay(source, game, spell.getSourceId(), spell.getControllerId(), false)) {
return game.getStack().counter(source.getFirstTarget(), source.getSourceId(), game); return game.getStack().counter(source.getFirstTarget(), source.getSourceId(), game);
} }
} }