Improved rule text generation of flashback ability. Fixed text bug of Dread Return.

This commit is contained in:
LevelX2 2013-04-14 01:23:12 +02:00
parent 590cebd8bd
commit 0be107359d
3 changed files with 13 additions and 9 deletions

View file

@ -42,6 +42,7 @@ import mage.cards.CardImpl;
import mage.cards.repository.CardRepository; import mage.cards.repository.CardRepository;
import mage.choices.Choice; import mage.choices.Choice;
import mage.choices.ChoiceImpl; import mage.choices.ChoiceImpl;
import mage.filter.common.FilterControlledCreaturePermanent;
import mage.game.Game; import mage.game.Game;
import mage.players.Player; import mage.players.Player;
import mage.target.TargetPlayer; import mage.target.TargetPlayer;
@ -63,7 +64,7 @@ public class CabalTherapy extends CardImpl<CabalTherapy> {
this.getSpellAbility().addTarget(new TargetPlayer()); this.getSpellAbility().addTarget(new TargetPlayer());
this.getSpellAbility().addEffect(new CabalTherapyEffect()); this.getSpellAbility().addEffect(new CabalTherapyEffect());
// Flashback-Sacrifice a creature. // Flashback-Sacrifice a creature.
this.addAbility(new FlashbackAbility(new SacrificeTargetCost(new TargetControlledCreaturePermanent(1)), TimingRule.SORCERY)); this.addAbility(new FlashbackAbility(new SacrificeTargetCost(new TargetControlledCreaturePermanent(1,1,new FilterControlledCreaturePermanent("a creature"), true)), TimingRule.SORCERY));
} }
public CabalTherapy(final CabalTherapy card) { public CabalTherapy(final CabalTherapy card) {
@ -80,7 +81,7 @@ class CabalTherapyEffect extends OneShotEffect<CabalTherapyEffect> {
public CabalTherapyEffect() { public CabalTherapyEffect() {
super(Outcome.Exile); super(Outcome.Exile);
staticText = "Name a nonland card. Search target player's hand for all cards with that name and discard them."; staticText = "Name a nonland card. Search target player's hand for all cards with that name and discard them";
} }
public CabalTherapyEffect(final CabalTherapyEffect effect) { public CabalTherapyEffect(final CabalTherapyEffect effect) {

View file

@ -35,6 +35,7 @@ import mage.abilities.costs.common.SacrificeTargetCost;
import mage.abilities.effects.common.ReturnFromGraveyardToBattlefieldTargetEffect; import mage.abilities.effects.common.ReturnFromGraveyardToBattlefieldTargetEffect;
import mage.abilities.keyword.FlashbackAbility; import mage.abilities.keyword.FlashbackAbility;
import mage.cards.CardImpl; import mage.cards.CardImpl;
import mage.filter.common.FilterControlledCreaturePermanent;
import mage.filter.common.FilterCreatureCard; import mage.filter.common.FilterCreatureCard;
import mage.target.common.TargetCardInYourGraveyard; import mage.target.common.TargetCardInYourGraveyard;
import mage.target.common.TargetControlledCreaturePermanent; import mage.target.common.TargetControlledCreaturePermanent;
@ -55,7 +56,7 @@ public class DreadReturn extends CardImpl<DreadReturn> {
this.getSpellAbility().addEffect(new ReturnFromGraveyardToBattlefieldTargetEffect()); this.getSpellAbility().addEffect(new ReturnFromGraveyardToBattlefieldTargetEffect());
this.getSpellAbility().addTarget(new TargetCardInYourGraveyard(new FilterCreatureCard("creature card from your graveyard"))); this.getSpellAbility().addTarget(new TargetCardInYourGraveyard(new FilterCreatureCard("creature card from your graveyard")));
// Flashback-Sacrifice three creatures. // Flashback-Sacrifice three creatures.
this.addAbility(new FlashbackAbility(new SacrificeTargetCost(new TargetControlledCreaturePermanent(3)), TimingRule.SORCERY)); this.addAbility(new FlashbackAbility(new SacrificeTargetCost(new TargetControlledCreaturePermanent(3,3,new FilterControlledCreaturePermanent("three creatures"),true,true)), TimingRule.SORCERY));
} }
public DreadReturn(final DreadReturn card) { public DreadReturn(final DreadReturn card) {

View file

@ -67,18 +67,20 @@ public class FlashbackAbility extends /*SpellAbility*/ ActivatedAbilityImpl<Flas
@Override @Override
public String getRule() { public String getRule() {
StringBuilder sbRule = new StringBuilder("Flashback "); StringBuilder sbRule = new StringBuilder("Flashback");
boolean first = true; if (costs.size() > 0) {
sbRule.append("--");
} else {
sbRule.append(" ");
}
if (manaCosts.size() > 0) { if (manaCosts.size() > 0) {
sbRule.append(manaCosts.getText()); sbRule.append(manaCosts.getText());
first = false;
} }
if (costs.size() > 0) { if (costs.size() > 0) {
if (first) {
sbRule.append(",");
}
sbRule.append(costs.getText()); sbRule.append(costs.getText());
sbRule.append(".");
} }
sbRule.append(" <i>(You may cast this card from your graveyard for its flashback cost. Then exile it.)</i>");
return sbRule.toString(); return sbRule.toString();
} }
} }