From 7057d1eb5ffed335aef7dd4231dffc9f3a289aa5 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Sun, 6 Jun 2021 12:03:14 -0400 Subject: [PATCH] [MH2] Implemented Rise and Shine --- Mage.Sets/src/mage/cards/r/RiseAndShine.java | 102 +++++++++++++++++++ Mage.Sets/src/mage/sets/ModernHorizons2.java | 1 + 2 files changed, 103 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/r/RiseAndShine.java diff --git a/Mage.Sets/src/mage/cards/r/RiseAndShine.java b/Mage.Sets/src/mage/cards/r/RiseAndShine.java new file mode 100644 index 00000000000..dddb5f8df10 --- /dev/null +++ b/Mage.Sets/src/mage/cards/r/RiseAndShine.java @@ -0,0 +1,102 @@ +package mage.cards.r; + +import mage.abilities.Ability; +import mage.abilities.costs.mana.ManaCostsImpl; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.effects.common.continuous.AddCardTypeTargetEffect; +import mage.abilities.effects.common.continuous.SetPowerToughnessTargetEffect; +import mage.abilities.effects.common.counter.AddCountersTargetEffect; +import mage.abilities.keyword.OverloadAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Duration; +import mage.constants.Outcome; +import mage.counters.CounterType; +import mage.filter.FilterPermanent; +import mage.filter.common.FilterControlledArtifactPermanent; +import mage.filter.predicate.Predicates; +import mage.game.Game; +import mage.game.permanent.Permanent; +import mage.target.TargetPermanent; +import mage.target.targetpointer.FixedTargets; + +import java.util.List; +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class RiseAndShine extends CardImpl { + + static final FilterPermanent filter + = new FilterControlledArtifactPermanent("noncreature artifact you control"); + + static { + filter.add(Predicates.not(CardType.CREATURE.getPredicate())); + } + + public RiseAndShine(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{1}{U}"); + + // Target noncreature artifact you control becomes a 0/0 artifact creature. Put four +1/+1 counters on each artifact that became a creature this way. + this.getSpellAbility().addEffect(new AddCardTypeTargetEffect( + Duration.EndOfGame, CardType.ARTIFACT, CardType.CREATURE + ).setText("Target noncreature artifact you control becomes")); + this.getSpellAbility().addEffect(new SetPowerToughnessTargetEffect( + 0, 0, Duration.EndOfGame + ).setText("a 0/0 artifact creature")); + this.getSpellAbility().addEffect(new AddCountersTargetEffect( + CounterType.P1P1.createInstance(4) + ).setText("Put four +1/+1 counters on each artifact that became a creature this way")); + this.getSpellAbility().addTarget(new TargetPermanent(filter)); + + // Overload {4}{U}{U} + this.addAbility(new OverloadAbility(this, new RiseAndShineEffect(), new ManaCostsImpl<>("{4}{U}{U}"))); + } + + private RiseAndShine(final RiseAndShine card) { + super(card); + } + + @Override + public RiseAndShine copy() { + return new RiseAndShine(this); + } +} + +class RiseAndShineEffect extends OneShotEffect { + + RiseAndShineEffect() { + super(Outcome.Benefit); + } + + private RiseAndShineEffect(final RiseAndShineEffect effect) { + super(effect); + } + + @Override + public RiseAndShineEffect copy() { + return new RiseAndShineEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + List permanents = game.getBattlefield().getActivePermanents( + RiseAndShine.filter, source.getControllerId(), source.getSourceId(), game + ); + if (permanents.isEmpty()) { + return false; + } + game.addEffect(new AddCardTypeTargetEffect( + Duration.EndOfGame, CardType.ARTIFACT, CardType.CREATURE + ).setTargetPointer(new FixedTargets(permanents, game)), source); + game.addEffect(new SetPowerToughnessTargetEffect( + 0, 0, Duration.EndOfGame + ).setTargetPointer(new FixedTargets(permanents, game)), source); + for (Permanent permanent : permanents) { + permanent.addCounters(CounterType.P1P1.createInstance(4), source.getControllerId(), source, game); + } + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/ModernHorizons2.java b/Mage.Sets/src/mage/sets/ModernHorizons2.java index 70ebdbed2e8..876bccd514e 100644 --- a/Mage.Sets/src/mage/sets/ModernHorizons2.java +++ b/Mage.Sets/src/mage/sets/ModernHorizons2.java @@ -223,6 +223,7 @@ public final class ModernHorizons2 extends ExpansionSet { cards.add(new SetCardInfo("Revolutionist", 139, Rarity.COMMON, mage.cards.r.Revolutionist.class)); cards.add(new SetCardInfo("Rift Sower", 170, Rarity.COMMON, mage.cards.r.RiftSower.class)); cards.add(new SetCardInfo("Riptide Laboratory", 303, Rarity.RARE, mage.cards.r.RiptideLaboratory.class)); + cards.add(new SetCardInfo("Rise and Shine", 58, Rarity.RARE, mage.cards.r.RiseAndShine.class)); cards.add(new SetCardInfo("Rishadan Dockhand", 59, Rarity.RARE, mage.cards.r.RishadanDockhand.class)); cards.add(new SetCardInfo("Road // Ruin", 212, Rarity.UNCOMMON, mage.cards.r.RoadRuin.class)); cards.add(new SetCardInfo("Rustvale Bridge", 253, Rarity.COMMON, mage.cards.r.RustvaleBridge.class));