diff --git a/Mage.Sets/src/mage/cards/m/MasterSymmetrist.java b/Mage.Sets/src/mage/cards/m/MasterSymmetrist.java new file mode 100644 index 00000000000..c0028cf30f4 --- /dev/null +++ b/Mage.Sets/src/mage/cards/m/MasterSymmetrist.java @@ -0,0 +1,66 @@ +package mage.cards.m; + +import mage.MageInt; +import mage.abilities.common.AttacksAllTriggeredAbility; +import mage.abilities.effects.common.continuous.GainAbilityTargetEffect; +import mage.abilities.keyword.ReachAbility; +import mage.abilities.keyword.TrampleAbility; +import mage.cards.CardImpl; +import mage.cards.CardSetInfo; +import mage.constants.*; +import mage.filter.common.FilterCreaturePermanent; +import mage.filter.predicate.Predicate; +import mage.game.Game; +import mage.game.permanent.Permanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class MasterSymmetrist extends CardImpl { + + private static final FilterCreaturePermanent filter + = new FilterCreaturePermanent("a creature you control with power equal to its toughness"); + + static { + filter.add(TargetController.YOU.getControllerPredicate()); + filter.add(MasterSymmetristPredicate.instance); + } + + public MasterSymmetrist(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{G}{G}"); + + this.subtype.add(SubType.RHINO); + this.subtype.add(SubType.DRUID); + this.power = new MageInt(4); + this.toughness = new MageInt(4); + + // Reach + this.addAbility(ReachAbility.getInstance()); + + // Whenever a creature you control with power equal to its toughness attacks, it gains trample until end of turn. + this.addAbility(new AttacksAllTriggeredAbility(new GainAbilityTargetEffect( + TrampleAbility.getInstance(), Duration.EndOfTurn, + "it gains trample until end of turn" + ), false, filter, SetTargetPointer.PERMANENT, false)); + } + + private MasterSymmetrist(final MasterSymmetrist card) { + super(card); + } + + @Override + public MasterSymmetrist copy() { + return new MasterSymmetrist(this); + } +} + +enum MasterSymmetristPredicate implements Predicate { + instance; + + @Override + public boolean apply(Permanent input, Game game) { + return input.getPower().getValue() == input.getToughness().getValue(); + } +} diff --git a/Mage.Sets/src/mage/sets/StrixhavenSchoolOfMages.java b/Mage.Sets/src/mage/sets/StrixhavenSchoolOfMages.java index 7aa7f0bb080..a2401abb3f6 100644 --- a/Mage.Sets/src/mage/sets/StrixhavenSchoolOfMages.java +++ b/Mage.Sets/src/mage/sets/StrixhavenSchoolOfMages.java @@ -86,6 +86,7 @@ public final class StrixhavenSchoolOfMages extends ExpansionSet { cards.add(new SetCardInfo("Mage Hunter", 76, Rarity.UNCOMMON, mage.cards.m.MageHunter.class)); cards.add(new SetCardInfo("Magma Opus", 203, Rarity.MYTHIC, mage.cards.m.MagmaOpus.class)); cards.add(new SetCardInfo("Manifestation Sage", 205, Rarity.RARE, mage.cards.m.ManifestationSage.class)); + cards.add(new SetCardInfo("Master Symmetrist", 138, Rarity.UNCOMMON, mage.cards.m.MasterSymmetrist.class)); cards.add(new SetCardInfo("Mountain", 372, Rarity.LAND, mage.cards.basiclands.Mountain.class, NON_FULL_USE_VARIOUS)); cards.add(new SetCardInfo("Multiple Choice", 48, Rarity.RARE, mage.cards.m.MultipleChoice.class)); cards.add(new SetCardInfo("Necroblossom Snarl", 269, Rarity.RARE, mage.cards.n.NecroblossomSnarl.class));