From 36ecbd8cf61a5ba74b1d77076ed7362e5a7e11b8 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Tue, 13 May 2025 10:54:33 -0400 Subject: [PATCH] [FIC] Implement Lord Jyscal Guado --- .../src/mage/cards/l/LordJyscalGuado.java | 108 ++++++++++++++++++ .../src/mage/sets/FinalFantasyCommander.java | 1 + .../mage/abilities/hint/ConditionHint.java | 2 +- 3 files changed, 110 insertions(+), 1 deletion(-) create mode 100644 Mage.Sets/src/mage/cards/l/LordJyscalGuado.java diff --git a/Mage.Sets/src/mage/cards/l/LordJyscalGuado.java b/Mage.Sets/src/mage/cards/l/LordJyscalGuado.java new file mode 100644 index 00000000000..4303d1247ca --- /dev/null +++ b/Mage.Sets/src/mage/cards/l/LordJyscalGuado.java @@ -0,0 +1,108 @@ +package mage.cards.l; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.condition.Condition; +import mage.abilities.effects.keyword.InvestigateEffect; +import mage.abilities.hint.ConditionHint; +import mage.abilities.hint.Hint; +import mage.abilities.keyword.FlyingAbility; +import mage.abilities.triggers.BeginningOfEndStepTriggeredAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.constants.WatcherScope; +import mage.game.Game; +import mage.game.events.GameEvent; +import mage.game.permanent.Permanent; +import mage.watchers.Watcher; + +import java.util.HashSet; +import java.util.Set; +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class LordJyscalGuado extends CardImpl { + + public LordJyscalGuado(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{W}"); + + this.supertype.add(SuperType.LEGENDARY); + this.subtype.add(SubType.SPIRIT); + this.subtype.add(SubType.CLERIC); + this.power = new MageInt(2); + this.toughness = new MageInt(1); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // At the beginning of each end step, if you put a counter on a creature this turn, investigate. + this.addAbility(new BeginningOfEndStepTriggeredAbility(new InvestigateEffect()) + .withInterveningIf(LordJyscalGuadoCondition.instance) + .addHint(LordJyscalGuadoCondition.getHint()), + new LordJyscalGuadoWatcher() + ); + } + + private LordJyscalGuado(final LordJyscalGuado card) { + super(card); + } + + @Override + public LordJyscalGuado copy() { + return new LordJyscalGuado(this); + } +} + +enum LordJyscalGuadoCondition implements Condition { + instance; + private static final Hint hint = new ConditionHint(instance); + + @Override + public boolean apply(Game game, Ability source) { + return LordJyscalGuadoWatcher.checkPlayer(source.getControllerId(), game); + } + + @Override + public String toString() { + return "you put a counter on a creature this turn"; + } + + public static Hint getHint() { + return hint; + } +} + +class LordJyscalGuadoWatcher extends Watcher { + + Set set = new HashSet<>(); + + LordJyscalGuadoWatcher() { + super(WatcherScope.GAME); + } + + @Override + public void watch(GameEvent event, Game game) { + if (event.getType() != GameEvent.EventType.COUNTER_ADDED) { + return; + } + Permanent permanent = game.getPermanent(event.getTargetId()); + if (permanent != null && permanent.isCreature(game)) { + set.add(event.getPlayerId()); + } + } + + @Override + public void reset() { + super.reset(); + set.clear(); + } + + static boolean checkPlayer(UUID playerId, Game game) { + return game.getState().getWatcher(LordJyscalGuadoWatcher.class).set.contains(playerId); + } +} diff --git a/Mage.Sets/src/mage/sets/FinalFantasyCommander.java b/Mage.Sets/src/mage/sets/FinalFantasyCommander.java index ebc2add8509..21c8c76ded1 100644 --- a/Mage.Sets/src/mage/sets/FinalFantasyCommander.java +++ b/Mage.Sets/src/mage/sets/FinalFantasyCommander.java @@ -156,6 +156,7 @@ public final class FinalFantasyCommander extends ExpansionSet { cards.add(new SetCardInfo("Lethal Scheme", 277, Rarity.RARE, mage.cards.l.LethalScheme.class)); cards.add(new SetCardInfo("Lightning Greaves", 349, Rarity.UNCOMMON, mage.cards.l.LightningGreaves.class)); cards.add(new SetCardInfo("Lingering Souls", 245, Rarity.UNCOMMON, mage.cards.l.LingeringSouls.class)); + cards.add(new SetCardInfo("Lord Jyscal Guado", 23, Rarity.RARE, mage.cards.l.LordJyscalGuado.class)); cards.add(new SetCardInfo("Luminous Broodmoth", 246, Rarity.MYTHIC, mage.cards.l.LuminousBroodmoth.class)); cards.add(new SetCardInfo("Mask of Memory", 350, Rarity.UNCOMMON, mage.cards.m.MaskOfMemory.class)); cards.add(new SetCardInfo("Meteor Golem", 351, Rarity.UNCOMMON, mage.cards.m.MeteorGolem.class)); diff --git a/Mage/src/main/java/mage/abilities/hint/ConditionHint.java b/Mage/src/main/java/mage/abilities/hint/ConditionHint.java index 2cdac23c408..52d7847477f 100644 --- a/Mage/src/main/java/mage/abilities/hint/ConditionHint.java +++ b/Mage/src/main/java/mage/abilities/hint/ConditionHint.java @@ -20,7 +20,7 @@ public class ConditionHint implements Hint { private final boolean useIcons; public ConditionHint(Condition condition) { - this(condition, condition.toString()); + this(condition, CardUtil.getTextWithFirstCharUpperCase(condition.toString())); } public ConditionHint(Condition condition, String textWithIcons) {