mirror of
https://github.com/correl/mage.git
synced 2025-01-12 11:08:01 +00:00
* Changed the method for step end processing of spells with multiple steps (608.2) from game.applyEffects() to game.getState().processAction(game);
This commit is contained in:
parent
919fa282ce
commit
d8fb962030
48 changed files with 52 additions and 52 deletions
|
@ -74,7 +74,7 @@ class AladdinsLampEffect extends ReplacementEffectImpl {
|
||||||
cards.remove(target.getFirstTarget());
|
cards.remove(target.getFirstTarget());
|
||||||
}
|
}
|
||||||
controller.putCardsOnBottomOfLibrary(cards, game, source, false);
|
controller.putCardsOnBottomOfLibrary(cards, game, source, false);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
controller.drawCards(1, event.getSourceId(), game, event.getAppliedEffects());
|
controller.drawCards(1, event.getSourceId(), game, event.getAppliedEffects());
|
||||||
discard();
|
discard();
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -98,7 +98,7 @@ class AngrathMinotaurPirateThirdAbilityEffect extends OneShotEffect {
|
||||||
permanent.destroy(source.getSourceId(), game, false);
|
permanent.destroy(source.getSourceId(), game, false);
|
||||||
powerSum += permanent.getPower().getValue();
|
powerSum += permanent.getPower().getValue();
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
targetOpponent.damage(powerSum, source.getSourceId(), game);
|
targetOpponent.damage(powerSum, source.getSourceId(), game);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -74,7 +74,7 @@ class BlessedReincarnationEffect extends OneShotEffect {
|
||||||
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
||||||
if (permanent != null && controller != null) {
|
if (permanent != null && controller != null) {
|
||||||
controller.moveCards(permanent, Zone.EXILED, source, game);
|
controller.moveCards(permanent, Zone.EXILED, source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
|
|
||||||
Player permanentController = game.getPlayer(permanent.getControllerId());
|
Player permanentController = game.getPlayer(permanent.getControllerId());
|
||||||
if (permanentController != null) {
|
if (permanentController != null) {
|
||||||
|
|
|
@ -86,7 +86,7 @@ class BoundEffect extends OneShotEffect {
|
||||||
Permanent toSacrifice = game.getPermanent(target.getFirstTarget());
|
Permanent toSacrifice = game.getPermanent(target.getFirstTarget());
|
||||||
if (toSacrifice != null) {
|
if (toSacrifice != null) {
|
||||||
toSacrifice.sacrifice(source.getSourceId(), game);
|
toSacrifice.sacrifice(source.getSourceId(), game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
int colors = toSacrifice.getColor(game).getColorCount();
|
int colors = toSacrifice.getColor(game).getColorCount();
|
||||||
if (colors > 0) {
|
if (colors > 0) {
|
||||||
TargetCardInYourGraveyard targetCard = new TargetCardInYourGraveyard(0, colors,
|
TargetCardInYourGraveyard targetCard = new TargetCardInYourGraveyard(0, colors,
|
||||||
|
|
|
@ -77,7 +77,7 @@ class BuildersBaneEffect extends OneShotEffect {
|
||||||
Permanent permanent = game.getPermanent(targetID);
|
Permanent permanent = game.getPermanent(targetID);
|
||||||
if (permanent != null) {
|
if (permanent != null) {
|
||||||
if (permanent.destroy(source.getSourceId(), game, false)) {
|
if (permanent.destroy(source.getSourceId(), game, false)) {
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (permanent.getZoneChangeCounter(game) + 1 == game.getState().getZoneChangeCounter(permanent.getId())
|
if (permanent.getZoneChangeCounter(game) + 1 == game.getState().getZoneChangeCounter(permanent.getId())
|
||||||
&& game.getState().getZone(permanent.getId()) != Zone.GRAVEYARD) {
|
&& game.getState().getZone(permanent.getId()) != Zone.GRAVEYARD) {
|
||||||
// A replacement effect has moved the card to another zone as grvayard
|
// A replacement effect has moved the card to another zone as grvayard
|
||||||
|
|
|
@ -59,7 +59,7 @@ class CinderCloudEffect extends OneShotEffect {
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
||||||
if (permanent != null && permanent.destroy(source.getSourceId(), game, false) && permanent.getColor(game).equals(ObjectColor.WHITE)) {
|
if (permanent != null && permanent.destroy(source.getSourceId(), game, false) && permanent.getColor(game).equals(ObjectColor.WHITE)) {
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (permanent.getZoneChangeCounter(game) + 1 == game.getState().getZoneChangeCounter(permanent.getId())
|
if (permanent.getZoneChangeCounter(game) + 1 == game.getState().getZoneChangeCounter(permanent.getId())
|
||||||
&& game.getState().getZone(permanent.getId()) != Zone.GRAVEYARD) {
|
&& game.getState().getZone(permanent.getId()) != Zone.GRAVEYARD) {
|
||||||
// A replacement effect has moved the card to another zone as grvayard
|
// A replacement effect has moved the card to another zone as grvayard
|
||||||
|
|
|
@ -63,7 +63,7 @@ class CompellingDeterrenceEffect extends OneShotEffect {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null && player != null) {
|
if (controller != null && player != null) {
|
||||||
player.moveCards(target, Zone.HAND, source, game);
|
player.moveCards(target, Zone.HAND, source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
FilterPermanent zombieFilter = new FilterPermanent();
|
FilterPermanent zombieFilter = new FilterPermanent();
|
||||||
zombieFilter.add(SubType.ZOMBIE.getPredicate());
|
zombieFilter.add(SubType.ZOMBIE.getPredicate());
|
||||||
if (game.getState().getBattlefield().countAll(zombieFilter, controller.getId(), game) > 0) {
|
if (game.getState().getBattlefield().countAll(zombieFilter, controller.getId(), game) > 0) {
|
||||||
|
|
|
@ -88,7 +88,7 @@ class DeclarationInStoneEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
controller.moveCards(cardsToExile, Zone.EXILED, source, game);
|
controller.moveCards(cardsToExile, Zone.EXILED, source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (nonTokenCount > 0) {
|
if (nonTokenCount > 0) {
|
||||||
new ClueArtifactToken().putOntoBattlefield(nonTokenCount, game, source.getSourceId(), targetPermanent.getControllerId(), false, false);
|
new ClueArtifactToken().putOntoBattlefield(nonTokenCount, game, source.getSourceId(), targetPermanent.getControllerId(), false, false);
|
||||||
}
|
}
|
||||||
|
|
|
@ -73,7 +73,7 @@ class DevourFleshSacrificeEffect extends OneShotEffect {
|
||||||
if (permanent != null) {
|
if (permanent != null) {
|
||||||
int gainLife = permanent.getToughness().getValue();
|
int gainLife = permanent.getToughness().getValue();
|
||||||
permanent.sacrifice(source.getSourceId(), game);
|
permanent.sacrifice(source.getSourceId(), game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
player.gainLife(gainLife, game, source);
|
player.gainLife(gainLife, game, source);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -78,7 +78,7 @@ class DomrisAmbushEffect extends OneShotEffect {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
permanent.addCounters(CounterType.P1P1.createInstance(), source, game);
|
permanent.addCounters(CounterType.P1P1.createInstance(), source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
return new DamageWithPowerFromOneToAnotherTargetEffect().apply(game, source);
|
return new DamageWithPowerFromOneToAnotherTargetEffect().apply(game, source);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,7 +88,7 @@ class EmpoweredAutogeneratorManaEffect extends ManaEffect {
|
||||||
if (game == null) {
|
if (game == null) {
|
||||||
return mana;
|
return mana;
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
Permanent sourcePermanent = game.getState().getPermanent(source.getSourceId());
|
Permanent sourcePermanent = game.getState().getPermanent(source.getSourceId());
|
||||||
if (sourcePermanent == null) {
|
if (sourcePermanent == null) {
|
||||||
return mana;
|
return mana;
|
||||||
|
|
|
@ -61,7 +61,7 @@ class FiligreeFractureEffect extends OneShotEffect {
|
||||||
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
||||||
if (player != null && permanent != null) {
|
if (player != null && permanent != null) {
|
||||||
permanent.destroy(source.getSourceId(), game, true);
|
permanent.destroy(source.getSourceId(), game, true);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (permanent.getColor(game).isBlack() || permanent.getColor(game).isBlue()) {
|
if (permanent.getColor(game).isBlack() || permanent.getColor(game).isBlue()) {
|
||||||
player.drawCards(1, source.getSourceId(), game);
|
player.drawCards(1, source.getSourceId(), game);
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ class FracturingGustDestroyEffect extends OneShotEffect {
|
||||||
++destroyedPermanents;
|
++destroyedPermanents;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects(); // needed in case a destroyed permanent did prevent life gain
|
game.getState().processAction(game); // needed in case a destroyed permanent did prevent life gain
|
||||||
if (destroyedPermanents > 0) {
|
if (destroyedPermanents > 0) {
|
||||||
controller.gainLife(2 * destroyedPermanents, game, source);
|
controller.gainLife(2 * destroyedPermanents, game, source);
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,7 +76,7 @@ class FromTheAshesEffect extends OneShotEffect {
|
||||||
playerAmount.put(playerId, amount);
|
playerAmount.put(playerId, amount);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
for (Map.Entry<UUID, Integer> entry : playerAmount.entrySet()) {
|
for (Map.Entry<UUID, Integer> entry : playerAmount.entrySet()) {
|
||||||
Player player = game.getPlayer(entry.getKey());
|
Player player = game.getPlayer(entry.getKey());
|
||||||
if (player != null && player.chooseUse(outcome, "Search your library for up to " + entry.getValue() + " basic land card(s) to put it onto the battlefield?", source, game)) {
|
if (player != null && player.chooseUse(outcome, "Search your library for up to " + entry.getValue() + " basic land card(s) to put it onto the battlefield?", source, game)) {
|
||||||
|
@ -90,7 +90,7 @@ class FromTheAshesEffect extends OneShotEffect {
|
||||||
entry.setValue(0); // no search no shuffling
|
entry.setValue(0); // no search no shuffling
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
for (Map.Entry<UUID, Integer> entry : playerAmount.entrySet()) {
|
for (Map.Entry<UUID, Integer> entry : playerAmount.entrySet()) {
|
||||||
Player player = game.getPlayer(entry.getKey());
|
Player player = game.getPlayer(entry.getKey());
|
||||||
if (player != null && entry.getValue() > 0) {
|
if (player != null && entry.getValue() > 0) {
|
||||||
|
|
|
@ -62,7 +62,7 @@ class FumigateEffect extends OneShotEffect {
|
||||||
destroyedCreature++;
|
destroyedCreature++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (destroyedCreature > 0) {
|
if (destroyedCreature > 0) {
|
||||||
controller.gainLife(destroyedCreature, game, source);
|
controller.gainLife(destroyedCreature, game, source);
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,7 +81,7 @@ class GhostlyFlickerEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
controller.moveCards(toExile, Zone.EXILED, source, game);
|
controller.moveCards(toExile, Zone.EXILED, source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
Set<Card> toBattlefield = new HashSet<>();
|
Set<Card> toBattlefield = new HashSet<>();
|
||||||
for (Card card : toExile) {
|
for (Card card : toExile) {
|
||||||
Zone currentZone = game.getState().getZone(card.getId());
|
Zone currentZone = game.getState().getZone(card.getId());
|
||||||
|
|
|
@ -71,7 +71,7 @@ class GideonsDefeatEffect extends OneShotEffect {
|
||||||
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
||||||
if (controller != null && permanent != null) {
|
if (controller != null && permanent != null) {
|
||||||
controller.moveCards(permanent, Zone.EXILED, source, game);
|
controller.moveCards(permanent, Zone.EXILED, source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (permanent.isPlaneswalker() && permanent.hasSubtype(SubType.GIDEON, game)) {
|
if (permanent.isPlaneswalker() && permanent.hasSubtype(SubType.GIDEON, game)) {
|
||||||
controller.gainLife(5, game, source);
|
controller.gainLife(5, game, source);
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,7 +97,7 @@ class HeraldOfLeshracCumulativeCost extends CostImpl {
|
||||||
ContinuousEffect effect = new GainControlTargetEffect(Duration.EndOfGame);
|
ContinuousEffect effect = new GainControlTargetEffect(Duration.EndOfGame);
|
||||||
effect.setTargetPointer(new FixedTarget(target.getFirstTarget()));
|
effect.setTargetPointer(new FixedTarget(target.getFirstTarget()));
|
||||||
game.addEffect(effect, ability);
|
game.addEffect(effect, ability);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
paid = true;
|
paid = true;
|
||||||
}
|
}
|
||||||
return paid;
|
return paid;
|
||||||
|
|
|
@ -69,7 +69,7 @@ class HourOfGloryEffect extends OneShotEffect {
|
||||||
if (targetCreature != null) {
|
if (targetCreature != null) {
|
||||||
controller.moveCards(targetCreature, Zone.EXILED, source, game);
|
controller.moveCards(targetCreature, Zone.EXILED, source, game);
|
||||||
if (targetCreature.hasSubtype(SubType.GOD, game)) {
|
if (targetCreature.hasSubtype(SubType.GOD, game)) {
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
Player targetController = game.getPlayer(targetCreature.getControllerId());
|
Player targetController = game.getPlayer(targetCreature.getControllerId());
|
||||||
if (targetController != null) {
|
if (targetController != null) {
|
||||||
targetController.revealCards(sourceObject.getIdName(), targetController.getHand(), game);
|
targetController.revealCards(sourceObject.getIdName(), targetController.getHand(), game);
|
||||||
|
|
|
@ -76,7 +76,7 @@ class InducedAmnesiaExileEffect extends OneShotEffect {
|
||||||
card.setFaceDown(true, game);
|
card.setFaceDown(true, game);
|
||||||
}
|
}
|
||||||
game.informPlayers(sourcePermanent.getLogName() + ": " + targetPlayer.getLogName() + " exiles their hand face down (" + numberOfCards + "card" + (numberOfCards > 1 ? "s" : "") + ')');
|
game.informPlayers(sourcePermanent.getLogName() + ": " + targetPlayer.getLogName() + " exiles their hand face down (" + numberOfCards + "card" + (numberOfCards > 1 ? "s" : "") + ')');
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
targetPlayer.drawCards(numberOfCards, source.getSourceId(), game);
|
targetPlayer.drawCards(numberOfCards, source.getSourceId(), game);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -69,7 +69,7 @@ class InfernalJudgmentEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
int creaturePower = permanent.getPower().getValue();
|
int creaturePower = permanent.getPower().getValue();
|
||||||
permanent.moveToExile(null, null, source.getSourceId(), game);
|
permanent.moveToExile(null, null, source.getSourceId(), game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
player.gainLife(creaturePower, game, source);
|
player.gainLife(creaturePower, game, source);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,7 +76,7 @@ class JoustEffect extends OneShotEffect {
|
||||||
if (creature2 == null) {
|
if (creature2 == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
return creature1.fight(creature2, source, game);
|
return creature1.fight(creature2, source, game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,7 +78,7 @@ class KaerveksPurgeEffect extends OneShotEffect {
|
||||||
// Destroy target creature with converted mana cost X.
|
// Destroy target creature with converted mana cost X.
|
||||||
Permanent targetCreature = game.getPermanent(getTargetPointer().getFirst(game, source));
|
Permanent targetCreature = game.getPermanent(getTargetPointer().getFirst(game, source));
|
||||||
if (targetCreature != null && targetCreature.destroy(source.getSourceId(), game, false)) {
|
if (targetCreature != null && targetCreature.destroy(source.getSourceId(), game, false)) {
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (targetCreature.getZoneChangeCounter(game) + 1 == game.getState().getZoneChangeCounter(targetCreature.getId())
|
if (targetCreature.getZoneChangeCounter(game) + 1 == game.getState().getZoneChangeCounter(targetCreature.getId())
|
||||||
&& game.getState().getZone(targetCreature.getId()) != Zone.GRAVEYARD) {
|
&& game.getState().getZone(targetCreature.getId()) != Zone.GRAVEYARD) {
|
||||||
// A replacement effect has moved the card to another zone as graveyard
|
// A replacement effect has moved the card to another zone as graveyard
|
||||||
|
|
|
@ -95,7 +95,7 @@ class KraulHarpoonerEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
int xValue = player.getGraveyard().count(StaticFilters.FILTER_CARD_CREATURE, game);
|
int xValue = player.getGraveyard().count(StaticFilters.FILTER_CARD_CREATURE, game);
|
||||||
game.addEffect(new BoostSourceEffect(xValue, 0, Duration.EndOfTurn), source);
|
game.addEffect(new BoostSourceEffect(xValue, 0, Duration.EndOfTurn), source);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
Permanent creature = game.getPermanent(source.getFirstTarget());
|
Permanent creature = game.getPermanent(source.getFirstTarget());
|
||||||
if (creature == null || !player.chooseUse(outcome, "Have " + sourcePerm.getLogName() + " fight " + creature.getLogName() + "?", source, game)) {
|
if (creature == null || !player.chooseUse(outcome, "Have " + sourcePerm.getLogName() + " fight " + creature.getLogName() + "?", source, game)) {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -70,7 +70,7 @@ class KrenkoTinStreetKingpinEffect extends OneShotEffect {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
new AddCountersSourceEffect(CounterType.P1P1.createInstance()).apply(game, source);
|
new AddCountersSourceEffect(CounterType.P1P1.createInstance()).apply(game, source);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
int xValue = permanent.getPower().getValue();
|
int xValue = permanent.getPower().getValue();
|
||||||
return new CreateTokenEffect(new GoblinToken("WAR"), xValue).apply(game, source);
|
return new CreateTokenEffect(new GoblinToken("WAR"), xValue).apply(game, source);
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ class LilianasDefeatEffect extends OneShotEffect {
|
||||||
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
Permanent permanent = game.getPermanent(getTargetPointer().getFirst(game, source));
|
||||||
if (player != null && permanent != null) {
|
if (player != null && permanent != null) {
|
||||||
permanent.destroy(source.getSourceId(), game, true);
|
permanent.destroy(source.getSourceId(), game, true);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (permanent.isPlaneswalker() && permanent.hasSubtype(SubType.LILIANA, game)) {
|
if (permanent.isPlaneswalker() && permanent.hasSubtype(SubType.LILIANA, game)) {
|
||||||
Player permanentController = game.getPlayer(permanent.getControllerId());
|
Player permanentController = game.getPlayer(permanent.getControllerId());
|
||||||
if (permanentController != null) {
|
if (permanentController != null) {
|
||||||
|
|
|
@ -76,13 +76,13 @@ class LivingDeathEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
|
|
||||||
// Sacrifice all creatures
|
// Sacrifice all creatures
|
||||||
for (Permanent permanent : game.getBattlefield().getActivePermanents(StaticFilters.FILTER_PERMANENT_CREATURE, source.getControllerId(), game)) {
|
for (Permanent permanent : game.getBattlefield().getActivePermanents(StaticFilters.FILTER_PERMANENT_CREATURE, source.getControllerId(), game)) {
|
||||||
permanent.sacrifice(source.getSourceId(), game);
|
permanent.sacrifice(source.getSourceId(), game);
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
|
|
||||||
// Exiled cards are put onto the battlefield at the same time under their owner's control
|
// Exiled cards are put onto the battlefield at the same time under their owner's control
|
||||||
Set<Card> cardsToReturnFromExile = new HashSet<>();
|
Set<Card> cardsToReturnFromExile = new HashSet<>();
|
||||||
|
|
|
@ -75,7 +75,7 @@ class MayaelsAriaEffect extends OneShotEffect {
|
||||||
creature.addCounters(CounterType.P1P1.createInstance(), source, game);
|
creature.addCounters(CounterType.P1P1.createInstance(), source, game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects(); // needed because otehrwise the +1/+1 counters wouldn't be taken into account
|
game.getState().processAction(game); // needed because otehrwise the +1/+1 counters wouldn't be taken into account
|
||||||
|
|
||||||
// Then you gain 10 life if you control a creature with power 10 or greater.
|
// Then you gain 10 life if you control a creature with power 10 or greater.
|
||||||
filter = new FilterCreaturePermanent();
|
filter = new FilterCreaturePermanent();
|
||||||
|
|
|
@ -73,7 +73,7 @@ class MoltenPsycheEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
game.applyEffects(); // so effects from creatures that were on the battlefield won't trigger from draw action
|
game.getState().processAction(game); // so effects from creatures that were on the battlefield won't trigger from draw action
|
||||||
|
|
||||||
for (UUID playerId : cardsToDraw.keySet()) {
|
for (UUID playerId : cardsToDraw.keySet()) {
|
||||||
Player player = game.getPlayer(playerId);
|
Player player = game.getPlayer(playerId);
|
||||||
|
|
|
@ -63,7 +63,7 @@ class OblationEffect extends OneShotEffect {
|
||||||
player.moveCardToLibraryWithInfo(permanent, source.getSourceId(), game, Zone.BATTLEFIELD, true, true);
|
player.moveCardToLibraryWithInfo(permanent, source.getSourceId(), game, Zone.BATTLEFIELD, true, true);
|
||||||
player.shuffleLibrary(source, game);
|
player.shuffleLibrary(source, game);
|
||||||
|
|
||||||
game.applyEffects(); // so effects from creatures that were on the battlefield won't trigger from draw
|
game.getState().processAction(game); // so effects from creatures that were on the battlefield won't trigger from draw
|
||||||
|
|
||||||
player.drawCards(2, source.getSourceId(), game);
|
player.drawCards(2, source.getSourceId(), game);
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -83,7 +83,7 @@ class OutmuscleEffect extends OneShotEffect {
|
||||||
if (creature == null) {
|
if (creature == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
return creature.fight(permanent, source, game);
|
return creature.fight(permanent, source, game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,7 +76,7 @@ class ProfaneProcessionEffect extends OneShotEffect {
|
||||||
MageObject sourceObject = source.getSourceObject(game);
|
MageObject sourceObject = source.getSourceObject(game);
|
||||||
if (controller != null && exileId != null && sourceObject != null) {
|
if (controller != null && exileId != null && sourceObject != null) {
|
||||||
new ExileTargetEffect(exileId, sourceObject.getIdName()).setTargetPointer(targetPointer).apply(game, source);
|
new ExileTargetEffect(exileId, sourceObject.getIdName()).setTargetPointer(targetPointer).apply(game, source);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
ExileZone exileZone = game.getExile().getExileZone(exileId);
|
ExileZone exileZone = game.getExile().getExileZone(exileId);
|
||||||
if (exileZone != null && exileZone.size() > 2) {
|
if (exileZone != null && exileZone.size() > 2) {
|
||||||
new TransformSourceEffect(true).apply(game, source);
|
new TransformSourceEffect(true).apply(game, source);
|
||||||
|
|
|
@ -71,7 +71,7 @@ public final class PureReflection extends CardImpl {
|
||||||
game.getBattlefield().getActivePermanents(filter, source.getControllerId(), source.getSourceId(), game).forEach((permanent) -> {
|
game.getBattlefield().getActivePermanents(filter, source.getControllerId(), source.getSourceId(), game).forEach((permanent) -> {
|
||||||
permanent.destroy(source.getSourceId(), game,false);
|
permanent.destroy(source.getSourceId(), game,false);
|
||||||
});
|
});
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
|
|
||||||
// Then that player creates an X/X white Reflection creature token, where X is the converted mana cost of that spell.
|
// Then that player creates an X/X white Reflection creature token, where X is the converted mana cost of that spell.
|
||||||
ReflectionPureToken token = new ReflectionPureToken(spell.getConvertedManaCost());
|
ReflectionPureToken token = new ReflectionPureToken(spell.getConvertedManaCost());
|
||||||
|
|
|
@ -70,7 +70,7 @@ class SavageSwipeEffect extends OneShotEffect {
|
||||||
ContinuousEffect effect = new BoostTargetEffect(2, 2, Duration.EndOfTurn);
|
ContinuousEffect effect = new BoostTargetEffect(2, 2, Duration.EndOfTurn);
|
||||||
effect.setTargetPointer(new FixedTarget(permanent, game));
|
effect.setTargetPointer(new FixedTarget(permanent, game));
|
||||||
game.addEffect(effect, source);
|
game.addEffect(effect, source);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
}
|
}
|
||||||
return new FightTargetsEffect().apply(game, source);
|
return new FightTargetsEffect().apply(game, source);
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,7 +101,7 @@ class SorinLordOfInnistradEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null) {
|
if (controller != null) {
|
||||||
return controller.moveCards(toBattlefield, Zone.BATTLEFIELD, source, game);
|
return controller.moveCards(toBattlefield, Zone.BATTLEFIELD, source, game);
|
||||||
|
|
|
@ -133,7 +133,7 @@ class TahngarthFirstMateEffect extends OneShotEffect {
|
||||||
ContinuousEffect effect = new GainControlTargetEffect(Duration.EndOfCombat, player.getId());
|
ContinuousEffect effect = new GainControlTargetEffect(Duration.EndOfCombat, player.getId());
|
||||||
effect.setTargetPointer(new FixedTarget(permanent, game));
|
effect.setTargetPointer(new FixedTarget(permanent, game));
|
||||||
game.addEffect(effect, source);
|
game.addEffect(effect, source);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
return game.getCombat().addAttackerToCombat(permanent.getId(), target.getFirstTarget(), game);
|
return game.getCombat().addAttackerToCombat(permanent.getId(), target.getFirstTarget(), game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -77,7 +77,7 @@ class TeleminPerformanceEffect extends OneShotEffect {
|
||||||
opponent.revealCards(source, reveal, game);
|
opponent.revealCards(source, reveal, game);
|
||||||
opponent.moveCards(nonCreatures, Zone.GRAVEYARD, source, game);
|
opponent.moveCards(nonCreatures, Zone.GRAVEYARD, source, game);
|
||||||
if (creature != null) {
|
if (creature != null) {
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
controller.moveCards(creature, Zone.BATTLEFIELD, source, game);
|
controller.moveCards(creature, Zone.BATTLEFIELD, source, game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,7 +88,7 @@ class TerastodonEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
ElephantToken elephantToken = new ElephantToken();
|
ElephantToken elephantToken = new ElephantToken();
|
||||||
for (Entry<UUID, Integer> entry : destroyedPermanents.entrySet()) {
|
for (Entry<UUID, Integer> entry : destroyedPermanents.entrySet()) {
|
||||||
elephantToken.putOntoBattlefield(entry.getValue(), game, source.getSourceId(), entry.getKey());
|
elephantToken.putOntoBattlefield(entry.getValue(), game, source.getSourceId(), entry.getKey());
|
||||||
|
|
|
@ -90,7 +90,7 @@ class TheGreatAuroraEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
game.applyEffects(); // so effects from creatures that were on the battlefield won't trigger from draw or put into play
|
game.getState().processAction(game); // so effects from creatures that were on the battlefield won't trigger from draw or put into play
|
||||||
|
|
||||||
// Draw cards
|
// Draw cards
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
||||||
|
|
|
@ -90,7 +90,7 @@ class ThoughtDissectorEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
targetOpponent.revealCards(source, reveal, game);
|
targetOpponent.revealCards(source, reveal, game);
|
||||||
if (artifact != null) {
|
if (artifact != null) {
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
controller.moveCards(artifact, Zone.BATTLEFIELD, source, game);
|
controller.moveCards(artifact, Zone.BATTLEFIELD, source, game);
|
||||||
Permanent sourcePermanent = source.getSourcePermanentIfItStillExists(game);
|
Permanent sourcePermanent = source.getSourcePermanentIfItStillExists(game);
|
||||||
if (sourcePermanent != null) {
|
if (sourcePermanent != null) {
|
||||||
|
|
|
@ -86,7 +86,7 @@ class TwilightProphetEffect extends OneShotEffect {
|
||||||
if (card != null) {
|
if (card != null) {
|
||||||
controller.revealCards(sourceObject.getIdName(), new CardsImpl(card), game);
|
controller.revealCards(sourceObject.getIdName(), new CardsImpl(card), game);
|
||||||
controller.moveCards(card, Zone.HAND, source, game);
|
controller.moveCards(card, Zone.HAND, source, game);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
int amount = card.getConvertedManaCost();
|
int amount = card.getConvertedManaCost();
|
||||||
if (amount > 0) {
|
if (amount > 0) {
|
||||||
new LoseLifeOpponentsEffect(amount).apply(game, source);
|
new LoseLifeOpponentsEffect(amount).apply(game, source);
|
||||||
|
|
|
@ -120,7 +120,7 @@ class VesuvanShapeshifterEffect extends OneShotEffect {
|
||||||
if (copyFromCreature != null) {
|
if (copyFromCreature != null) {
|
||||||
game.copyPermanent(Duration.Custom, copyFromCreature, copyToCreature.getId(), source, new VesuvanShapeShifterFaceUpApplier());
|
game.copyPermanent(Duration.Custom, copyFromCreature, copyToCreature.getId(), source, new VesuvanShapeShifterFaceUpApplier());
|
||||||
source.getTargets().clear();
|
source.getTargets().clear();
|
||||||
game.applyEffects(); // needed to get effects ready if copy happens in replacment and the copied abilities react of the same event (e.g. turn face up)
|
game.getState().processAction(game); // needed to get effects ready if copy happens in replacment and the copied abilities react of the same event (e.g. turn face up)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,7 +64,7 @@ class VictimizeEffect extends OneShotEffect {
|
||||||
if (controller != null) {
|
if (controller != null) {
|
||||||
SacrificeTargetCost cost = new SacrificeTargetCost(new TargetControlledCreaturePermanent(FILTER_CONTROLLED_CREATURE_SHORT_TEXT));
|
SacrificeTargetCost cost = new SacrificeTargetCost(new TargetControlledCreaturePermanent(FILTER_CONTROLLED_CREATURE_SHORT_TEXT));
|
||||||
if (cost.pay(source, game, source.getSourceId(), source.getControllerId(), false, null)) {
|
if (cost.pay(source, game, source.getSourceId(), source.getControllerId(), false, null)) {
|
||||||
game.applyEffects(); // To end effects of the sacrificed creature
|
game.getState().processAction(game); // To end effects of the sacrificed creature
|
||||||
controller.moveCards(new CardsImpl(getTargetPointer().getTargets(game, source)).getCards(game),
|
controller.moveCards(new CardsImpl(getTargetPointer().getTargets(game, source)).getCards(game),
|
||||||
Zone.BATTLEFIELD, source, game, true, false, false, null);
|
Zone.BATTLEFIELD, source, game, true, false, false, null);
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,7 +97,7 @@ class WarpWorldEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
game.applyEffects(); // so effects from creatures that were on the battlefield won't trigger from draw or later put into play
|
game.getState().processAction(game); // so effects from creatures that were on the battlefield won't trigger from draw or later put into play
|
||||||
|
|
||||||
Map<UUID, CardsImpl> cardsRevealed = new HashMap<>();
|
Map<UUID, CardsImpl> cardsRevealed = new HashMap<>();
|
||||||
|
|
||||||
|
@ -111,7 +111,7 @@ class WarpWorldEffect extends OneShotEffect {
|
||||||
cardsRevealed.put(player.getId(), cards);
|
cardsRevealed.put(player.getId(), cards);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
// put artifacts, creaturs and lands onto the battlefield
|
// put artifacts, creaturs and lands onto the battlefield
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
||||||
Player player = game.getPlayer(playerId);
|
Player player = game.getPlayer(playerId);
|
||||||
|
@ -129,7 +129,7 @@ class WarpWorldEffect extends OneShotEffect {
|
||||||
player.moveCards(toBattlefield, Zone.BATTLEFIELD, source, game);
|
player.moveCards(toBattlefield, Zone.BATTLEFIELD, source, game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
// put enchantments onto the battlefield
|
// put enchantments onto the battlefield
|
||||||
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) {
|
||||||
Player player = game.getPlayer(playerId);
|
Player player = game.getPlayer(playerId);
|
||||||
|
|
|
@ -92,7 +92,7 @@ class WaveOfVitriolEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
Cards toBattlefield = new CardsImpl();
|
Cards toBattlefield = new CardsImpl();
|
||||||
Set<Player> playersToShuffle = new LinkedHashSet<>();
|
Set<Player> playersToShuffle = new LinkedHashSet<>();
|
||||||
for (Map.Entry<Player, Integer> entry : sacrificedLands.entrySet()) {
|
for (Map.Entry<Player, Integer> entry : sacrificedLands.entrySet()) {
|
||||||
|
|
|
@ -61,7 +61,7 @@ class WidespreadBrutalityEffect extends OneShotEffect {
|
||||||
if (amassedArmy == null) {
|
if (amassedArmy == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
int power = amassedArmy.getPower().getValue();
|
int power = amassedArmy.getPower().getValue();
|
||||||
for (Permanent permanent : game.getBattlefield().getActivePermanents(source.getControllerId(), game)) {
|
for (Permanent permanent : game.getBattlefield().getActivePermanents(source.getControllerId(), game)) {
|
||||||
if (permanent != null && permanent.isCreature() && !permanent.hasSubtype(SubType.ARMY, game)) {
|
if (permanent != null && permanent.isCreature() && !permanent.hasSubtype(SubType.ARMY, game)) {
|
||||||
|
|
|
@ -93,7 +93,7 @@ class YorvoLordOfGarenbrigEffect extends OneShotEffect {
|
||||||
if (permanent == null) {
|
if (permanent == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
if (permanent.getPower().getValue() > sourcePerm.getPower().getValue()) {
|
if (permanent.getPower().getValue() > sourcePerm.getPower().getValue()) {
|
||||||
sourcePerm.addCounters(CounterType.P1P1.createInstance(), source, game);
|
sourcePerm.addCounters(CounterType.P1P1.createInstance(), source, game);
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,7 +66,7 @@ class ZombieApocalypseEffect extends OneShotEffect {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null) {
|
if (controller != null) {
|
||||||
controller.moveCards(controller.getGraveyard().getCards(filterZombie, game), Zone.BATTLEFIELD, source, game, true, false, false, null);
|
controller.moveCards(controller.getGraveyard().getCards(filterZombie, game), Zone.BATTLEFIELD, source, game, true, false, false, null);
|
||||||
game.applyEffects();
|
game.getState().processAction(game);
|
||||||
for (Permanent permanent : game.getBattlefield().getActivePermanents(
|
for (Permanent permanent : game.getBattlefield().getActivePermanents(
|
||||||
new FilterPermanent(SubType.HUMAN, "Humans"), source.getControllerId(), game)) {
|
new FilterPermanent(SubType.HUMAN, "Humans"), source.getControllerId(), game)) {
|
||||||
permanent.destroy(source.getSourceId(), game, false);
|
permanent.destroy(source.getSourceId(), game, false);
|
||||||
|
|
Loading…
Reference in a new issue