YMKM: roalesk_prime_specimen + support (#4903)

* roalesk_prime_specimen + support

* allow added abilities to show on face-down cards
This commit is contained in:
Northmoc
2024-03-27 10:57:42 -04:00
committed by GitHub
parent 38c5fee296
commit fb6e944b45
5 changed files with 34 additions and 1 deletions

View File

@@ -253,6 +253,8 @@ public abstract class AnimateEffectBase extends SpellAbilityEffect {
if (!"Permanent".equals(duration) && !perpetual) {
if ("UntilControllerNextUntap".equals(duration)) {
game.getUntap().addUntil(c.getController(), unanimate);
} else if ("UntilAnimatedFaceup".equals(duration)) {
c.addFaceupCommand(unanimate);
} else {
addUntilCommand(sa, unanimate);
}

View File

@@ -21,6 +21,7 @@ import forge.game.spellability.SpellAbility;
import forge.util.Aggregates;
import forge.util.Lang;
import forge.util.Localizer;
import org.apache.commons.lang3.StringUtils;
public class ChooseCardNameEffect extends SpellAbilityEffect {
@@ -119,6 +120,10 @@ public class ChooseCardNameEffect extends SpellAbilityEffect {
Predicate<ICardFace> cpp = Predicates.alwaysTrue();
if (sa.hasParam("ValidCards")) {
//Calculating/replacing this must happen before running valid in CardFacePredicates
if (valid.contains("cmcEQ") && !StringUtils.isNumeric(valid.split("cmcEQ")[1])) {
String s = valid.split("cmcEQ")[1];
valid = valid.replace(s, String.valueOf(AbilityUtils.calculateAmount(host, s, sa)));
}
if (valid.contains("ManaCost=")) {
if (valid.contains("ManaCost=Equipped")) {
String s = host.getEquipping().getManaCost().getShortString();

View File

@@ -2819,7 +2819,9 @@ public class Card extends GameEntity implements Comparable<Card>, IHasSVars {
addedManaStrings.add(sAbility);
}
if (!sAbility.endsWith(state.getName() + "\r\n")) {
boolean alwaysShow = false;
if (!sa.isIntrinsic()) alwaysShow = true; // allows added abilities to show on face-down stuff (e.g. Morph,Cloaked)
if (!sAbility.endsWith(state.getName() + "\r\n") || alwaysShow) {
sb.append(sAbility);
sb.append("\r\n");
}