mirror of
https://github.com/correl/mage.git
synced 2024-12-26 03:00:11 +00:00
Fixed Torment of Hailfire interaction with Sigarda (fixes #4452)
This commit is contained in:
parent
e5ef545d8f
commit
ac09be4b2b
1 changed files with 25 additions and 19 deletions
|
@ -86,8 +86,10 @@ class TormentOfHailfireEffect extends OneShotEffect {
|
|||
Player controller = game.getPlayer(source.getControllerId());
|
||||
if (controller != null) {
|
||||
int repeat = source.getManaCostsToPay().getX();
|
||||
for (int i = 0; i < repeat; i++) {
|
||||
for (int i = 1; i <= repeat; i++) {
|
||||
for (UUID opponentId : game.getOpponents(source.getControllerId())) {
|
||||
boolean hasChosen = false;
|
||||
while (!hasChosen) {
|
||||
Player opponent = game.getPlayer(opponentId);
|
||||
if (opponent != null) {
|
||||
int permanents = game.getBattlefield().countAll(StaticFilters.FILTER_PERMANENT_NON_LAND, opponentId, game);
|
||||
|
@ -97,20 +99,24 @@ class TormentOfHailfireEffect extends OneShotEffect {
|
|||
if (opponent.choose(outcome, target, source.getSourceId(), game)) {
|
||||
Permanent permanent = game.getPermanent(target.getFirstTarget());
|
||||
if (permanent != null) {
|
||||
permanent.sacrifice(source.getSourceId(), game);
|
||||
if (permanent.sacrifice(source.getSourceId(), game)) {
|
||||
hasChosen = true;
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (!opponent.getHand().isEmpty() && opponent.chooseUse(outcome, "Discard a card? (Iteration " + i + " of " + repeat + ")",
|
||||
"Otherwise you lose 3 life.", "Discard", "Lose 3 life", source, game)) {
|
||||
opponent.discardOne(false, source, game);
|
||||
hasChosen = true;
|
||||
continue;
|
||||
}
|
||||
opponent.loseLife(3, game, false);
|
||||
hasChosen = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue