Fixed Torment of Hailfire interaction with Sigarda (fixes #4452)

This commit is contained in:
L_J 2018-02-23 14:45:01 +00:00 committed by GitHub
parent e5ef545d8f
commit ac09be4b2b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -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;
}