* Mindsparker - Fixed that the ability did not trigger for the correct card types and colors.

This commit is contained in:
LevelX2 2013-07-24 19:02:50 +02:00
parent 235d314104
commit 14bf4c8d33
2 changed files with 12 additions and 12 deletions

View file

@ -76,7 +76,7 @@ public class Mindsparker extends CardImpl<Mindsparker> {
this.addAbility(FirstStrikeAbility.getInstance()); this.addAbility(FirstStrikeAbility.getInstance());
// Whenever an opponent casts a white or blue instant or sorcery spell, Mindsparker deals 2 damage to that player. // Whenever an opponent casts a white or blue instant or sorcery spell, Mindsparker deals 2 damage to that player.
this.addAbility(new OpponentCastsSpellTriggeredAbility(Zone.BATTLEFIELD, new MindsparkerEffect(), filter, false)); this.addAbility(new OpponentCastsSpellTriggeredAbility(Zone.BATTLEFIELD, new MindsparkerEffect(), filter, false, true));
} }
@ -115,4 +115,4 @@ class MindsparkerEffect extends OneShotEffect<MindsparkerEffect> {
} }
return false; return false;
} }
} }

View file

@ -27,9 +27,9 @@
*/ */
package mage.abilities.common; package mage.abilities.common;
import mage.constants.Zone;
import mage.abilities.TriggeredAbilityImpl; import mage.abilities.TriggeredAbilityImpl;
import mage.abilities.effects.Effect; import mage.abilities.effects.Effect;
import mage.constants.Zone;
import mage.filter.FilterCard; import mage.filter.FilterCard;
import mage.game.Game; import mage.game.Game;
import mage.game.events.GameEvent; import mage.game.events.GameEvent;
@ -55,8 +55,7 @@ public class OpponentCastsSpellTriggeredAbility extends TriggeredAbilityImpl<Opp
} }
public OpponentCastsSpellTriggeredAbility(Zone zone, Effect effect, FilterCard filter, boolean optional) { public OpponentCastsSpellTriggeredAbility(Zone zone, Effect effect, FilterCard filter, boolean optional) {
super(zone, effect, optional); this(zone, effect, filter, optional, false);
this.filter = filter;
} }
public OpponentCastsSpellTriggeredAbility(Zone zone, Effect effect, FilterCard filter, boolean optional, boolean setTargetPointerPlayer) { public OpponentCastsSpellTriggeredAbility(Zone zone, Effect effect, FilterCard filter, boolean optional, boolean setTargetPointerPlayer) {
@ -67,7 +66,7 @@ public class OpponentCastsSpellTriggeredAbility extends TriggeredAbilityImpl<Opp
public OpponentCastsSpellTriggeredAbility(final OpponentCastsSpellTriggeredAbility ability) { public OpponentCastsSpellTriggeredAbility(final OpponentCastsSpellTriggeredAbility ability) {
super(ability); super(ability);
filter = ability.filter; this.filter = ability.filter;
this.setTargetPointerPlayer = ability.setTargetPointerPlayer; this.setTargetPointerPlayer = ability.setTargetPointerPlayer;
} }
@ -75,12 +74,13 @@ public class OpponentCastsSpellTriggeredAbility extends TriggeredAbilityImpl<Opp
public boolean checkTrigger(GameEvent event, Game game) { public boolean checkTrigger(GameEvent event, Game game) {
if (event.getType() == GameEvent.EventType.SPELL_CAST && game.getOpponents(controllerId).contains(event.getPlayerId())) { if (event.getType() == GameEvent.EventType.SPELL_CAST && game.getOpponents(controllerId).contains(event.getPlayerId())) {
Spell spell = game.getStack().getSpell(event.getTargetId()); Spell spell = game.getStack().getSpell(event.getTargetId());
if (spell != null && filter.match(spell, game) && !setTargetPointerPlayer) { if (spell != null && filter.match(spell, game)) {
this.getEffects().get(0).setTargetPointer(new FixedTarget(event.getTargetId())); if (setTargetPointerPlayer) {
return true; for (Effect effect: this.getEffects()) {
} else { effect.setTargetPointer(new FixedTarget(event.getPlayerId()));
this.getEffects().get(0).setTargetPointer(new FixedTarget(event.getPlayerId())); }
return true; return true;
}
} }
} }
return false; return false;