diff --git a/Mage.Sets/src/mage/cards/d/DrizztDoUrden.java b/Mage.Sets/src/mage/cards/d/DrizztDoUrden.java new file mode 100644 index 0000000000..4406ee2fe9 --- /dev/null +++ b/Mage.Sets/src/mage/cards/d/DrizztDoUrden.java @@ -0,0 +1,108 @@ +package mage.cards.d; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.DiesCreatureTriggeredAbility; +import mage.abilities.common.EntersBattlefieldTriggeredAbility; +import mage.abilities.condition.Condition; +import mage.abilities.decorator.ConditionalInterveningIfTriggeredAbility; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.effects.common.CreateTokenEffect; +import mage.abilities.keyword.DoubleStrikeAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.CardType; +import mage.constants.Outcome; +import mage.constants.SubType; +import mage.constants.SuperType; +import mage.counters.CounterType; +import mage.game.Game; +import mage.game.permanent.Permanent; +import mage.game.permanent.token.GuenhwyvarToken; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class DrizztDoUrden extends CardImpl { + + public DrizztDoUrden(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{3}{G}{W}"); + + this.addSuperType(SuperType.LEGENDARY); + this.subtype.add(SubType.ELF); + this.subtype.add(SubType.RANGER); + this.power = new MageInt(3); + this.toughness = new MageInt(3); + + // Double strike + this.addAbility(DoubleStrikeAbility.getInstance()); + + // Whenever Drizzt Do'Urden enters the battlefield, create Guenhwyvar, a legendary 4/1 green Cat creature token with trample. + this.addAbility(new EntersBattlefieldTriggeredAbility(new CreateTokenEffect(new GuenhwyvarToken()) + .setText("create Guenhwyvar, a legendary 4/1 green Cat creature token with trample"))); + + // Whenever a creature dies, if it had power greater than Drizzt's power, put a number of +1/+1 counters on Drizzt equal to the difference. + this.addAbility(new ConditionalInterveningIfTriggeredAbility( + new DiesCreatureTriggeredAbility(new DrizztDoUrdenEffect(), false), + DrizztDoUrdenCondition.instance, "Whenever a creature dies, if it had power greater " + + "than {this}'s power, put a number of +1/+1 counters on {this} equal to the difference." + )); + } + + private DrizztDoUrden(final DrizztDoUrden card) { + super(card); + } + + @Override + public DrizztDoUrden copy() { + return new DrizztDoUrden(this); + } +} + +enum DrizztDoUrdenCondition implements Condition { + instance; + + @Override + public boolean apply(Game game, Ability source) { + Permanent sourcePermanent = source.getSourcePermanentOrLKI(game); + Permanent creatureDied = (Permanent) source + .getEffects() + .stream() + .map(effect -> effect.getValue("creatureDied")) + .findFirst() + .orElse(null); + return sourcePermanent != null + && creatureDied != null + && creatureDied.getPower().getValue() > sourcePermanent.getPower().getValue(); + } +} + +class DrizztDoUrdenEffect extends OneShotEffect { + + DrizztDoUrdenEffect() { + super(Outcome.Benefit); + } + + private DrizztDoUrdenEffect(final DrizztDoUrdenEffect effect) { + super(effect); + } + + @Override + public DrizztDoUrdenEffect copy() { + return new DrizztDoUrdenEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Permanent sourcePermanent = source.getSourcePermanentOrLKI(game); + Permanent creatureDied = (Permanent) this.getValue("creatureDied"); + if (creatureDied == null || sourcePermanent == null) { + return false; + } + return sourcePermanent.addCounters(CounterType.P1P1.createInstance( + Math.max(creatureDied.getPower().getValue() - sourcePermanent.getPower().getValue(), 0) + ), source.getControllerId(), source, game); + } +} diff --git a/Mage.Sets/src/mage/sets/AdventuresInTheForgottenRealms.java b/Mage.Sets/src/mage/sets/AdventuresInTheForgottenRealms.java index 157f7ac41c..fc7315f666 100644 --- a/Mage.Sets/src/mage/sets/AdventuresInTheForgottenRealms.java +++ b/Mage.Sets/src/mage/sets/AdventuresInTheForgottenRealms.java @@ -25,6 +25,7 @@ public final class AdventuresInTheForgottenRealms extends ExpansionSet { this.numBoosterRare = 1; this.maxCardNumberInBooster = 275; + cards.add(new SetCardInfo("Drizzt Do'Urden", 220, Rarity.RARE, mage.cards.d.DrizztDoUrden.class)); cards.add(new SetCardInfo("Flumph", 15, Rarity.RARE, mage.cards.f.Flumph.class)); cards.add(new SetCardInfo("Forest", 281, Rarity.LAND, mage.cards.basiclands.Forest.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Island", 269, Rarity.LAND, mage.cards.basiclands.Island.class, NON_FULL_USE_VARIOUS)); diff --git a/Mage/src/main/java/mage/game/permanent/token/GuenhwyvarToken.java b/Mage/src/main/java/mage/game/permanent/token/GuenhwyvarToken.java new file mode 100644 index 0000000000..12c0f54b9e --- /dev/null +++ b/Mage/src/main/java/mage/game/permanent/token/GuenhwyvarToken.java @@ -0,0 +1,32 @@ +package mage.game.permanent.token; + +import mage.MageInt; +import mage.abilities.keyword.TrampleAbility; +import mage.constants.CardType; +import mage.constants.SubType; +import mage.constants.SuperType; + +/** + * @author TheElk801 + */ +public final class GuenhwyvarToken extends TokenImpl { + + public GuenhwyvarToken() { + super("Guenhwyvar", "Guenhwyvar, a legendary 4/1 green Cat creature token with trample"); + supertype.add(SuperType.LEGENDARY); + cardType.add(CardType.CREATURE); + color.setGreen(true); + subtype.add(SubType.CAT); + power = new MageInt(4); + toughness = new MageInt(1); + addAbility(TrampleAbility.getInstance()); + } + + private GuenhwyvarToken(final GuenhwyvarToken token) { + super(token); + } + + public GuenhwyvarToken copy() { + return new GuenhwyvarToken(this); + } +}