From 6a323a467c2454922585fe22ac02ef618d6b8e13 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Tue, 9 Jul 2024 16:36:01 -0400 Subject: [PATCH] [BLB] Implement Seedglaive Mentor --- .../src/mage/cards/s/SeedglaiveMentor.java | 47 +++++++++++++++++++ Mage.Sets/src/mage/sets/Bloomburrow.java | 1 + .../common/ValiantTriggeredAbility.java | 37 +++++++++++++++ .../main/java/mage/constants/AbilityWord.java | 1 + 4 files changed, 86 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/s/SeedglaiveMentor.java create mode 100644 Mage/src/main/java/mage/abilities/common/ValiantTriggeredAbility.java diff --git a/Mage.Sets/src/mage/cards/s/SeedglaiveMentor.java b/Mage.Sets/src/mage/cards/s/SeedglaiveMentor.java new file mode 100644 index 00000000000..9598a8d17a2 --- /dev/null +++ b/Mage.Sets/src/mage/cards/s/SeedglaiveMentor.java @@ -0,0 +1,47 @@ +package mage.cards.s; + +import mage.MageInt; +import mage.abilities.common.ValiantTriggeredAbility; +import mage.abilities.effects.common.counter.AddCountersSourceEffect; +import mage.abilities.keyword.HasteAbility; +import mage.abilities.keyword.VigilanceAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.counters.CounterType; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class SeedglaiveMentor extends CardImpl { + + public SeedglaiveMentor(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{R}{W}"); + + this.subtype.add(SubType.MOUSE); + this.subtype.add(SubType.SOLDIER); + this.power = new MageInt(3); + this.toughness = new MageInt(2); + + // Vigilance + this.addAbility(VigilanceAbility.getInstance()); + + // Haste + this.addAbility(HasteAbility.getInstance()); + + // Valiant -- Whenever Seedglaive Mentor becomes the target of a spell or ability you control for the first time each turn, put a +1/+1 counter on it. + this.addAbility(new ValiantTriggeredAbility(new AddCountersSourceEffect(CounterType.P1P1.createInstance()).setText("put a +1/+1 counter on it"))); + } + + private SeedglaiveMentor(final SeedglaiveMentor card) { + super(card); + } + + @Override + public SeedglaiveMentor copy() { + return new SeedglaiveMentor(this); + } +} diff --git a/Mage.Sets/src/mage/sets/Bloomburrow.java b/Mage.Sets/src/mage/sets/Bloomburrow.java index 00938900c21..4307f1be340 100644 --- a/Mage.Sets/src/mage/sets/Bloomburrow.java +++ b/Mage.Sets/src/mage/sets/Bloomburrow.java @@ -41,6 +41,7 @@ public final class Bloomburrow extends ExpansionSet { cards.add(new SetCardInfo("Rockface Village", 259, Rarity.UNCOMMON, mage.cards.r.RockfaceVillage.class)); cards.add(new SetCardInfo("Run Away Together", 67, Rarity.COMMON, mage.cards.r.RunAwayTogether.class)); cards.add(new SetCardInfo("Salvation Swan", 28, Rarity.RARE, mage.cards.s.SalvationSwan.class)); + cards.add(new SetCardInfo("Seedglaive Mentor", 231, Rarity.UNCOMMON, mage.cards.s.SeedglaiveMentor.class)); cards.add(new SetCardInfo("Sunshower Druid", 195, Rarity.COMMON, mage.cards.s.SunshowerDruid.class)); cards.add(new SetCardInfo("Swamp", 270, Rarity.LAND, mage.cards.basiclands.Swamp.class, FULL_ART_BFZ_VARIOUS)); } diff --git a/Mage/src/main/java/mage/abilities/common/ValiantTriggeredAbility.java b/Mage/src/main/java/mage/abilities/common/ValiantTriggeredAbility.java new file mode 100644 index 00000000000..e11494ad304 --- /dev/null +++ b/Mage/src/main/java/mage/abilities/common/ValiantTriggeredAbility.java @@ -0,0 +1,37 @@ +package mage.abilities.common; + +import mage.abilities.effects.Effect; +import mage.constants.AbilityWord; +import mage.constants.SetTargetPointer; +import mage.constants.TargetController; +import mage.filter.FilterStackObject; + +/** + * @author xenohedron, TheElk801 + */ +public class ValiantTriggeredAbility extends BecomesTargetSourceFirstTimeTriggeredAbility { + + private static final FilterStackObject filter = new FilterStackObject("a spell or ability you control"); + + static { + filter.add(TargetController.YOU.getControllerPredicate()); + } + + public ValiantTriggeredAbility(Effect effect) { + this(effect, false); + this.setAbilityWord(AbilityWord.VALIANT); + } + + public ValiantTriggeredAbility(Effect effect, boolean optional) { + super(effect, filter, SetTargetPointer.NONE, false); + } + + private ValiantTriggeredAbility(final ValiantTriggeredAbility ability) { + super(ability); + } + + @Override + public ValiantTriggeredAbility copy() { + return new ValiantTriggeredAbility(this); + } +} diff --git a/Mage/src/main/java/mage/constants/AbilityWord.java b/Mage/src/main/java/mage/constants/AbilityWord.java index 7298b460843..5d15af0a9e5 100644 --- a/Mage/src/main/java/mage/constants/AbilityWord.java +++ b/Mage/src/main/java/mage/constants/AbilityWord.java @@ -58,6 +58,7 @@ public enum AbilityWord { TEMPTING_OFFER("Tempting offer"), THRESHOLD("Threshold"), UNDERGROWTH("Undergrowth"), + VALIANT("Valiant"), WILL_OF_THE_COUNCIL("Will of the council"), WILL_OF_THE_PLANESWALKERS("Will of the planeswalkers");