From f4c2171fd16a41d0da7853e5d542fc79f346784b Mon Sep 17 00:00:00 2001 From: theelk801 Date: Wed, 10 Jul 2024 16:32:50 -0400 Subject: [PATCH] [BLB] Implement Warren Warleader --- .../src/mage/cards/w/WarrenWarleader.java | 56 +++++++++++++++++++ Mage.Sets/src/mage/sets/Bloomburrow.java | 1 + 2 files changed, 57 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/w/WarrenWarleader.java diff --git a/Mage.Sets/src/mage/cards/w/WarrenWarleader.java b/Mage.Sets/src/mage/cards/w/WarrenWarleader.java new file mode 100644 index 00000000000..828ad318a8f --- /dev/null +++ b/Mage.Sets/src/mage/cards/w/WarrenWarleader.java @@ -0,0 +1,56 @@ +package mage.cards.w; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.AttacksWithCreaturesTriggeredAbility; +import mage.abilities.effects.common.CreateTokenEffect; +import mage.abilities.effects.common.continuous.BoostControlledEffect; +import mage.abilities.keyword.OffspringAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.SubType; +import mage.filter.StaticFilters; +import mage.game.permanent.token.RabbitToken; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class WarrenWarleader extends CardImpl { + + public WarrenWarleader(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{W}{W}"); + + this.subtype.add(SubType.RABBIT); + this.subtype.add(SubType.KNIGHT); + this.power = new MageInt(4); + this.toughness = new MageInt(4); + + // Offspring {2} + this.addAbility(new OffspringAbility("{2}")); + + // Whenever you attack, choose one -- + // * Create a 1/1 white Rabbit creature token that's tapped and attacking. + Ability ability = new AttacksWithCreaturesTriggeredAbility( + new CreateTokenEffect(new RabbitToken(), 1, true, true), 1 + ); + + // * Attacking creatures you control get +1/+1 until end of turn. + ability.addEffect(new BoostControlledEffect( + 1, 1, Duration.EndOfTurn, StaticFilters.FILTER_ATTACKING_CREATURES + )); + this.addAbility(ability); + } + + private WarrenWarleader(final WarrenWarleader card) { + super(card); + } + + @Override + public WarrenWarleader copy() { + return new WarrenWarleader(this); + } +} diff --git a/Mage.Sets/src/mage/sets/Bloomburrow.java b/Mage.Sets/src/mage/sets/Bloomburrow.java index 28ae2e0a60b..c83dde334c0 100644 --- a/Mage.Sets/src/mage/sets/Bloomburrow.java +++ b/Mage.Sets/src/mage/sets/Bloomburrow.java @@ -64,6 +64,7 @@ public final class Bloomburrow extends ExpansionSet { cards.add(new SetCardInfo("Tempest Angler", 235, Rarity.COMMON, mage.cards.t.TempestAngler.class)); cards.add(new SetCardInfo("Tender Wildguide", 196, Rarity.RARE, mage.cards.t.TenderWildguide.class)); cards.add(new SetCardInfo("Thundertrap Trainer", 78, Rarity.RARE, mage.cards.t.ThundertrapTrainer.class)); + cards.add(new SetCardInfo("Warren Warleader", 38, Rarity.MYTHIC, mage.cards.w.WarrenWarleader.class)); cards.removeIf(setCardInfo -> unfinished.contains(setCardInfo.getName())); // remove when mechanic is implemented }