Implemented Will of the All-Hunter

This commit is contained in:
Evan Kranzler 2020-04-08 22:03:39 -04:00
parent 461769eaa2
commit c2c14c16c9
2 changed files with 75 additions and 0 deletions

View file

@ -0,0 +1,74 @@
package mage.cards.w;
import mage.abilities.Ability;
import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.effects.OneShotEffect;
import mage.abilities.effects.common.continuous.BoostTargetEffect;
import mage.abilities.keyword.CyclingAbility;
import mage.cards.CardImpl;
import mage.cards.CardSetInfo;
import mage.constants.CardType;
import mage.constants.Outcome;
import mage.counters.CounterType;
import mage.game.Game;
import mage.game.permanent.Permanent;
import mage.target.common.TargetCreaturePermanent;
import java.util.UUID;
/**
* @author TheElk801
*/
public final class WillOfTheAllHunter extends CardImpl {
public WillOfTheAllHunter(UUID ownerId, CardSetInfo setInfo) {
super(ownerId, setInfo, new CardType[]{CardType.INSTANT}, "{1}{W}");
// Target creature gets +2/+2 until end of turn. If it's blocking, instead put two +1/+1 counters on it.
this.getSpellAbility().addEffect(new WillOfTheAllHunterEffect());
this.getSpellAbility().addTarget(new TargetCreaturePermanent());
// Cycling {2}
this.addAbility(new CyclingAbility(new ManaCostsImpl("{2}")));
}
private WillOfTheAllHunter(final WillOfTheAllHunter card) {
super(card);
}
@Override
public WillOfTheAllHunter copy() {
return new WillOfTheAllHunter(this);
}
}
class WillOfTheAllHunterEffect extends OneShotEffect {
WillOfTheAllHunterEffect() {
super(Outcome.Benefit);
staticText = "Target creature gets +2/+2 until end of turn. " +
"If it's blocking, instead put two +1/+1 counters on it.";
}
private WillOfTheAllHunterEffect(final WillOfTheAllHunterEffect effect) {
super(effect);
}
@Override
public WillOfTheAllHunterEffect copy() {
return new WillOfTheAllHunterEffect(this);
}
@Override
public boolean apply(Game game, Ability source) {
Permanent permanent = game.getPermanent(source.getFirstTarget());
if (permanent == null) {
return false;
}
if (permanent.getBlocking() > 0) {
return permanent.addCounters(CounterType.P1P1.createInstance(2), source, game);
}
game.addEffect(new BoostTargetEffect(2, 2), source);
return true;
}
}

View file

@ -157,6 +157,7 @@ public final class IkoriaLairOfBehemoths extends ExpansionSet {
cards.add(new SetCardInfo("Void Beckoner", 104, Rarity.UNCOMMON, mage.cards.v.VoidBeckoner.class));
cards.add(new SetCardInfo("Voracious Greatshark", 70, Rarity.RARE, mage.cards.v.VoraciousGreatshark.class));
cards.add(new SetCardInfo("Weaponize the Monsters", 140, Rarity.UNCOMMON, mage.cards.w.WeaponizeTheMonsters.class));
cards.add(new SetCardInfo("Will of the All-Hunter", 38, Rarity.UNCOMMON, mage.cards.w.WillOfTheAllHunter.class));
cards.add(new SetCardInfo("Wilt", 176, Rarity.COMMON, mage.cards.w.Wilt.class));
cards.add(new SetCardInfo("Wingfold Pteron", 71, Rarity.COMMON, mage.cards.w.WingfoldPteron.class));
cards.add(new SetCardInfo("Zagoth Crystal", 242, Rarity.UNCOMMON, mage.cards.z.ZagothCrystal.class));