mirror of
https://github.com/correl/mage.git
synced 2025-01-13 11:01:58 +00:00
* Herald's Horn - Fixed that cast cost reduction was also applied to other players.
This commit is contained in:
parent
f27f32ec5e
commit
940fe603c6
3 changed files with 25 additions and 13 deletions
|
@ -27,6 +27,7 @@
|
||||||
*/
|
*/
|
||||||
package mage.cards.h;
|
package mage.cards.h;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
import mage.MageObject;
|
import mage.MageObject;
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.common.AsEntersBattlefieldAbility;
|
import mage.abilities.common.AsEntersBattlefieldAbility;
|
||||||
|
@ -45,8 +46,6 @@ import mage.filter.predicate.mageobject.ChosenSubtypePredicate;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Saga
|
* @author Saga
|
||||||
|
@ -54,15 +53,15 @@ import java.util.UUID;
|
||||||
public class HeraldsHorn extends CardImpl {
|
public class HeraldsHorn extends CardImpl {
|
||||||
|
|
||||||
public HeraldsHorn(UUID ownerId, CardSetInfo setInfo) {
|
public HeraldsHorn(UUID ownerId, CardSetInfo setInfo) {
|
||||||
super(ownerId,setInfo,new CardType[]{CardType.ARTIFACT},"{3}");
|
super(ownerId, setInfo, new CardType[]{CardType.ARTIFACT}, "{3}");
|
||||||
|
|
||||||
// As Herald's Horn enters the battlefield, choose a creature type.
|
// As Herald's Horn enters the battlefield, choose a creature type.
|
||||||
this.addAbility(new AsEntersBattlefieldAbility(new ChooseCreatureTypeEffect(Outcome.BoostCreature)));
|
this.addAbility(new AsEntersBattlefieldAbility(new ChooseCreatureTypeEffect(Outcome.BoostCreature)));
|
||||||
|
|
||||||
// Creature spells you cast of the chosen type cost {1} less to cast.
|
// Creature spells you cast of the chosen type cost {1} less to cast.
|
||||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD,
|
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD,
|
||||||
new SpellsCostReductionAllOfChosenSubtypeEffect(new FilterCreatureCard("Creature spells you cast of the chosen type"), 1)));
|
new SpellsCostReductionAllOfChosenSubtypeEffect(new FilterCreatureCard("Creature spells you cast of the chosen type"), 1, true)));
|
||||||
|
|
||||||
// At the beginning of your upkeep, look at the top card of your library. If it's a creature card of the chosen type, you may reveal it and put it into your hand.
|
// At the beginning of your upkeep, look at the top card of your library. If it's a creature card of the chosen type, you may reveal it and put it into your hand.
|
||||||
this.addAbility(new BeginningOfUpkeepTriggeredAbility(Zone.BATTLEFIELD, new HeraldsHornEffect(), TargetController.YOU, false));
|
this.addAbility(new BeginningOfUpkeepTriggeredAbility(Zone.BATTLEFIELD, new HeraldsHornEffect(), TargetController.YOU, false));
|
||||||
}
|
}
|
||||||
|
@ -97,21 +96,21 @@ class HeraldsHornEffect extends OneShotEffect {
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
MageObject sourceObject = game.getObject(source.getSourceId());
|
MageObject sourceObject = game.getObject(source.getSourceId());
|
||||||
|
|
||||||
// Look at the top card of your library.
|
// Look at the top card of your library.
|
||||||
if (controller.getLibrary().hasCards()) {
|
if (controller.getLibrary().hasCards()) {
|
||||||
Card card = controller.getLibrary().getFromTop(game);
|
Card card = controller.getLibrary().getFromTop(game);
|
||||||
Cards cards = new CardsImpl(card);
|
Cards cards = new CardsImpl(card);
|
||||||
controller.lookAtCards(sourceObject.getIdName(), cards, game);
|
controller.lookAtCards(sourceObject.getIdName(), cards, game);
|
||||||
|
|
||||||
// If it's a creature card of the chosen type, you may reveal it and put it into your hand.
|
// If it's a creature card of the chosen type, you may reveal it and put it into your hand.
|
||||||
FilterCreatureCard filter = new FilterCreatureCard("creature card of the chosen type");
|
FilterCreatureCard filter = new FilterCreatureCard("creature card of the chosen type");
|
||||||
filter.add(new ChosenSubtypePredicate(source.getSourceId()));
|
filter.add(new ChosenSubtypePredicate(source.getSourceId()));
|
||||||
String message = "Reveal the top card of your library and put that card into your hand?";
|
String message = "Reveal the top card of your library and put that card into your hand?";
|
||||||
if (card != null) {
|
if (card != null) {
|
||||||
if (filter.match(card, game) && controller.chooseUse(Outcome.Benefit, message, source, game)) {
|
if (filter.match(card, game) && controller.chooseUse(Outcome.Benefit, message, source, game)) {
|
||||||
controller.moveCards(card, Zone.HAND, source, game);
|
controller.moveCards(card, Zone.HAND, source, game);
|
||||||
controller.revealCards(sourceObject.getIdName() + " put into hand", cards, game);
|
controller.revealCards(sourceObject.getIdName() + " put into hand", cards, game);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,6 +53,7 @@ public class SpellsCostReductionAllEffect extends CostModificationEffectImpl {
|
||||||
private FilterCard filter;
|
private FilterCard filter;
|
||||||
private int amount;
|
private int amount;
|
||||||
private final boolean upTo;
|
private final boolean upTo;
|
||||||
|
private boolean onlyControlled;
|
||||||
|
|
||||||
public SpellsCostReductionAllEffect(int amount) {
|
public SpellsCostReductionAllEffect(int amount) {
|
||||||
this(new FilterCard("Spells"), amount);
|
this(new FilterCard("Spells"), amount);
|
||||||
|
@ -63,19 +64,24 @@ public class SpellsCostReductionAllEffect extends CostModificationEffectImpl {
|
||||||
}
|
}
|
||||||
|
|
||||||
public SpellsCostReductionAllEffect(FilterCard filter, int amount, boolean upTo) {
|
public SpellsCostReductionAllEffect(FilterCard filter, int amount, boolean upTo) {
|
||||||
|
this(filter, amount, upTo, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SpellsCostReductionAllEffect(FilterCard filter, int amount, boolean upTo, boolean onlyControlled) {
|
||||||
super(Duration.WhileOnBattlefield, Outcome.Benefit, CostModificationType.REDUCE_COST);
|
super(Duration.WhileOnBattlefield, Outcome.Benefit, CostModificationType.REDUCE_COST);
|
||||||
this.filter = filter;
|
this.filter = filter;
|
||||||
this.amount = amount;
|
this.amount = amount;
|
||||||
this.upTo = upTo;
|
this.upTo = upTo;
|
||||||
|
this.onlyControlled = onlyControlled;
|
||||||
this.staticText = filter.getMessage() + " cost " + (upTo ? "up to " : "") + '{' + amount + "} less to cast";
|
this.staticText = filter.getMessage() + " cost " + (upTo ? "up to " : "") + '{' + amount + "} less to cast";
|
||||||
}
|
}
|
||||||
|
|
||||||
protected SpellsCostReductionAllEffect(SpellsCostReductionAllEffect effect) {
|
protected SpellsCostReductionAllEffect(final SpellsCostReductionAllEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.filter = effect.filter;
|
this.filter = effect.filter;
|
||||||
this.amount = effect.amount;
|
this.amount = effect.amount;
|
||||||
this.upTo = effect.upTo;
|
this.upTo = effect.upTo;
|
||||||
|
this.onlyControlled = effect.onlyControlled;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -136,6 +142,9 @@ public class SpellsCostReductionAllEffect extends CostModificationEffectImpl {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean applies(Ability abilityToModify, Ability source, Game game) {
|
public boolean applies(Ability abilityToModify, Ability source, Game game) {
|
||||||
|
if (onlyControlled && abilityToModify.getControllerId().equals(source.getControllerId())) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (abilityToModify instanceof SpellAbility) {
|
if (abilityToModify instanceof SpellAbility) {
|
||||||
Spell spell = (Spell) game.getStack().getStackObject(abilityToModify.getId());
|
Spell spell = (Spell) game.getStack().getStackObject(abilityToModify.getId());
|
||||||
if (spell != null) {
|
if (spell != null) {
|
||||||
|
|
|
@ -19,7 +19,11 @@ import mage.game.Game;
|
||||||
public class SpellsCostReductionAllOfChosenSubtypeEffect extends SpellsCostReductionAllEffect {
|
public class SpellsCostReductionAllOfChosenSubtypeEffect extends SpellsCostReductionAllEffect {
|
||||||
|
|
||||||
public SpellsCostReductionAllOfChosenSubtypeEffect(FilterCard filter, int amount) {
|
public SpellsCostReductionAllOfChosenSubtypeEffect(FilterCard filter, int amount) {
|
||||||
super(filter, amount);
|
this(filter, amount, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SpellsCostReductionAllOfChosenSubtypeEffect(FilterCard filter, int amount, boolean onlyControlled) {
|
||||||
|
super(filter, amount, false, onlyControlled);
|
||||||
}
|
}
|
||||||
|
|
||||||
public SpellsCostReductionAllOfChosenSubtypeEffect(final SpellsCostReductionAllOfChosenSubtypeEffect effect) {
|
public SpellsCostReductionAllOfChosenSubtypeEffect(final SpellsCostReductionAllOfChosenSubtypeEffect effect) {
|
||||||
|
|
Loading…
Reference in a new issue