mirror of
https://github.com/correl/mage.git
synced 2025-01-13 19:11:33 +00:00
* Mishra, Artificer Prodigy - Fixed that artifact put into play with it's triggered ability where wrongly handled face down.
This commit is contained in:
parent
d6bed435e2
commit
a1e385160a
2 changed files with 4 additions and 13 deletions
|
@ -142,15 +142,12 @@ class MishraArtificerProdigyEffect extends OneShotEffect {
|
||||||
FilterCard filter = new FilterCard("card named " + this.cardName);
|
FilterCard filter = new FilterCard("card named " + this.cardName);
|
||||||
filter.add(new NamePredicate(cardName));
|
filter.add(new NamePredicate(cardName));
|
||||||
Card card = null;
|
Card card = null;
|
||||||
Zone zone = null;
|
|
||||||
// Graveyard
|
// Graveyard
|
||||||
if (controller.chooseUse(Outcome.Neutral, "Search your graveyard?", source, game)) {
|
if (controller.chooseUse(Outcome.Neutral, "Search your graveyard?", source, game)) {
|
||||||
TargetCardInYourGraveyard target = new TargetCardInYourGraveyard(0, 1, filter);
|
// You can't fail to find the card in your graveyard because it's not hidden
|
||||||
|
TargetCardInYourGraveyard target = new TargetCardInYourGraveyard(1, 1, filter);
|
||||||
if (controller.choose(Outcome.PutCardInPlay, controller.getGraveyard(), target, game)) {
|
if (controller.choose(Outcome.PutCardInPlay, controller.getGraveyard(), target, game)) {
|
||||||
card = game.getCard(target.getFirstTarget());
|
card = game.getCard(target.getFirstTarget());
|
||||||
if (card != null) {
|
|
||||||
zone = Zone.GRAVEYARD;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Hand
|
// Hand
|
||||||
|
@ -158,9 +155,6 @@ class MishraArtificerProdigyEffect extends OneShotEffect {
|
||||||
TargetCardInHand target = new TargetCardInHand(0, 1, filter);
|
TargetCardInHand target = new TargetCardInHand(0, 1, filter);
|
||||||
if (controller.choose(Outcome.PutCardInPlay, controller.getHand(), target, game)) {
|
if (controller.choose(Outcome.PutCardInPlay, controller.getHand(), target, game)) {
|
||||||
card = game.getCard(target.getFirstTarget());
|
card = game.getCard(target.getFirstTarget());
|
||||||
if (card != null) {
|
|
||||||
zone = Zone.HAND;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Library
|
// Library
|
||||||
|
@ -168,15 +162,12 @@ class MishraArtificerProdigyEffect extends OneShotEffect {
|
||||||
TargetCardInLibrary target = new TargetCardInLibrary(0, 1, filter);
|
TargetCardInLibrary target = new TargetCardInLibrary(0, 1, filter);
|
||||||
if (controller.searchLibrary(target, game)) {
|
if (controller.searchLibrary(target, game)) {
|
||||||
card = game.getCard(target.getFirstTarget());
|
card = game.getCard(target.getFirstTarget());
|
||||||
if (card != null) {
|
|
||||||
zone = Zone.LIBRARY;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
controller.shuffleLibrary(game);
|
controller.shuffleLibrary(game);
|
||||||
}
|
}
|
||||||
// Put on battlefield
|
// Put on battlefield
|
||||||
if (card != null) {
|
if (card != null) {
|
||||||
controller.moveCards(card, zone, Zone.BATTLEFIELD, source, game);
|
controller.moveCards(card, null, Zone.BATTLEFIELD, source, game);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2983,7 +2983,7 @@ public abstract class PlayerImpl implements Player, Serializable {
|
||||||
case BATTLEFIELD:
|
case BATTLEFIELD:
|
||||||
for (Card card : cards) {
|
for (Card card : cards) {
|
||||||
fromZone = game.getState().getZone(card.getId());
|
fromZone = game.getState().getZone(card.getId());
|
||||||
if (putOntoBattlefieldWithInfo(card, game, fromZone, source == null ? null : source.getSourceId(), false, !card.isFaceDown(game))) {
|
if (putOntoBattlefieldWithInfo(card, game, fromZone, source == null ? null : source.getSourceId(), false, card.isFaceDown(game))) {
|
||||||
successfulMovedCards.add(card);
|
successfulMovedCards.add(card);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue