diff --git a/Mage.Sets/src/mage/cards/r/RenegadeReaper.java b/Mage.Sets/src/mage/cards/r/RenegadeReaper.java new file mode 100644 index 00000000000..04ed34200c7 --- /dev/null +++ b/Mage.Sets/src/mage/cards/r/RenegadeReaper.java @@ -0,0 +1,78 @@ +package mage.cards.r; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.keyword.FlyingAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.constants.SubType; +import mage.game.Game; +import mage.players.Player; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class RenegadeReaper extends CardImpl { + + public RenegadeReaper(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{B}"); + + this.subtype.add(SubType.ANGEL); + this.subtype.add(SubType.BERSERKER); + this.power = new MageInt(2); + this.toughness = new MageInt(3); + + // Flying + this.addAbility(FlyingAbility.getInstance()); + + // When Renegade Reaper enters the battlefield, mill four cards. If at least one Angel is milled this way, you gain 4 life. + this.addAbility(new EntersBattlefieldTriggeredAbility(new RenegadeReaperEffect())); + } + + private RenegadeReaper(final RenegadeReaper card) { + super(card); + } + + @Override + public RenegadeReaper copy() { + return new RenegadeReaper(this); + } +} + +class RenegadeReaperEffect extends OneShotEffect { + + RenegadeReaperEffect() { + super(Outcome.Benefit); + staticText = "mill four cards. If at least one Angel is milled this way, you gain 4 life"; + } + + private RenegadeReaperEffect(final RenegadeReaperEffect effect) { + super(effect); + } + + @Override + public RenegadeReaperEffect copy() { + return new RenegadeReaperEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Player player = game.getPlayer(source.getControllerId()); + if (player == null) { + return false; + } + if (player.millCards(4, source, game) + .getCards(game) + .stream() + .anyMatch(card -> card.hasSubtype(SubType.ANGEL, game))) { + player.gainLife(4, game, source); + } + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/Kaldheim.java b/Mage.Sets/src/mage/sets/Kaldheim.java index e1debcff8bd..e23911b83bb 100644 --- a/Mage.Sets/src/mage/sets/Kaldheim.java +++ b/Mage.Sets/src/mage/sets/Kaldheim.java @@ -36,6 +36,7 @@ public final class Kaldheim extends ExpansionSet { cards.add(new SetCardInfo("Gilded Assault Cart", 390, Rarity.UNCOMMON, mage.cards.g.GildedAssaultCart.class)); cards.add(new SetCardInfo("Gladewalker Ritualist", 392, Rarity.UNCOMMON, mage.cards.g.GladewalkerRitualist.class)); cards.add(new SetCardInfo("Hengegate Pathway", 260, Rarity.RARE, mage.cards.h.HengegatePathway.class)); + cards.add(new SetCardInfo("Renegade Reaper", 386, Rarity.UNCOMMON, mage.cards.r.RenegadeReaper.class)); cards.add(new SetCardInfo("Showdown of the Skalds", 229, Rarity.RARE, mage.cards.s.ShowdownOfTheSkalds.class)); } }