mirror of
https://github.com/correl/mage.git
synced 2025-01-12 11:08:01 +00:00
* Necrotic Plague - Fixed that the second ability was a ability of the enchanted creature instead of the enchantment. Fixed that the new target creature was choosen during resolution instead of already set on stack.
This commit is contained in:
parent
532c51afd1
commit
9c9171a5ee
2 changed files with 91 additions and 128 deletions
|
@ -29,35 +29,32 @@
|
||||||
package mage.sets.magic2011;
|
package mage.sets.magic2011;
|
||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import mage.constants.CardType;
|
|
||||||
import mage.constants.Duration;
|
|
||||||
import mage.constants.Layer;
|
|
||||||
import mage.constants.Outcome;
|
|
||||||
import mage.constants.Rarity;
|
|
||||||
import mage.constants.SubLayer;
|
|
||||||
import mage.constants.TargetController;
|
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.DiesTriggeredAbility;
|
import mage.abilities.common.BeginningOfUpkeepTriggeredAbility;
|
||||||
import mage.abilities.common.OnEventTriggeredAbility;
|
import mage.abilities.common.DiesAttachedTriggeredAbility;
|
||||||
import mage.abilities.common.SimpleStaticAbility;
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
import mage.abilities.effects.ContinuousEffectImpl;
|
|
||||||
import mage.abilities.effects.Effect;
|
import mage.abilities.effects.Effect;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.abilities.effects.common.AttachEffect;
|
import mage.abilities.effects.common.AttachEffect;
|
||||||
import mage.abilities.effects.common.SacrificeSourceEffect;
|
import mage.abilities.effects.common.SacrificeSourceEffect;
|
||||||
|
import mage.abilities.effects.common.continious.GainAbilityAttachedEffect;
|
||||||
import mage.abilities.keyword.EnchantAbility;
|
import mage.abilities.keyword.EnchantAbility;
|
||||||
import mage.cards.Card;
|
import mage.cards.Card;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
|
import mage.constants.AttachmentType;
|
||||||
|
import mage.constants.CardType;
|
||||||
|
import mage.constants.Duration;
|
||||||
|
import mage.constants.Outcome;
|
||||||
|
import mage.constants.Rarity;
|
||||||
|
import mage.constants.TargetController;
|
||||||
|
import mage.constants.Zone;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
import mage.filter.predicate.permanent.ControllerPredicate;
|
import mage.filter.predicate.permanent.ControllerPredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.events.GameEvent.EventType;
|
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
import mage.target.TargetPermanent;
|
import mage.target.TargetPermanent;
|
||||||
import mage.target.common.TargetCreaturePermanent;
|
import mage.target.common.TargetCreaturePermanent;
|
||||||
import mage.target.targetpointer.FixedTarget;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -65,63 +62,94 @@ import mage.target.targetpointer.FixedTarget;
|
||||||
*/
|
*/
|
||||||
public class NecroticPlague extends CardImpl<NecroticPlague> {
|
public class NecroticPlague extends CardImpl<NecroticPlague> {
|
||||||
|
|
||||||
|
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature an opponent controls");
|
||||||
|
|
||||||
|
static {
|
||||||
|
filter.add(new ControllerPredicate(TargetController.OPPONENT));
|
||||||
|
}
|
||||||
|
|
||||||
public NecroticPlague(UUID ownerId) {
|
public NecroticPlague(UUID ownerId) {
|
||||||
super(ownerId, 107, "Necrotic Plague", Rarity.RARE, new CardType[]{CardType.ENCHANTMENT}, "{2}{B}{B}");
|
super(ownerId, 107, "Necrotic Plague", Rarity.RARE, new CardType[]{CardType.ENCHANTMENT}, "{2}{B}{B}");
|
||||||
this.expansionSetCode = "M11";
|
this.expansionSetCode = "M11";
|
||||||
this.color.setBlack(true);
|
this.color.setBlack(true);
|
||||||
this.subtype.add("Aura");
|
this.subtype.add("Aura");
|
||||||
|
|
||||||
|
// Enchant creature
|
||||||
TargetPermanent auraTarget = new TargetCreaturePermanent();
|
TargetPermanent auraTarget = new TargetCreaturePermanent();
|
||||||
this.getSpellAbility().addTarget(auraTarget);
|
this.getSpellAbility().addTarget(auraTarget);
|
||||||
this.getSpellAbility().addEffect(new AttachEffect(Outcome.Detriment));
|
this.getSpellAbility().addEffect(new AttachEffect(Outcome.Detriment));
|
||||||
Ability ability = new EnchantAbility(auraTarget.getTargetName());
|
Ability ability = new EnchantAbility(auraTarget.getTargetName());
|
||||||
this.addAbility(ability);
|
this.addAbility(ability);
|
||||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new NecroticPlagueEffect(this.objectId)));
|
// Enchanted creature has "At the beginning of your upkeep, sacrifice this creature."
|
||||||
|
// When enchanted creature dies, its controller chooses target creature one of his or her opponents controls. Return Necrotic Plague from its owner's graveyard to the battlefield attached to that creature.
|
||||||
|
Ability gainedAbility = new BeginningOfUpkeepTriggeredAbility(new SacrificeSourceEffect(), TargetController.YOU, false);
|
||||||
|
Effect effect = new GainAbilityAttachedEffect(gainedAbility, AttachmentType.AURA, Duration.WhileOnBattlefield);
|
||||||
|
effect.setText("Enchanted creature has \"At the beginning of your upkeep, sacrifice this creature.\"");
|
||||||
|
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, effect));
|
||||||
|
this.addAbility(new DiesAttachedTriggeredAbility(new NecroticPlagueEffect(),"enchanted creature", false));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void adjustTargets(Ability ability, Game game) {
|
||||||
|
if (ability instanceof DiesAttachedTriggeredAbility) {
|
||||||
|
Permanent attachedTo = null;
|
||||||
|
for (Effect effect :ability.getEffects()) {
|
||||||
|
attachedTo = (Permanent) effect.getValue("attachedTo");
|
||||||
|
}
|
||||||
|
if (attachedTo != null) {
|
||||||
|
Player creatureController = game.getPlayer(attachedTo.getControllerId());
|
||||||
|
if (creatureController != null) {
|
||||||
|
ability.setControllerId(creatureController.getId());
|
||||||
|
ability.getTargets().clear();
|
||||||
|
TargetCreaturePermanent target = new TargetCreaturePermanent(filter);
|
||||||
|
target.setRequired(true);
|
||||||
|
ability.getTargets().add(target);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public NecroticPlague(final NecroticPlague card) {
|
public NecroticPlague(final NecroticPlague card) {
|
||||||
super(card);
|
super(card);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void assignNewId() {
|
|
||||||
super.assignNewId();
|
|
||||||
updateSource();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public NecroticPlague copy() {
|
public NecroticPlague copy() {
|
||||||
return new NecroticPlague(this);
|
return new NecroticPlague(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateSource() {
|
|
||||||
for (Ability ability: abilities) {
|
|
||||||
for (Effect effect: ability.getEffects()) {
|
|
||||||
if (effect instanceof NecroticPlagueEffect) {
|
|
||||||
((NecroticPlagueEffect)effect).updateSource(objectId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class NecroticPlagueEffect extends ContinuousEffectImpl<NecroticPlagueEffect> {
|
class NecroticPlagueEffect extends OneShotEffect<NecroticPlagueEffect> {
|
||||||
|
|
||||||
private Ability ability1;
|
|
||||||
private Ability ability2;
|
|
||||||
|
|
||||||
public NecroticPlagueEffect(UUID cardId) {
|
|
||||||
super(Duration.WhileOnBattlefield, Outcome.Detriment);
|
public NecroticPlagueEffect() {
|
||||||
ability1 = new OnEventTriggeredAbility(EventType.UPKEEP_STEP_PRE, "beginning of your upkeep", new SacrificeSourceEffect());
|
super(Outcome.PutCardInPlay);
|
||||||
ability2 = new DiesTriggeredAbility(new NecroticPlagueEffect2(cardId), false);
|
staticText = "its controller chooses target creature one of his or her opponents controls. Return {this} from its owner's graveyard to the battlefield attached to that creature";
|
||||||
staticText = "Enchanted creature has \"At the beginning of your upkeep, sacrifice this creature.\" When enchanted creature is put into a graveyard, its controller chooses target creature one of his or her opponents controls. Return {this} from its owner's graveyard to the battlefield attached to that creature.";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public NecroticPlagueEffect(final NecroticPlagueEffect effect) {
|
public NecroticPlagueEffect(final NecroticPlagueEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.ability1 = effect.ability1.copy();
|
}
|
||||||
this.ability2 = effect.ability2.copy();
|
|
||||||
|
@Override
|
||||||
|
public boolean apply(Game game, Ability source) {
|
||||||
|
Permanent attachedTo = (Permanent) this.getValue("attachedTo");
|
||||||
|
if (attachedTo != null) {
|
||||||
|
Player creatureController = game.getPlayer(attachedTo.getControllerId());
|
||||||
|
if (creatureController != null) {
|
||||||
|
Card sourceEnchantmentCard = game.getCard(source.getSourceId());
|
||||||
|
Permanent creature = game.getPermanent(this.getTargetPointer().getFirst(game, source));
|
||||||
|
if (sourceEnchantmentCard != null && creature != null) {
|
||||||
|
game.getState().setValue("attachTo:" + sourceEnchantmentCard.getId(), creature);
|
||||||
|
creatureController.putOntoBattlefieldWithInfo(sourceEnchantmentCard, game, Zone.GRAVEYARD, source.getSourceId());
|
||||||
|
return creature.addAttachment(sourceEnchantmentCard.getId(), game);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -129,92 +157,4 @@ class NecroticPlagueEffect extends ContinuousEffectImpl<NecroticPlagueEffect> {
|
||||||
return new NecroticPlagueEffect(this);
|
return new NecroticPlagueEffect(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean apply(Layer layer, SubLayer sublayer, Ability source, Game game) {
|
|
||||||
Permanent enchantment = game.getPermanent(source.getSourceId());
|
|
||||||
if (enchantment != null && enchantment.getAttachedTo() != null) {
|
|
||||||
Permanent creature = game.getPermanent(enchantment.getAttachedTo());
|
|
||||||
if (creature != null) {
|
|
||||||
switch (layer) {
|
|
||||||
case AbilityAddingRemovingEffects_6:
|
|
||||||
if (sublayer == SubLayer.NA) {
|
|
||||||
creature.addAbility(ability1, game);
|
|
||||||
creature.addAbility(ability2, game);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateSource(UUID id) {
|
|
||||||
for (Effect effect: ability2.getEffects()) {
|
|
||||||
if (effect instanceof NecroticPlagueEffect2) {
|
|
||||||
((NecroticPlagueEffect2)effect).updateSource(id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean apply(Game game, Ability source) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean hasLayer(Layer layer) {
|
|
||||||
return layer == Layer.AbilityAddingRemovingEffects_6;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
class NecroticPlagueEffect2 extends OneShotEffect<NecroticPlagueEffect2> {
|
|
||||||
|
|
||||||
private UUID cardId;
|
|
||||||
|
|
||||||
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("creature an opponent controls");
|
|
||||||
|
|
||||||
static {
|
|
||||||
filter.add(new ControllerPredicate(TargetController.OPPONENT));
|
|
||||||
}
|
|
||||||
|
|
||||||
public NecroticPlagueEffect2(UUID cardId) {
|
|
||||||
super(Outcome.PutCardInPlay);
|
|
||||||
this.cardId = cardId;
|
|
||||||
staticText = "its controller chooses target creature one of his or her opponents controls. Return {this} from its owner's graveyard to the battlefield attached to that creature.";
|
|
||||||
}
|
|
||||||
|
|
||||||
public NecroticPlagueEffect2(final NecroticPlagueEffect2 effect) {
|
|
||||||
super(effect);
|
|
||||||
this.cardId = effect.cardId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean apply(Game game, Ability source) {
|
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
|
||||||
if (controller != null) {
|
|
||||||
TargetCreaturePermanent target = new TargetCreaturePermanent(filter);
|
|
||||||
if (target.canChoose(source.getSourceId(), source.getControllerId(), game)) {
|
|
||||||
if (controller.chooseTarget(Outcome.Detriment, target, source, game)) {
|
|
||||||
Card card = game.getCard(cardId);
|
|
||||||
if (card != null) {
|
|
||||||
this.setTargetPointer(new FixedTarget(target.getFirstTarget()));
|
|
||||||
return card.putOntoBattlefield(game, Zone.GRAVEYARD, source.getId(), source.getControllerId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateSource(UUID id) {
|
|
||||||
this.cardId = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public NecroticPlagueEffect2 copy() {
|
|
||||||
return new NecroticPlagueEffect2(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,8 +36,30 @@ public class NecroticPlagueTest extends CardTestPlayerBase {
|
||||||
@Test
|
@Test
|
||||||
public void testCard2() {
|
public void testCard2() {
|
||||||
addCard(Zone.BATTLEFIELD, playerA, "Swamp", 4);
|
addCard(Zone.BATTLEFIELD, playerA, "Swamp", 4);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Goblin Deathraiders English
|
||||||
|
* Creature — Goblin Warrior 3/1, BR
|
||||||
|
* Trample
|
||||||
|
*/
|
||||||
addCard(Zone.BATTLEFIELD, playerA, "Goblin Deathraiders");
|
addCard(Zone.BATTLEFIELD, playerA, "Goblin Deathraiders");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Necrotic Plague
|
||||||
|
* Enchantment — Aura, 2BB
|
||||||
|
* Enchant creature
|
||||||
|
* Enchanted creature has "At the beginning of your upkeep, sacrifice this creature."
|
||||||
|
* When enchanted creature dies, its controller chooses target creature one of his or
|
||||||
|
* her opponents controls. Return Necrotic Plague from its owner's graveyard to the
|
||||||
|
* battlefield attached to that creature.
|
||||||
|
*/
|
||||||
addCard(Zone.HAND, playerA, "Necrotic Plague");
|
addCard(Zone.HAND, playerA, "Necrotic Plague");
|
||||||
|
/**
|
||||||
|
* Sejiri Merfolk English
|
||||||
|
* Creature — Merfolk Soldier 2/1, 1U
|
||||||
|
* As long as you control a Plains, Sejiri Merfolk has first strike and lifelink.
|
||||||
|
* (Damage dealt by a creature with lifelink also causes its controller to gain that much life.)
|
||||||
|
*/
|
||||||
addCard(Zone.BATTLEFIELD, playerB, "Sejiri Merfolk");
|
addCard(Zone.BATTLEFIELD, playerB, "Sejiri Merfolk");
|
||||||
|
|
||||||
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Necrotic Plague", "Sejiri Merfolk");
|
castSpell(1, PhaseStep.PRECOMBAT_MAIN, playerA, "Necrotic Plague", "Sejiri Merfolk");
|
||||||
|
@ -47,8 +69,9 @@ public class NecroticPlagueTest extends CardTestPlayerBase {
|
||||||
|
|
||||||
assertLife(playerA, 20);
|
assertLife(playerA, 20);
|
||||||
assertLife(playerB, 20);
|
assertLife(playerB, 20);
|
||||||
assertPermanentCount(playerA, "Goblin Deathraiders", 0);
|
|
||||||
assertPermanentCount(playerB, "Sejiri Merfolk", 0);
|
assertPermanentCount(playerB, "Sejiri Merfolk", 0);
|
||||||
|
assertPermanentCount(playerA, "Goblin Deathraiders", 0);
|
||||||
assertGraveyardCount(playerA, 2);
|
assertGraveyardCount(playerA, 2);
|
||||||
assertGraveyardCount(playerA, "Necrotic Plague", 1);
|
assertGraveyardCount(playerA, "Necrotic Plague", 1);
|
||||||
assertGraveyardCount(playerA, "Goblin Deathraiders", 1);
|
assertGraveyardCount(playerA, "Goblin Deathraiders", 1);
|
||||||
|
|
Loading…
Reference in a new issue