mirror of
https://github.com/Card-Forge/forge.git
synced 2025-11-18 11:48:02 +00:00
Merge branch 'master' of git.cardforge.org:core-developers/forge
This commit is contained in:
@@ -4088,7 +4088,7 @@ public class CardFactoryUtil {
|
||||
|
||||
newSA.setPayCosts(surgeCost);
|
||||
newSA.setBasicSpell(false);
|
||||
newSA.addOptionalCost(OptionalCost.Surge);
|
||||
newSA.setSurged(true);
|
||||
|
||||
String desc = "Surge " + surgeCost.toSimpleString() + " (" + inst.getReminderText()
|
||||
+ ")";
|
||||
|
||||
@@ -1614,9 +1614,10 @@ public class CardProperty {
|
||||
if (card.isOptionalCostPaid(OptionalCost.Generic)) return false;
|
||||
}
|
||||
} else if (property.startsWith("surged")) {
|
||||
if (!card.isOptionalCostPaid(OptionalCost.Surge)) {
|
||||
if (card.getCastSA() == null) {
|
||||
return false;
|
||||
}
|
||||
return card.getCastSA().isSurged();
|
||||
} else if (property.startsWith("evoked")) {
|
||||
if (card.getCastSA() == null) {
|
||||
return false;
|
||||
|
||||
@@ -11,7 +11,6 @@ public enum OptionalCost {
|
||||
Kicker1("Kicker"),
|
||||
Kicker2("Kicker"),
|
||||
Retrace("Retrace"),
|
||||
Surge("Surge"), // no real OptionalCost but used there
|
||||
AltCost(""), // used by prowl
|
||||
Flash("Flash"),
|
||||
Generic("Generic"); // used by "Dragon Presence" and pseudo-kicker cards
|
||||
|
||||
@@ -97,6 +97,7 @@ public abstract class SpellAbility extends CardTraitBase implements ISpellAbilit
|
||||
private boolean cycling = false;
|
||||
private boolean dash = false;
|
||||
private boolean evoke = false;
|
||||
private boolean surge = false;
|
||||
private boolean offering = false;
|
||||
private boolean emerge = false;
|
||||
private boolean morphup = false;
|
||||
@@ -510,10 +511,6 @@ public abstract class SpellAbility extends CardTraitBase implements ISpellAbilit
|
||||
getMultiKickerManaCost() != null;
|
||||
}
|
||||
|
||||
public boolean isSurged() {
|
||||
return isOptionalCostPaid(OptionalCost.Surge);
|
||||
}
|
||||
|
||||
public boolean isEntwine() {
|
||||
return isOptionalCostPaid(OptionalCost.Entwine);
|
||||
}
|
||||
@@ -1072,6 +1069,14 @@ public abstract class SpellAbility extends CardTraitBase implements ISpellAbilit
|
||||
evoke = isEvoke;
|
||||
}
|
||||
|
||||
public final boolean isSurged() {
|
||||
return surge;
|
||||
}
|
||||
|
||||
public final void setSurged(final boolean isSurge) {
|
||||
surge = isSurge;
|
||||
}
|
||||
|
||||
public CardCollection getTappedForConvoke() {
|
||||
return tappedForConvoke;
|
||||
}
|
||||
|
||||
15
forge-gui/res/puzzle/PS_M197.pzl
Normal file
15
forge-gui/res/puzzle/PS_M197.pzl
Normal file
@@ -0,0 +1,15 @@
|
||||
[metadata]
|
||||
Name:Possibility Storm - Magic Core Set 2019 #07
|
||||
URL:https://i1.wp.com/www.possibilitystorm.com/wp-content/uploads/2018/08/077.-M197.jpg
|
||||
Goal:Win
|
||||
Turns:1
|
||||
Difficulty:Uncommon
|
||||
Description:Win this turn. Assume your opponent has no mana available. Remember that your solution must work for all possible blocking scenarios.
|
||||
[state]
|
||||
humanlife=20
|
||||
ailife=5
|
||||
activeplayer=human
|
||||
activephase=MAIN1
|
||||
humanhand=Compulsory Rest;Academy Journeymage;Untamed Hunger;Act of Treason;Emergent Growth
|
||||
humanbattlefield=Shield Mare;Surge Mare;Plague Mare;Lightning Mare;Vine Mare;Plains|Set:M19;Island|Set:M19;Swamp|Set:M19;Mountain|Set:M19;Forest|Set:M19;Unknown Shores
|
||||
aibattlefield=Ghirapur Osprey;Ancient Crab;Wretched Camel;Thresher Lizard;Stalking Tiger
|
||||
Reference in New Issue
Block a user