mirror of
https://github.com/Card-Forge/forge.git
synced 2025-11-16 10:48:00 +00:00
Fix for Temporal Extortion
This commit is contained in:
@@ -1551,8 +1551,7 @@ public class AbilityUtils {
|
||||
boolean alreadyPaid = false;
|
||||
for (Player payer : allPayers) {
|
||||
if (unlessCost.equals("LifeTotalHalfUp")) {
|
||||
String halfup = Integer.toString((int) Math.ceil(payer.getLife() / 2.0));
|
||||
cost = new Cost("PayLife<" + halfup + ">", true);
|
||||
cost = new Cost("PayLife<Count$YourLifeTotal/HalfUp>", true);
|
||||
}
|
||||
alreadyPaid |= payer.getController().payCostToPreventEffect(cost, sa, alreadyPaid, allPayers);
|
||||
}
|
||||
|
||||
@@ -198,8 +198,6 @@ public class HumanPlay {
|
||||
req.playAbility(!useOldTargets, false, true);
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------------
|
||||
|
||||
private static int getAmountFromPart(CostPart part, Card source, SpellAbility sourceAbility) {
|
||||
String amountString = part.getAmount();
|
||||
return StringUtils.isNumeric(amountString) ? Integer.parseInt(amountString) : AbilityUtils.calculateAmount(source, amountString, sourceAbility);
|
||||
@@ -267,11 +265,15 @@ public class HumanPlay {
|
||||
boolean mayRemovePart = true;
|
||||
|
||||
if (part instanceof CostPayLife) {
|
||||
final int amount = getAmountFromPart(part, source, sourceAbility);
|
||||
if (!p.canPayLife(amount)) {
|
||||
if (!part.canPay(sourceAbility, p)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
int amount = getAmountFromPart(part, source, sourceAbility);
|
||||
if (part.getAmount().contains("/Half")) {
|
||||
amount = Math.max(amount, 0);
|
||||
}
|
||||
|
||||
if (!p.getController().confirmPayment(part, Localizer.getInstance().getMessage("lblDoYouWantPayNLife", String.valueOf(amount)) + orString, sourceAbility)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user