From 08f50b1ec12ed366758586eaf829eb7bdce03cd0 Mon Sep 17 00:00:00 2001 From: Evan Kranzler Date: Sat, 6 Nov 2021 19:51:29 -0400 Subject: [PATCH] [VOW] Implemented Parish-Blade Trainee --- .../src/mage/cards/p/ParishBladeTrainee.java | 81 +++++++++++++++++++ .../src/mage/sets/InnistradCrimsonVow.java | 1 + 2 files changed, 82 insertions(+) create mode 100644 Mage.Sets/src/mage/cards/p/ParishBladeTrainee.java diff --git a/Mage.Sets/src/mage/cards/p/ParishBladeTrainee.java b/Mage.Sets/src/mage/cards/p/ParishBladeTrainee.java new file mode 100644 index 00000000000..996ecaac37f --- /dev/null +++ b/Mage.Sets/src/mage/cards/p/ParishBladeTrainee.java @@ -0,0 +1,81 @@ +package mage.cards.p; + +import mage.MageInt; +import mage.abilities.Ability; +import mage.abilities.common.DiesSourceTriggeredAbility; +import mage.abilities.effects.OneShotEffect; +import mage.abilities.keyword.TrainingAbility; +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.game.permanent.Permanent; +import mage.target.common.TargetControlledCreaturePermanent; + +import java.util.UUID; + +/** + * @author TheElk801 + */ +public final class ParishBladeTrainee extends CardImpl { + + public ParishBladeTrainee(UUID ownerId, CardSetInfo setInfo) { + super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{1}{W}"); + + this.subtype.add(SubType.HUMAN); + this.subtype.add(SubType.SOLDIER); + this.power = new MageInt(1); + this.toughness = new MageInt(2); + + // Training + this.addAbility(new TrainingAbility()); + + // When Parish-Blade Trainee dies, put its counters on target creature you control. + Ability ability = new DiesSourceTriggeredAbility(new ParishBladeTraineeEffect()); + ability.addTarget(new TargetControlledCreaturePermanent()); + this.addAbility(ability); + } + + private ParishBladeTrainee(final ParishBladeTrainee card) { + super(card); + } + + @Override + public ParishBladeTrainee copy() { + return new ParishBladeTrainee(this); + } +} + +class ParishBladeTraineeEffect extends OneShotEffect { + + ParishBladeTraineeEffect() { + super(Outcome.Benefit); + staticText = "put its counters on target creature you control"; + } + + private ParishBladeTraineeEffect(final ParishBladeTraineeEffect effect) { + super(effect); + } + + @Override + public ParishBladeTraineeEffect copy() { + return new ParishBladeTraineeEffect(this); + } + + @Override + public boolean apply(Game game, Ability source) { + Permanent sourcePermanent = (Permanent) getValue("permanentLeftBattlefield"); + Permanent permanent = game.getPermanent(source.getFirstTarget()); + if (sourcePermanent == null || permanent == null) { + return false; + } + sourcePermanent + .getCounters(game) + .values() + .stream() + .forEach(counter -> permanent.addCounters(counter, source.getControllerId(), source, game)); + return true; + } +} diff --git a/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java b/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java index fde6575a54c..4cbb61d27b4 100644 --- a/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java +++ b/Mage.Sets/src/mage/sets/InnistradCrimsonVow.java @@ -197,6 +197,7 @@ public final class InnistradCrimsonVow extends ExpansionSet { cards.add(new SetCardInfo("Overcharged Amalgam", 71, Rarity.RARE, mage.cards.o.OverchargedAmalgam.class)); cards.add(new SetCardInfo("Packsong Pup", 213, Rarity.UNCOMMON, mage.cards.p.PacksongPup.class)); cards.add(new SetCardInfo("Parasitic Grasp", 123, Rarity.UNCOMMON, mage.cards.p.ParasiticGrasp.class)); + cards.add(new SetCardInfo("Parish-Blade Trainee", 29, Rarity.COMMON, mage.cards.p.ParishBladeTrainee.class)); cards.add(new SetCardInfo("Path of Peril", 124, Rarity.RARE, mage.cards.p.PathOfPeril.class)); cards.add(new SetCardInfo("Persistent Specimen", 125, Rarity.COMMON, mage.cards.p.PersistentSpecimen.class)); cards.add(new SetCardInfo("Piercing Light", 30, Rarity.COMMON, mage.cards.p.PiercingLight.class));