From fe7fe67a36fb21d87757ddaa39e4505c6bca816c Mon Sep 17 00:00:00 2001 From: theelk801 Date: Fri, 18 Jul 2025 14:34:49 -0400 Subject: [PATCH] [EOE] Implement Brightspear Zealot --- .../src/mage/cards/b/BrightspearZealot.java | 65 +++++++++++++++++++ Mage.Sets/src/mage/sets/EdgeOfEternities.java | 1 + 2 files changed, 66 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/b/BrightspearZealot.java diff --git a/Mage.Sets/src/mage/cards/b/BrightspearZealot.java b/Mage.Sets/src/mage/cards/b/BrightspearZealot.java new file mode 100644 index 00000000000..539494f14df --- /dev/null +++ b/Mage.Sets/src/mage/cards/b/BrightspearZealot.java @@ -0,0 +1,65 @@ +package mage.cards.b; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.SimpleStaticAbility; +import mage.abilities.condition.Condition; +import mage.abilities.decorator.ConditionalContinuousEffect; +import mage.abilities.effects.common.continuous.BoostSourceEffect; +import mage.abilities.keyword.VigilanceAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.game.Game; +import mage.watchers.common.SpellsCastWatcher; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class BrightspearZealot extends CardImpl { + + public BrightspearZealot(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{W}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.SOLDIER); + this.power = new MageInt(2); + this.toughness = new MageInt(4); + + // Vigilance + this.addAbility(VigilanceAbility.getInstance()); + + // This creature gets +2/+0 as long as you've cast two or more spells this turn. + this.addAbility(new SimpleStaticAbility(new ConditionalContinuousEffect( + new BoostSourceEffect(2, 0, Duration.WhileOnBattlefield), + BrightspearZealotCondition.instance, "{this} gets +2/+0 as long " + + "as you've cast two or more spells this turn" + ))); + } + + private BrightspearZealot(final BrightspearZealot card) { + super(card); + } + + @Override + public BrightspearZealot copy() { + return new BrightspearZealot(this); + } +} + +enum BrightspearZealotCondition implements Condition { + instance; + + @Override + public boolean apply(Game game, Ability source) { + return game + .getState() + .getWatcher(SpellsCastWatcher.class) + .getSpellsCastThisTurn(source.getControllerId()) + .size() >= 2; + } +} diff --git a/Mage.Sets/src/mage/sets/EdgeOfEternities.java b/Mage.Sets/src/mage/sets/EdgeOfEternities.java index 7868f57c291..4a14ab138d8 100644 --- a/Mage.Sets/src/mage/sets/EdgeOfEternities.java +++ b/Mage.Sets/src/mage/sets/EdgeOfEternities.java @@ -60,6 +60,7 @@ public final class EdgeOfEternities extends ExpansionSet { cards.add(new SetCardInfo("Breeding Pool", 251, Rarity.RARE, mage.cards.b.BreedingPool.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Breeding Pool", 278, Rarity.RARE, mage.cards.b.BreedingPool.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Breeding Pool", 373, Rarity.RARE, mage.cards.b.BreedingPool.class, NON_FULL_USE_VARIOUS)); + cards.add(new SetCardInfo("Brightspear Zealot", 8, Rarity.COMMON, mage.cards.b.BrightspearZealot.class)); cards.add(new SetCardInfo("Broodguard Elite", 175, Rarity.UNCOMMON, mage.cards.b.BroodguardElite.class)); cards.add(new SetCardInfo("Bygone Colossus", 235, Rarity.UNCOMMON, mage.cards.b.BygoneColossus.class)); cards.add(new SetCardInfo("Cerebral Download", 48, Rarity.UNCOMMON, mage.cards.c.CerebralDownload.class));