Some minor updates to the cards of the recently merged pull requests.

This commit is contained in:
LevelX2 2015-09-15 00:24:08 +02:00
parent 83230aebc2
commit 310627c924
10 changed files with 126 additions and 139 deletions

View file

@ -31,7 +31,6 @@ import java.util.UUID;
import mage.MageObject;
import mage.abilities.Abilities;
import mage.abilities.Ability;
import mage.abilities.ActivatedAbilityImpl;
import mage.abilities.common.SimpleActivatedAbility;
import mage.abilities.costs.Cost;
import mage.abilities.costs.common.TapSourceCost;
@ -39,6 +38,7 @@ import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.effects.common.UntapTargetEffect;
import mage.cards.Card;
import mage.cards.CardImpl;
import mage.constants.AbilityType;
import mage.constants.CardType;
import mage.constants.Rarity;
import mage.constants.Zone;
@ -63,7 +63,7 @@ public class MagewrightsStone extends CardImpl {
super(ownerId, 162, "Magewright's Stone", Rarity.UNCOMMON, new CardType[]{CardType.ARTIFACT}, "{2}");
this.expansionSetCode = "DIS";
// {1}, {tap}: Untap target creature that has an activated ability with {T} in its cost.
// {1}, {T}: Untap target creature that has an activated ability with {T} in its cost.
Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new UntapTargetEffect(), new ManaCostsImpl("{1}"));
ability.addCost(new TapSourceCost());
ability.addTarget(new TargetCreaturePermanent(filter));
@ -80,27 +80,19 @@ public class MagewrightsStone extends CardImpl {
}
}
/**
*
* @author North
*/
class HasAbilityWithTapSymbolPredicate implements Predicate<MageObject> {
public HasAbilityWithTapSymbolPredicate() {
}
@Override
public boolean apply(MageObject input, Game game) {
Abilities<Ability> abilities;
if (input instanceof Card){
abilities = ((Card)input).getAbilities(game);
if (input instanceof Card) {
abilities = ((Card) input).getAbilities(game);
} else {
abilities = input.getAbilities();
}
for (Ability ability : abilities) {
if((ability instanceof ActivatedAbilityImpl) && ability.getCosts().size() > 0){
if (ability.getAbilityType().equals(AbilityType.ACTIVATED) && !ability.getCosts().isEmpty()) {
for (Cost cost : ability.getCosts()) {
if (cost instanceof TapSourceCost) {
return true;
@ -113,6 +105,6 @@ class HasAbilityWithTapSymbolPredicate implements Predicate<MageObject> {
@Override
public String toString() {
return "Ability contains {T} symbol.";
return "activated ability with {T} in its cost";
}
}

View file

@ -1,7 +1,7 @@
package mage.sets.futuresight;
import java.util.UUID;
import mage.MageInt;
import mage.abilities.common.EntersBattlefieldTriggeredAbility;
import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.decorator.ConditionalTriggeredAbility;
@ -12,10 +12,9 @@ import mage.cards.CardImpl;
import mage.constants.CardType;
import mage.constants.Rarity;
import mage.filter.common.FilterCreatureCard;
import mage.MageInt;
import mage.target.common.TargetCardInGraveyard;
public class GraveScrabbler extends CardImpl{
public class GraveScrabbler extends CardImpl {
public GraveScrabbler(UUID ownerId) {
super(ownerId, 86, "Grave Scrabbler", Rarity.COMMON, new CardType[]{CardType.CREATURE}, "{3}{B}");
@ -36,7 +35,7 @@ public class GraveScrabbler extends CardImpl{
"When {this} enters the battlefield, if its madness cost was paid, you may return target creature card from a graveyard to its owner's hand."));
}
public GraveScrabbler(final GraveScrabbler card){
public GraveScrabbler(final GraveScrabbler card) {
super(card);
}

View file

@ -49,6 +49,7 @@ import mage.target.common.TargetCreaturePermanent;
* @author Leathios
*/
public class AegisOfTheMeek extends CardImpl {
private static final FilterCreaturePermanent filter = new FilterCreaturePermanent("1/1 creature");
static {
@ -60,7 +61,7 @@ public class AegisOfTheMeek extends CardImpl {
super(ownerId, 282, "Aegis of the Meek", Rarity.RARE, new CardType[]{CardType.ARTIFACT}, "{3}");
this.expansionSetCode = "ICE";
// {1}, {tap}: Target 1/1 creature gets +1/+2 until end of turn.
// {1}, {T}: Target 1/1 creature gets +1/+2 until end of turn.
Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD, new BoostTargetEffect(1, 2, Duration.EndOfTurn), new ManaCostsImpl("{1}"));
ability.addCost(new TapSourceCost());
ability.addTarget(new TargetCreaturePermanent(filter));

View file

@ -68,6 +68,7 @@ public class SoldeviMachinist extends CardImpl {
}
class SoldeviMachinistManaBuilder extends ConditionalManaBuilder {
@Override
public ConditionalMana build(Object... options) {
return new ArtifactCastConditionalMana(this.mana);

View file

@ -28,20 +28,20 @@
package mage.sets.onslaught;
import java.util.UUID;
import mage.MageInt;
import mage.abilities.Ability;
import mage.abilities.common.AttacksTriggeredAbility;
import mage.abilities.common.DealsCombatDamageToAPlayerTriggeredAbility;
import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.effects.Effect;
import mage.abilities.effects.common.LoseHalfLifeEffect;
import mage.abilities.effects.OneShotEffect;
import mage.abilities.effects.common.LoseHalfLifeEffect;
import mage.abilities.keyword.MorphAbility;
import mage.cards.Card;
import mage.cards.CardImpl;
import mage.constants.CardType;
import mage.constants.Rarity;
import mage.MageInt;
import mage.constants.Outcome;
import mage.constants.Rarity;
import mage.game.Game;
import mage.players.Player;
@ -49,10 +49,9 @@ import mage.players.Player;
*
* @author BijanT
*/
public class EbonbladeReaper extends CardImpl{
public class EbonbladeReaper extends CardImpl {
public EbonbladeReaper(UUID ownerId)
{
public EbonbladeReaper(UUID ownerId) {
super(ownerId, 141, "Ebonblade Reaper", Rarity.RARE, new CardType[]{CardType.CREATURE}, "{2}{B}");
this.expansionSetCode = "ONS";
this.subtype.add("Human");
@ -71,8 +70,7 @@ public class EbonbladeReaper extends CardImpl{
this.addAbility(new MorphAbility(this, new ManaCostsImpl<>("{3}{B}{B}")));
}
public EbonbladeReaper(final EbonbladeReaper card)
{
public EbonbladeReaper(final EbonbladeReaper card) {
super(card);
}
@ -82,17 +80,14 @@ public class EbonbladeReaper extends CardImpl{
}
}
class EbonbladeReaperEffect extends OneShotEffect
{
class EbonbladeReaperEffect extends OneShotEffect {
public EbonbladeReaperEffect()
{
public EbonbladeReaperEffect() {
super(Outcome.Damage);
this.staticText = "that player loses half his or her life, rounded up.";
this.staticText = "that player loses half his or her life, rounded up";
}
public EbonbladeReaperEffect(final EbonbladeReaperEffect effect)
{
public EbonbladeReaperEffect(final EbonbladeReaperEffect effect) {
super(effect);
}

View file

@ -31,11 +31,11 @@ import java.util.UUID;
import mage.MageInt;
import mage.ObjectColor;
import mage.abilities.Ability;
import mage.abilities.common.SimpleActivatedAbility;
import mage.abilities.costs.common.TapSourceCost;
import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.effects.common.continuous.GainAbilityTargetEffect;
import mage.abilities.common.SimpleActivatedAbility;
import mage.abilities.effects.common.PutPermanentOnBattlefieldEffect;
import mage.abilities.effects.common.continuous.GainAbilityTargetEffect;
import mage.abilities.keyword.ProtectionAbility;
import mage.cards.CardImpl;
import mage.constants.CardType;
@ -58,11 +58,11 @@ public class GoblinWizard extends CardImpl {
private static final FilterPermanentCard filter = new FilterPermanentCard("Goblin");
private static final FilterCard protectionFilter = new FilterCard("white");
private static final FilterPermanent goblinCard = new FilterPermanent("Goblin");
private static final FilterPermanent goblinPermanent = new FilterPermanent("Goblin");
static {
filter.add(new SubtypePredicate("Goblin"));
goblinCard.add(new SubtypePredicate("Goblin"));
goblinPermanent.add(new SubtypePredicate("Goblin"));
protectionFilter.add(new ColorPredicate(ObjectColor.WHITE));
}
@ -83,8 +83,9 @@ public class GoblinWizard extends CardImpl {
new TapSourceCost()));
// {R}: Target Goblin gains protection from white until end of turn.
Ability ability = new mage.abilities.common.SimpleActivatedAbility(Zone.BATTLEFIELD, new GainAbilityTargetEffect(new ProtectionAbility(protectionFilter), Duration.EndOfTurn), new ManaCostsImpl("{R}"));
Target target = new TargetPermanent(goblinCard);
Ability ability = new SimpleActivatedAbility(Zone.BATTLEFIELD,
new GainAbilityTargetEffect(new ProtectionAbility(protectionFilter), Duration.EndOfTurn), new ManaCostsImpl("{R}"));
Target target = new TargetPermanent(goblinPermanent);
ability.addTarget(target);
this.addAbility(ability);

View file

@ -54,7 +54,7 @@ public class LastDitchEffort extends CardImpl {
// Sacrifice any number of creatures. Last-Ditch Effort deals that much damage to target creature or player.
this.getSpellAbility().addEffect(new LastDitchEffortEffect());
this.getSpellAbility().addTarget(new TargetCreatureOrPlayer(1));
this.getSpellAbility().addTarget(new TargetCreatureOrPlayer());
}
public LastDitchEffort(final LastDitchEffort card) {
@ -71,7 +71,7 @@ class LastDitchEffortEffect extends OneShotEffect {
LastDitchEffortEffect() {
super(Outcome.Damage);
this.staticText = "Sacrifice any number of creatures. Last-Ditch Effort deals that much damage to target creature or player.";
this.staticText = "Sacrifice any number of creatures. {this} deals that much damage to target creature or player";
}
LastDitchEffortEffect(final LastDitchEffortEffect effect) {
@ -109,7 +109,6 @@ class LastDitchEffortEffect extends OneShotEffect {
if (opponent != null) {
opponent.damage(damage, source.getSourceId(), game, false, true);
}
return true;
}
return true;
}

View file

@ -13,7 +13,7 @@ public class LoseHalfLifeEffect extends OneShotEffect {
public LoseHalfLifeEffect() {
super(Outcome.LoseLife);
staticText = "You lose half your life, rounded up";
staticText = "you lose half your life, rounded up";
}
public LoseHalfLifeEffect(final LoseHalfLifeEffect effect) {

View file

@ -24,26 +24,29 @@ import mage.players.Player;
*
* 702.33a. Madness is a keyword that represents two abilities.
*
* The first is a static ability that functions while the card with madness is in a player's hand.
* The second is a triggered ability that functions when the first ability is applied.
* The first is a static ability that functions while the card with madness is
* in a player's hand. The second is a triggered ability that functions when the
* first ability is applied.
*
* "Madness [cost]" means "If a player would discard this card, that player discards it, but may exile it instead of putting it into his or her graveyard" and
* "When this card is exiled this way, its owner may cast it by paying [cost] rather than paying its mana cost.
* If that player doesn't, he or she puts this card into his or her graveyard.
* "Madness [cost]" means "If a player would discard this card, that player
* discards it, but may exile it instead of putting it into his or her
* graveyard" and "When this card is exiled this way, its owner may cast it by
* paying [cost] rather than paying its mana cost. If that player doesn't, he or
* she puts this card into his or her graveyard.
*
* 702.33b. Casting a spell using its madness ability follows the rules for paying alternative costs in rules 601.2b and 601.2e-g.
* 702.33b. Casting a spell using its madness ability follows the rules for
* paying alternative costs in rules 601.2b and 601.2e-g.
*
* @author LevelX2
*/
public class MadnessAbility extends StaticAbility {
private String rule;
@SuppressWarnings("unchecked")
public MadnessAbility(Card card, ManaCosts madnessCost) {
super(Zone.HAND, new MadnessReplacementEffect((ManaCosts<ManaCost>)madnessCost));
addSubAbility(new MadnessTriggeredAbility((ManaCosts<ManaCost>)madnessCost));
super(Zone.HAND, new MadnessReplacementEffect((ManaCosts<ManaCost>) madnessCost));
addSubAbility(new MadnessTriggeredAbility((ManaCosts<ManaCost>) madnessCost));
rule = "Madness " + madnessCost.getText() + " <i>(If you discard this card, you may cast it for its madness cost instead of putting it into your graveyard.)<i/>";
}
@ -56,8 +59,7 @@ public class MadnessAbility extends StaticAbility {
return new MadnessAbility(this);
}
public static Condition GetCondition()
{
public static Condition GetCondition() {
return MadnessCondition.getInstance();
}
@ -67,7 +69,6 @@ public class MadnessAbility extends StaticAbility {
}
}
class MadnessReplacementEffect extends ReplacementEffectImpl {
public MadnessReplacementEffect(ManaCosts<ManaCost> madnessCost) {
@ -97,7 +98,7 @@ class MadnessReplacementEffect extends ReplacementEffectImpl {
if (card != null) {
if (controller.chooseUse(outcome, "Move " + card.getLogName() + " to exile to cast it by Madness?", source, game)) {
controller.moveCardToExileWithInfo(card, source.getSourceId(), "Madness", source.getSourceId(), game, ((ZoneChangeEvent) event).getFromZone(), true);
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.MADNESS_CARD_EXILED, card.getId(), card.getId(),controller.getId()));
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.MADNESS_CARD_EXILED, card.getId(), card.getId(), controller.getId()));
return true;
}
}
@ -112,21 +113,22 @@ class MadnessReplacementEffect extends ReplacementEffectImpl {
@Override
public boolean applies(GameEvent event, Ability source, Game game) {
return event.getTargetId().equals(source.getSourceId()) &&
((ZoneChangeEvent) event).getFromZone() == Zone.HAND && ((ZoneChangeEvent) event).getToZone() == Zone.GRAVEYARD;
return event.getTargetId().equals(source.getSourceId())
&& ((ZoneChangeEvent) event).getFromZone() == Zone.HAND && ((ZoneChangeEvent) event).getToZone() == Zone.GRAVEYARD;
}
}
/**
* Checks for the MADNESS_CARD_EXILED event to ask the player
* if he wants to cast the card by it's Madness costs.
* If not, the card goes to the graveyard.
* Checks for the MADNESS_CARD_EXILED event to ask the player if he wants to
* cast the card by it's Madness costs. If not, the card goes to the graveyard.
*/
class MadnessTriggeredAbility extends TriggeredAbilityImpl {
//This array holds the Id's of all of the cards that activated madness
private static ArrayList<UUID> activatedIds = new ArrayList<UUID>();
MadnessTriggeredAbility(ManaCosts<ManaCost> madnessCost ) {
private static ArrayList<UUID> activatedIds = new ArrayList<>();
MadnessTriggeredAbility(ManaCosts<ManaCost> madnessCost) {
super(Zone.EXILED, new MadnessCastEffect(madnessCost), true);
this.setRuleVisible(false);
}
@ -168,13 +170,10 @@ class MadnessTriggeredAbility extends TriggeredAbilityImpl {
}
@Override
public boolean isActivated()
{
public boolean isActivated() {
//Look through the list of activated Ids and see if the current source's Id is one of them
for(UUID currentId : activatedIds)
{
if(currentId.equals(getSourceId()))
{
for (UUID currentId : activatedIds) {
if (currentId.equals(getSourceId())) {
//Remove the current source from the list, so if the card is somehow recast without
//paying the madness cost, this will return false
activatedIds.remove(currentId);