mirror of
https://github.com/correl/mage.git
synced 2025-01-11 19:13:02 +00:00
* Desertion - Fixed that the countered spell was wrongly moved to battlefield under owner control instad of Desertion caster control (fixed #3467).
This commit is contained in:
parent
05d90729c3
commit
e7337f66b7
1 changed files with 12 additions and 13 deletions
|
@ -27,21 +27,20 @@
|
||||||
*/
|
*/
|
||||||
package mage.cards.d;
|
package mage.cards.d;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
|
import mage.cards.Card;
|
||||||
import mage.cards.CardImpl;
|
import mage.cards.CardImpl;
|
||||||
import mage.cards.CardSetInfo;
|
import mage.cards.CardSetInfo;
|
||||||
import mage.constants.CardType;
|
import mage.constants.CardType;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.constants.ZoneDetail;
|
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.stack.Spell;
|
import mage.game.stack.Spell;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
import mage.target.TargetSpell;
|
import mage.target.TargetSpell;
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Quercitron
|
* @author Quercitron
|
||||||
|
@ -49,7 +48,7 @@ import java.util.UUID;
|
||||||
public class Desertion extends CardImpl {
|
public class Desertion extends CardImpl {
|
||||||
|
|
||||||
public Desertion(UUID ownerId, CardSetInfo setInfo) {
|
public Desertion(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.INSTANT},"{3}{U}{U}");
|
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{3}{U}{U}");
|
||||||
|
|
||||||
// Counter target spell. If an artifact or creature spell is countered this way, put that card onto the battlefield under your control instead of into its owner's graveyard.
|
// Counter target spell. If an artifact or creature spell is countered this way, put that card onto the battlefield under your control instead of into its owner's graveyard.
|
||||||
this.getSpellAbility().addEffect(new DesertionEffect());
|
this.getSpellAbility().addEffect(new DesertionEffect());
|
||||||
|
@ -70,7 +69,7 @@ class DesertionEffect extends OneShotEffect {
|
||||||
|
|
||||||
public DesertionEffect() {
|
public DesertionEffect() {
|
||||||
super(Outcome.Detriment);
|
super(Outcome.Detriment);
|
||||||
this.staticText = "Counter target spell. If an artifact or creature spell is countered this way, put that card onto the battlefield under your control instead of into its owner's graveyard.";
|
this.staticText = "Counter target spell. If an artifact or creature spell is countered this way, put that card onto the battlefield under your control instead of into its owner's graveyard";
|
||||||
}
|
}
|
||||||
|
|
||||||
public DesertionEffect(final DesertionEffect effect) {
|
public DesertionEffect(final DesertionEffect effect) {
|
||||||
|
@ -86,18 +85,18 @@ class DesertionEffect extends OneShotEffect {
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null) {
|
if (controller != null) {
|
||||||
Spell targetSpell = game.getStack().getSpell(targetPointer.getFirst(game, source));
|
Spell targetSpell = game.getStack().getSpell(getTargetPointer().getFirst(game, source));
|
||||||
if (targetSpell != null) {
|
if (targetSpell != null) {
|
||||||
//targetPointer.getFirst(game, source)
|
if (game.getStack().counter(targetSpell.getId(), source.getSourceId(), game)) {
|
||||||
|
game.applyEffects();
|
||||||
if (targetSpell.isArtifact() || targetSpell.isCreature()) {
|
if (targetSpell.isArtifact() || targetSpell.isCreature()) {
|
||||||
return game.getStack().counter(targetSpell.getId(), source.getSourceId(), game, Zone.BATTLEFIELD, false, ZoneDetail.NONE);
|
Card card = game.getCard(targetSpell.getSourceId());
|
||||||
} else {
|
controller.moveCards(card, Zone.BATTLEFIELD, source, game);
|
||||||
return game.getStack().counter(targetSpell.getId(), source.getSourceId(), game);
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue