From 3d989b24ac782effaacc2d58976a39dc284b7c8d Mon Sep 17 00:00:00 2001 From: Erik Date: Sat, 15 Aug 2020 16:55:59 -0400 Subject: [PATCH] Text corrections from issue #6654 (WIP) (#6707) * Collective restraint typo fix * set text for EndlessSwarm. Add starts with vowel cond case to CountersSourceEffect * Teferi's Curse, added text option to GainAbilityAttachEffect * added set text to several cards. Implement reviewer suggestions in GainAbilityAttachedEffect * Remove period from rule text (undo my lazy coding fix) --- Mage.Sets/src/mage/cards/a/AngelOfRenewal.java | 2 +- Mage.Sets/src/mage/cards/b/BenedictionOfMoons.java | 4 ++-- Mage.Sets/src/mage/cards/c/CollectiveRestraint.java | 2 +- Mage.Sets/src/mage/cards/d/DwarvenPriest.java | 2 +- Mage.Sets/src/mage/cards/e/EndlessSwarm.java | 4 ++-- Mage.Sets/src/mage/cards/t/TeferisCurse.java | 8 ++------ .../common/continuous/GainAbilityAttachedEffect.java | 11 +++++++++-- .../common/counter/AddCountersSourceEffect.java | 7 ++++++- 8 files changed, 24 insertions(+), 16 deletions(-) diff --git a/Mage.Sets/src/mage/cards/a/AngelOfRenewal.java b/Mage.Sets/src/mage/cards/a/AngelOfRenewal.java index 09c42722ee..2df6065b77 100644 --- a/Mage.Sets/src/mage/cards/a/AngelOfRenewal.java +++ b/Mage.Sets/src/mage/cards/a/AngelOfRenewal.java @@ -27,7 +27,7 @@ public final class AngelOfRenewal extends CardImpl { // Flying this.addAbility(FlyingAbility.getInstance()); // When Angel of Renewal enters the battlefield, you gain 1 life for each creature you control. - this.addAbility(new EntersBattlefieldTriggeredAbility(new GainLifeEffect(CreaturesYouControlCount.instance))); + this.addAbility(new EntersBattlefieldTriggeredAbility(new GainLifeEffect(CreaturesYouControlCount.instance).setText("you gain 1 life for each creature you control"))); } public AngelOfRenewal(final AngelOfRenewal card) { diff --git a/Mage.Sets/src/mage/cards/b/BenedictionOfMoons.java b/Mage.Sets/src/mage/cards/b/BenedictionOfMoons.java index c24a5b34a2..a03d0fca72 100644 --- a/Mage.Sets/src/mage/cards/b/BenedictionOfMoons.java +++ b/Mage.Sets/src/mage/cards/b/BenedictionOfMoons.java @@ -22,11 +22,11 @@ public final class BenedictionOfMoons extends CardImpl { super(ownerId, setInfo, new CardType[]{CardType.SORCERY}, "{W}"); // You gain 1 life for each player. - this.getSpellAbility().addEffect(new GainLifeEffect(new PlayerCount())); + this.getSpellAbility().addEffect(new GainLifeEffect(new PlayerCount()).setText("you gain 1 life for each player")); // Haunt // When the creature Benediction of Moons haunts dies, you gain 1 life for each player. - this.addAbility(new HauntAbility(this, new GainLifeEffect(new PlayerCount()))); + this.addAbility(new HauntAbility(this, new GainLifeEffect(new PlayerCount()).setText("you gain 1 life for each player"))); } diff --git a/Mage.Sets/src/mage/cards/c/CollectiveRestraint.java b/Mage.Sets/src/mage/cards/c/CollectiveRestraint.java index 3cb3e18e16..bfefb14e7a 100644 --- a/Mage.Sets/src/mage/cards/c/CollectiveRestraint.java +++ b/Mage.Sets/src/mage/cards/c/CollectiveRestraint.java @@ -46,7 +46,7 @@ class CollectiveRestraintPayManaToAttackAllEffect extends CantAttackYouUnlessPay CollectiveRestraintPayManaToAttackAllEffect() { super(null, false); - staticText = "Creatures can't attack you unless their controller pays {X} for each creature they control that's attacking you, where X is the number of basic land types you control."; + staticText = "Creatures can't attack you unless their controller pays {X} for each creature they control that's attacking you, where X is the number of basic land types among lands you control."; } CollectiveRestraintPayManaToAttackAllEffect(CollectiveRestraintPayManaToAttackAllEffect effect) { diff --git a/Mage.Sets/src/mage/cards/d/DwarvenPriest.java b/Mage.Sets/src/mage/cards/d/DwarvenPriest.java index edf1d6dece..2576ccb6fc 100644 --- a/Mage.Sets/src/mage/cards/d/DwarvenPriest.java +++ b/Mage.Sets/src/mage/cards/d/DwarvenPriest.java @@ -25,7 +25,7 @@ public final class DwarvenPriest extends CardImpl { this.toughness = new MageInt(4); // When Dwarven Priest enters the battlefield, you gain 1 life for each creature you control. - this.addAbility(new EntersBattlefieldTriggeredAbility(new GainLifeEffect(CreaturesYouControlCount.instance))); + this.addAbility(new EntersBattlefieldTriggeredAbility(new GainLifeEffect(CreaturesYouControlCount.instance).setText("you gain 1 life for each creature you control"))); } public DwarvenPriest(final DwarvenPriest card) { diff --git a/Mage.Sets/src/mage/cards/e/EndlessSwarm.java b/Mage.Sets/src/mage/cards/e/EndlessSwarm.java index a33c408463..cdd5fcb83b 100644 --- a/Mage.Sets/src/mage/cards/e/EndlessSwarm.java +++ b/Mage.Sets/src/mage/cards/e/EndlessSwarm.java @@ -22,8 +22,8 @@ public final class EndlessSwarm extends CardImpl { // Create a 1/1 green Snake creature token for each card in your hand. - this.getSpellAbility().addEffect(new CreateTokenEffect(new SnakeToken(), CardsInControllerHandCount.instance)); - + this.getSpellAbility().addEffect(new CreateTokenEffect(new SnakeToken(), CardsInControllerHandCount.instance).setText("create a 1/1 green Snake creature token for each card in your hand")); + // Epic this.getSpellAbility().addEffect(new EpicEffect()); diff --git a/Mage.Sets/src/mage/cards/t/TeferisCurse.java b/Mage.Sets/src/mage/cards/t/TeferisCurse.java index 8b78a63ccb..8b11d07580 100644 --- a/Mage.Sets/src/mage/cards/t/TeferisCurse.java +++ b/Mage.Sets/src/mage/cards/t/TeferisCurse.java @@ -10,11 +10,7 @@ import mage.abilities.keyword.EnchantAbility; import mage.abilities.keyword.PhasingAbility; import mage.cards.CardImpl; import mage.cards.CardSetInfo; -import mage.constants.AttachmentType; -import mage.constants.CardType; -import mage.constants.SubType; -import mage.constants.Outcome; -import mage.constants.Zone; +import mage.constants.*; import mage.filter.FilterPermanent; import mage.filter.predicate.Predicates; import mage.target.TargetPermanent; @@ -45,7 +41,7 @@ public final class TeferisCurse extends CardImpl { this.addAbility(ability); // Enchanted permanent has phasing. - this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new GainAbilityAttachedEffect(PhasingAbility.getInstance(), AttachmentType.AURA))); + this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new GainAbilityAttachedEffect(PhasingAbility.getInstance(), AttachmentType.AURA, Duration.WhileOnBattlefield, null, "permanent"))); } public TeferisCurse(final TeferisCurse card) { diff --git a/Mage/src/main/java/mage/abilities/effects/common/continuous/GainAbilityAttachedEffect.java b/Mage/src/main/java/mage/abilities/effects/common/continuous/GainAbilityAttachedEffect.java index 959f3cddd5..3eb23d9a7b 100644 --- a/Mage/src/main/java/mage/abilities/effects/common/continuous/GainAbilityAttachedEffect.java +++ b/Mage/src/main/java/mage/abilities/effects/common/continuous/GainAbilityAttachedEffect.java @@ -15,6 +15,7 @@ public class GainAbilityAttachedEffect extends ContinuousEffectImpl { protected Ability ability; protected AttachmentType attachmentType; protected boolean independentEffect; + protected String targetObjectName; public GainAbilityAttachedEffect(Ability ability, AttachmentType attachmentType) { this(ability, attachmentType, Duration.WhileOnBattlefield); @@ -25,7 +26,12 @@ public class GainAbilityAttachedEffect extends ContinuousEffectImpl { } public GainAbilityAttachedEffect(Ability ability, AttachmentType attachmentType, Duration duration, String rule) { + this(ability, attachmentType, duration, rule, "creature"); + } + + public GainAbilityAttachedEffect(Ability ability, AttachmentType attachmentType, Duration duration, String rule, String targetObjectName) { super(duration, Layer.AbilityAddingRemovingEffects_6, SubLayer.NA, Outcome.AddAbility); + this.targetObjectName = targetObjectName; this.ability = ability; this.attachmentType = attachmentType; switch (duration) { @@ -54,6 +60,7 @@ public class GainAbilityAttachedEffect extends ContinuousEffectImpl { ability.newId(); // This is needed if the effect is copied e.g. by a clone so the ability can be added multiple times to permanents this.attachmentType = effect.attachmentType; this.independentEffect = effect.independentEffect; + this.targetObjectName = effect.targetObjectName; } @Override @@ -96,13 +103,13 @@ public class GainAbilityAttachedEffect extends ContinuousEffectImpl { private void setText() { StringBuilder sb = new StringBuilder(); sb.append(attachmentType.verb()); - sb.append(" creature "); + sb.append(" " + targetObjectName + " "); if (duration == Duration.WhileOnBattlefield) { sb.append("has "); } else { sb.append("gains "); } - sb.append(ability.getRule("this creature")); + sb.append(ability.getRule("this " + targetObjectName)); if (!duration.toString().isEmpty()) { sb.append(' ').append(duration.toString()); } diff --git a/Mage/src/main/java/mage/abilities/effects/common/counter/AddCountersSourceEffect.java b/Mage/src/main/java/mage/abilities/effects/common/counter/AddCountersSourceEffect.java index 00c174f97b..8bf7fc269c 100644 --- a/Mage/src/main/java/mage/abilities/effects/common/counter/AddCountersSourceEffect.java +++ b/Mage/src/main/java/mage/abilities/effects/common/counter/AddCountersSourceEffect.java @@ -135,7 +135,12 @@ public class AddCountersSourceEffect extends OneShotEffect { } else if (amount.toString().equals("X") && amount.getMessage().isEmpty()) { sb.append("X "); } else { - sb.append("a "); + //if counter name starts with a vowel use 'an' instead of 'a' + if ("aeiou".indexOf(counter.getName().toLowerCase(Locale.ENGLISH).charAt(0)) >= 0 ){ + sb.append("an "); + } else { + sb.append("a "); + } plural = false; } sb.append(counter.getName().toLowerCase(Locale.ENGLISH)).append(" counter");