From 34d1e910492a8ce6f54902e374602202de81195b Mon Sep 17 00:00:00 2001 From: theelk801 Date: Mon, 27 Jan 2025 11:44:36 -0500 Subject: [PATCH] [DFT] Implement Back on Track --- Mage.Sets/src/mage/cards/b/BackOnTrack.java | 47 +++++++++++++++++++++ Mage.Sets/src/mage/sets/Aetherdrift.java | 1 + 2 files changed, 48 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/b/BackOnTrack.java diff --git a/Mage.Sets/src/mage/cards/b/BackOnTrack.java b/Mage.Sets/src/mage/cards/b/BackOnTrack.java new file mode 100644 index 00000000000..67d142e55e9 --- /dev/null +++ b/Mage.Sets/src/mage/cards/b/BackOnTrack.java @@ -0,0 +1,47 @@ +package mage.cards.b; + +import mage.abilities.effects.common.CreateTokenEffect; +import mage.abilities.effects.common.ReturnFromGraveyardToBattlefieldTargetEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.filter.FilterCard; +import mage.filter.predicate.Predicates; +import mage.game.permanent.token.PilotSaddleCrewToken; +import mage.target.common.TargetCardInYourGraveyard; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class BackOnTrack extends CardImpl { + + private static final FilterCard filter = new FilterCard("creature or Vehicle card from your graveyard"); + + static { + filter.add(Predicates.or( + CardType.CREATURE.getPredicate(), + SubType.VEHICLE.getPredicate() + )); + } + + public BackOnTrack(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{4}{B}"); + + // Return target creature or Vehicle card from your graveyard to the battlefield. Create a 1/1 colorless Pilot creature token with "This token saddles Mounts and crews Vehicles as though its power were 2 greater." + this.getSpellAbility().addEffect(new ReturnFromGraveyardToBattlefieldTargetEffect()); + this.getSpellAbility().addEffect(new CreateTokenEffect(new PilotSaddleCrewToken())); + this.getSpellAbility().addTarget(new TargetCardInYourGraveyard(filter)); + } + + private BackOnTrack(final BackOnTrack card) { + super(card); + } + + @Override + public BackOnTrack copy() { + return new BackOnTrack(this); + } +} diff --git a/Mage.Sets/src/mage/sets/Aetherdrift.java b/Mage.Sets/src/mage/sets/Aetherdrift.java index 42595e1ba2d..962067f08d1 100644 --- a/Mage.Sets/src/mage/sets/Aetherdrift.java +++ b/Mage.Sets/src/mage/sets/Aetherdrift.java @@ -33,6 +33,7 @@ public final class Aetherdrift extends ExpansionSet { cards.add(new SetCardInfo("Amonkhet Raceway", 248, Rarity.UNCOMMON, mage.cards.a.AmonkhetRaceway.class)); cards.add(new SetCardInfo("Apocalypse Runner", 188, Rarity.UNCOMMON, mage.cards.a.ApocalypseRunner.class)); cards.add(new SetCardInfo("Avishkar Raceway", 249, Rarity.COMMON, mage.cards.a.AvishkarRaceway.class)); + cards.add(new SetCardInfo("Back on Track", 76, Rarity.UNCOMMON, mage.cards.b.BackOnTrack.class)); cards.add(new SetCardInfo("Beastrider Vanguard", 154, Rarity.COMMON, mage.cards.b.BeastriderVanguard.class)); cards.add(new SetCardInfo("Bestow Greatness", 155, Rarity.COMMON, mage.cards.b.BestowGreatness.class)); cards.add(new SetCardInfo("Bleachbone Verge", 250, Rarity.RARE, mage.cards.b.BleachboneVerge.class));