mirror of
https://github.com/correl/mage.git
synced 2025-01-01 03:00:12 +00:00
[MOC] Implement Path of the Pyromancer
This commit is contained in:
parent
4ebb658c43
commit
a53c63e19c
2 changed files with 70 additions and 0 deletions
69
Mage.Sets/src/mage/cards/p/PathOfThePyromancer.java
Normal file
69
Mage.Sets/src/mage/cards/p/PathOfThePyromancer.java
Normal file
|
@ -0,0 +1,69 @@
|
|||
package mage.cards.p;
|
||||
|
||||
import mage.Mana;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
import mage.abilities.effects.common.WillOfThePlaneswalkersEffect;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Outcome;
|
||||
import mage.game.Game;
|
||||
import mage.players.Player;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
* @author TheElk801
|
||||
*/
|
||||
public final class PathOfThePyromancer extends CardImpl {
|
||||
|
||||
public PathOfThePyromancer(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{4}{R}");
|
||||
|
||||
// Discard all the cards in your hand. Add {R} for each card discarded this way, then draw that many cards plus one.
|
||||
this.getSpellAbility().addEffect(new PathOfThePyromancerEffect());
|
||||
|
||||
// Will of the Planeswalkers -- Starting with you, each player votes for planeswalk or chaos. If planeswalk gets more votes, planeswalk. If chaos gets more votes or the vote is tied, chaos ensues.
|
||||
this.getSpellAbility().addEffect(new WillOfThePlaneswalkersEffect());
|
||||
}
|
||||
|
||||
private PathOfThePyromancer(final PathOfThePyromancer card) {
|
||||
super(card);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PathOfThePyromancer copy() {
|
||||
return new PathOfThePyromancer(this);
|
||||
}
|
||||
}
|
||||
|
||||
class PathOfThePyromancerEffect extends OneShotEffect {
|
||||
|
||||
PathOfThePyromancerEffect() {
|
||||
super(Outcome.Benefit);
|
||||
staticText = "discard all the cards in your hand. Add {R} " +
|
||||
"for each card discarded this way, then draw that many cards plus one";
|
||||
}
|
||||
|
||||
private PathOfThePyromancerEffect(final PathOfThePyromancerEffect effect) {
|
||||
super(effect);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PathOfThePyromancerEffect copy() {
|
||||
return new PathOfThePyromancerEffect(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
Player player = game.getPlayer(source.getControllerId());
|
||||
if (player == null) {
|
||||
return false;
|
||||
}
|
||||
int discarded = player.discard(player.getHand(), false, source, game).size();
|
||||
player.getManaPool().addMana(Mana.RedMana(discarded), game, source);
|
||||
player.drawCards(discarded + 1, source, game);
|
||||
return true;
|
||||
}
|
||||
}
|
|
@ -234,6 +234,7 @@ public final class MarchOfTheMachineCommander extends ExpansionSet {
|
|||
cards.add(new SetCardInfo("Path of the Animist", 38, Rarity.RARE, mage.cards.p.PathOfTheAnimist.class));
|
||||
cards.add(new SetCardInfo("Path of the Enigma", 23, Rarity.RARE, mage.cards.p.PathOfTheEnigma.class));
|
||||
cards.add(new SetCardInfo("Path of the Ghosthunter", 18, Rarity.RARE, mage.cards.p.PathOfTheGhosthunter.class));
|
||||
cards.add(new SetCardInfo("Path of the Pyromancer", 34, Rarity.RARE, mage.cards.p.PathOfThePyromancer.class));
|
||||
cards.add(new SetCardInfo("Path to Exile", 198, Rarity.UNCOMMON, mage.cards.p.PathToExile.class));
|
||||
cards.add(new SetCardInfo("Perplexing Test", 229, Rarity.RARE, mage.cards.p.PerplexingTest.class));
|
||||
cards.add(new SetCardInfo("Phyrexian Delver", 263, Rarity.RARE, mage.cards.p.PhyrexianDelver.class));
|
||||
|
|
Loading…
Reference in a new issue