From 413b8fae27c41088020580a62a62bb4337579be8 Mon Sep 17 00:00:00 2001 From: theelk801 Date: Fri, 23 Jan 2026 13:38:14 -0500 Subject: [PATCH] [TMT] Implement Turtles in Time --- .../src/mage/cards/s/StepBetweenWorlds.java | 25 ++---- Mage.Sets/src/mage/cards/t/TurtlesInTime.java | 87 +++++++++++++++++++ .../mage/sets/TeenageMutantNinjaTurtles.java | 1 + 3 files changed, 97 insertions(+), 16 deletions(-) create mode 100644 Mage.Sets/src/mage/cards/t/TurtlesInTime.java diff --git a/Mage.Sets/src/mage/cards/s/StepBetweenWorlds.java b/Mage.Sets/src/mage/cards/s/StepBetweenWorlds.java index dc04bdb368a..7716123be6f 100644 --- a/Mage.Sets/src/mage/cards/s/StepBetweenWorlds.java +++ b/Mage.Sets/src/mage/cards/s/StepBetweenWorlds.java @@ -61,32 +61,25 @@ class StepBetweenWorldsEffect extends OneShotEffect { @Override public boolean apply(Game game, Ability source) { - Player controller = game.getPlayer(source.getControllerId()); - if (controller == null) { - return false; - } List players = new ArrayList<>(); for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) { Player player = game.getPlayer(playerId); if (player == null) { continue; } - if (!player.chooseUse( - Outcome.Benefit, - "Shuffle your hand and graveyard into your library, then draw seven cards?", - source, game - )) { - continue; + if (player.chooseUse(Outcome.DrawCard, "Shuffle your hand and graveyard into your library and draw seven cards?", source, game)) { + game.informPlayers(player.getLogName() + " chooses to shuffle and draw"); + players.add(player); + } else { + game.informPlayers(player.getLogName() + " chooses not to shuffle and draw"); } - players.add(player); - Cards cards = new CardsImpl(player.getHand()); - cards.addAll(player.getGraveyard()); - player.putCardsOnTopOfLibrary(cards, game, source, false); - player.shuffleLibrary(source, game); } for (Player player : players) { + Cards cards = new CardsImpl(player.getHand()); + cards.addAll(player.getGraveyard()); + player.shuffleCardsToLibrary(cards, game, source); player.drawCards(7, source, game); } - return true; + return !players.isEmpty(); } } diff --git a/Mage.Sets/src/mage/cards/t/TurtlesInTime.java b/Mage.Sets/src/mage/cards/t/TurtlesInTime.java new file mode 100644 index 00000000000..843db8929ca --- /dev/null +++ b/Mage.Sets/src/mage/cards/t/TurtlesInTime.java @@ -0,0 +1,87 @@ +package mage.cards.t; + +import mage.abilities.Ability; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.effects.common.ExileSpellEffect; +import mage.abilities.effects.common.ReturnToHandFromBattlefieldAllEffect; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.cards.Cards; +import mage.cards.CardsImpl; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.filter.StaticFilters; +import mage.game.Game; +import mage.players.Player; + +import java.util.ArrayList; +import java.util.List; +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class TurtlesInTime extends CardImpl { + + public TurtlesInTime(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{5}{U}{U}"); + + // Return all creatures to their owners' hands. Each player may shuffle their hand and graveyard into their library, then each player who does draws seven cards. + this.getSpellAbility().addEffect(new ReturnToHandFromBattlefieldAllEffect(StaticFilters.FILTER_PERMANENT_CREATURES)); + this.getSpellAbility().addEffect(new TurtlesInTimeEffect()); + + // Exile Turtles in Time. + this.getSpellAbility().addEffect(new ExileSpellEffect().concatBy("
")); + } + + private TurtlesInTime(final TurtlesInTime card) { + super(card); + } + + @Override + public TurtlesInTime copy() { + return new TurtlesInTime(this); + } +} + +class TurtlesInTimeEffect extends OneShotEffect { + + TurtlesInTimeEffect() { + super(Outcome.Benefit); + staticText = "Each player may shuffle their hand and graveyard into their library, " + + "then each player who does draws seven cards"; + } + + private TurtlesInTimeEffect(final TurtlesInTimeEffect effect) { + super(effect); + } + + @Override + public TurtlesInTimeEffect copy() { + return new TurtlesInTimeEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + List players = new ArrayList<>(); + for (UUID playerId : game.getState().getPlayersInRange(source.getControllerId(), game)) { + Player player = game.getPlayer(playerId); + if (player == null) { + continue; + } + if (player.chooseUse(Outcome.DrawCard, "Shuffle your hand and graveyard into your library and draw seven cards?", source, game)) { + game.informPlayers(player.getLogName() + " chooses to shuffle and draw"); + players.add(player); + } else { + game.informPlayers(player.getLogName() + " chooses not to shuffle and draw"); + } + } + for (Player player : players) { + Cards cards = new CardsImpl(player.getHand()); + cards.addAll(player.getGraveyard()); + player.shuffleCardsToLibrary(cards, game, source); + player.drawCards(7, source, game); + } + return !players.isEmpty(); + } +} diff --git a/Mage.Sets/src/mage/sets/TeenageMutantNinjaTurtles.java b/Mage.Sets/src/mage/sets/TeenageMutantNinjaTurtles.java index f24ea4172af..a5b31e8d196 100644 --- a/Mage.Sets/src/mage/sets/TeenageMutantNinjaTurtles.java +++ b/Mage.Sets/src/mage/sets/TeenageMutantNinjaTurtles.java @@ -94,6 +94,7 @@ public final class TeenageMutantNinjaTurtles extends ExpansionSet { cards.add(new SetCardInfo("Turncoat Kunoichi", 26, Rarity.RARE, mage.cards.t.TurncoatKunoichi.class)); cards.add(new SetCardInfo("Turtle Power!", 135, Rarity.RARE, mage.cards.t.TurtlePower.class)); cards.add(new SetCardInfo("Turtle Van", 181, Rarity.RARE, mage.cards.t.TurtleVan.class)); + cards.add(new SetCardInfo("Turtles in Time", 55, Rarity.MYTHIC, mage.cards.t.TurtlesInTime.class)); cards.add(new SetCardInfo("Weather Maker", 182, Rarity.RARE, mage.cards.w.WeatherMaker.class)); } }