From b068d10c44b54f61f758447502dc22e981d0d482 Mon Sep 17 00:00:00 2001 From: LevelX2 Date: Mon, 30 Dec 2019 21:35:10 +0100 Subject: [PATCH] * Nissa, Vastwood Seer - Fixed a bug of the Nissa, Sage Animist that the animated lands lost the creature type as soon as Nissa was cast again from command zone or from hand (fixes #5677). --- .../src/mage/cards/n/NissaSageAnimist.java | 97 ++++++++++++------- .../abilities/effects/ContinuousEffects.java | 8 +- 2 files changed, 70 insertions(+), 35 deletions(-) diff --git a/Mage.Sets/src/mage/cards/n/NissaSageAnimist.java b/Mage.Sets/src/mage/cards/n/NissaSageAnimist.java index 5940a4b0ac..b64572e12c 100644 --- a/Mage.Sets/src/mage/cards/n/NissaSageAnimist.java +++ b/Mage.Sets/src/mage/cards/n/NissaSageAnimist.java @@ -1,6 +1,6 @@ - package mage.cards.n; +import java.util.UUID; import mage.MageObject; import mage.abilities.Ability; import mage.abilities.LoyaltyAbility; @@ -9,6 +9,7 @@ import mage.abilities.effects.ContinuousEffectImpl; import mage.abilities.effects.OneShotEffect; import mage.abilities.effects.common.CreateTokenEffect; import mage.abilities.effects.common.UntapTargetEffect; +import mage.abilities.effects.common.continuous.BecomesCreatureTargetEffect; import mage.cards.Card; import mage.cards.CardImpl; import mage.cards.CardSetInfo; @@ -18,10 +19,10 @@ import mage.filter.StaticFilters; import mage.game.Game; import mage.game.permanent.Permanent; import mage.game.permanent.token.NissaSageAnimistToken; +import mage.game.permanent.token.custom.CreatureToken; import mage.players.Player; import mage.target.common.TargetLandPermanent; - -import java.util.UUID; +import mage.target.targetpointer.FixedTarget; /** * @@ -48,7 +49,7 @@ public final class NissaSageAnimist extends CardImpl { // -7: Untap up to six target lands. They become 6/6 Elemental creatures. They're still lands. Ability ability = new LoyaltyAbility(new UntapTargetEffect(), -7); ability.addTarget(new TargetLandPermanent(0, 6, StaticFilters.FILTER_LANDS, false)); - ability.addEffect(new NissaSageAnimistMinusSevenEffect()); + ability.addEffect(new NissaSageAnimistMinusAnimateEffect()); this.addAbility(ability); } @@ -98,52 +99,82 @@ class NissaSageAnimistPlusOneEffect extends OneShotEffect { } } -class NissaSageAnimistMinusSevenEffect extends ContinuousEffectImpl { +class NissaSageAnimistMinusAnimateEffect extends OneShotEffect { - NissaSageAnimistMinusSevenEffect() { - super(Duration.EndOfGame, Outcome.BecomeCreature); + public NissaSageAnimistMinusAnimateEffect() { + super(Outcome.BecomeCreature); this.staticText = "They become 6/6 Elemental creatures. They're still lands"; } - NissaSageAnimistMinusSevenEffect(final NissaSageAnimistMinusSevenEffect effect) { + public NissaSageAnimistMinusAnimateEffect(final NissaSageAnimistMinusAnimateEffect effect) { super(effect); } @Override - public NissaSageAnimistMinusSevenEffect copy() { - return new NissaSageAnimistMinusSevenEffect(this); + public NissaSageAnimistMinusAnimateEffect copy() { + return new NissaSageAnimistMinusAnimateEffect(this); } @Override - public boolean apply(Layer layer, SubLayer sublayer, Ability source, Game game) { + public boolean apply(Game game, Ability source) { for (UUID permanentId : this.getTargetPointer().getTargets(game, source)) { Permanent permanent = game.getPermanent(permanentId); if (permanent != null) { - switch (layer) { - case TypeChangingEffects_4: - permanent.addCardType(CardType.CREATURE); - if (!permanent.hasSubtype(SubType.ELEMENTAL, game)) { - permanent.getSubtype(game).add(SubType.ELEMENTAL); - } - break; - case PTChangingEffects_7: - if (sublayer == SubLayer.SetPT_7b) { - permanent.getToughness().setValue(6); - permanent.getPower().setValue(6); - } - } + ContinuousEffectImpl effect = new BecomesCreatureTargetEffect(new CreatureToken(6, 6, "", SubType.ELEMENTAL), false, true, Duration.Custom); + effect.setTargetPointer(new FixedTarget(permanent, game)); + game.addEffect(effect, source); } } return true; } - @Override - public boolean apply(Game game, Ability source) { - return false; - } - - @Override - public boolean hasLayer(Layer layer) { - return layer == Layer.TypeChangingEffects_4 || layer == Layer.PTChangingEffects_7; - } +// class NissaSageAnimistMinusSevenEffect extends ContinuousEffectImpl { +// +// NissaSageAnimistMinusSevenEffect() { +// super(Duration.EndOfGame, Outcome.BecomeCreature); +// this.staticText = "They become 6/6 Elemental creatures. They're still lands"; +// } +// +// NissaSageAnimistMinusSevenEffect(final NissaSageAnimistMinusSevenEffect effect) { +// super(effect); +// } +// +// @Override +// public NissaSageAnimistMinusSevenEffect copy() { +// return new NissaSageAnimistMinusSevenEffect(this); +// } +// +// @Override +// public boolean apply(Layer layer, SubLayer sublayer, Ability source, Game game) { +// for (UUID permanentId : this.getTargetPointer().getTargets(game, source)) { +// Permanent permanent = game.getPermanent(permanentId); +// if (permanent != null) { +// switch (layer) { +// case TypeChangingEffects_4: +// permanent.addCardType(CardType.CREATURE); +// if (!permanent.hasSubtype(SubType.ELEMENTAL, game)) { +// permanent.getSubtype(game).add(SubType.ELEMENTAL); +// } +// break; +// case PTChangingEffects_7: +// if (sublayer == SubLayer.SetPT_7b) { +// permanent.getToughness().setValue(6); +// permanent.getPower().setValue(6); +// } +// } +// } +// } +// return true; +// } +// +// @Override +// public boolean apply(Game game, Ability source) { +// return false; +// } +// +// @Override +// public boolean hasLayer(Layer layer) { +// return layer == Layer.TypeChangingEffects_4 || layer == Layer.PTChangingEffects_7; +// } +// } } diff --git a/Mage/src/main/java/mage/abilities/effects/ContinuousEffects.java b/Mage/src/main/java/mage/abilities/effects/ContinuousEffects.java index 296f931fdb..72a0d7ba87 100644 --- a/Mage/src/main/java/mage/abilities/effects/ContinuousEffects.java +++ b/Mage/src/main/java/mage/abilities/effects/ContinuousEffects.java @@ -229,7 +229,9 @@ public class ContinuousEffects implements Serializable { } private List filterLayeredEffects(List effects, Layer layer) { - return effects.stream().filter(effect -> effect.hasLayer(layer)).collect(Collectors.toList()); + return effects.stream() + .filter(effect -> effect.hasLayer(layer)) + .collect(Collectors.toList()); } public Map> getApplicableRequirementEffects(Permanent permanent, boolean playerRealted, Game game) { @@ -1076,11 +1078,13 @@ public class ContinuousEffects implements Serializable { private boolean isAbilityStillExists(final Game game, final Ability ability, ContinuousEffect effect) { final Card card = game.getPermanentOrLKIBattlefield(ability.getSourceId()); - if (!(effect instanceof BecomesFaceDownCreatureEffect)) { + if (!(effect instanceof BecomesFaceDownCreatureEffect) + && (effect != null && !effect.getDuration().equals(Duration.Custom))) { // Custom effects do not depend on the creating permanent if (card != null) { return card.getAbilities(game).contains(ability); } } + return true; }