mirror of
https://github.com/correl/mage.git
synced 2024-11-15 19:19:33 +00:00
Fixed wrong ability texts with duplicated card name (see #4335)
This commit is contained in:
parent
3d53d28f5e
commit
56949414d1
5 changed files with 95 additions and 6 deletions
|
@ -45,11 +45,17 @@ public class DamageAllEffect extends OneShotEffect {
|
||||||
|
|
||||||
private FilterPermanent filter;
|
private FilterPermanent filter;
|
||||||
private DynamicValue amount;
|
private DynamicValue amount;
|
||||||
|
private String sourceName = "{source}";
|
||||||
|
|
||||||
public DamageAllEffect(int amount, FilterPermanent filter) {
|
public DamageAllEffect(int amount, FilterPermanent filter) {
|
||||||
this(new StaticValue(amount), filter);
|
this(new StaticValue(amount), filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageAllEffect(int amount, String whoDealDamageName, FilterPermanent filter) {
|
||||||
|
this(new StaticValue(amount), filter);
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageAllEffect(DynamicValue amount, FilterPermanent filter) {
|
public DamageAllEffect(DynamicValue amount, FilterPermanent filter) {
|
||||||
super(Outcome.Damage);
|
super(Outcome.Damage);
|
||||||
this.amount = amount;
|
this.amount = amount;
|
||||||
|
@ -61,6 +67,7 @@ public class DamageAllEffect extends OneShotEffect {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.amount = effect.amount;
|
this.amount = effect.amount;
|
||||||
this.filter = effect.filter.copy();
|
this.filter = effect.filter.copy();
|
||||||
|
this.sourceName = effect.sourceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -79,7 +86,7 @@ public class DamageAllEffect extends OneShotEffect {
|
||||||
|
|
||||||
private void setText() {
|
private void setText() {
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
sb.append("{source} deals ").append(amount.toString()).append(" damage to each ").append(filter.getMessage());
|
sb.append(this.sourceName).append(" deals ").append(amount.toString()).append(" damage to each ").append(filter.getMessage());
|
||||||
String message = amount.getMessage();
|
String message = amount.getMessage();
|
||||||
if (!message.isEmpty()) {
|
if (!message.isEmpty()) {
|
||||||
if (amount.toString().equals("X")) {
|
if (amount.toString().equals("X")) {
|
||||||
|
@ -92,4 +99,11 @@ public class DamageAllEffect extends OneShotEffect {
|
||||||
staticText = sb.toString();
|
staticText = sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getSourceName() {
|
||||||
|
return sourceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSourceName(String sourceName) {
|
||||||
|
this.sourceName = sourceName;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,12 +45,18 @@ import mage.players.Player;
|
||||||
public class DamageAttachedEffect extends OneShotEffect {
|
public class DamageAttachedEffect extends OneShotEffect {
|
||||||
|
|
||||||
protected DynamicValue amount;
|
protected DynamicValue amount;
|
||||||
|
private String sourceName = "{source}";
|
||||||
|
|
||||||
public DamageAttachedEffect(int amount) {
|
public DamageAttachedEffect(int amount) {
|
||||||
super(Outcome.Damage);
|
super(Outcome.Damage);
|
||||||
this.amount = new StaticValue(amount);
|
this.amount = new StaticValue(amount);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageAttachedEffect(int amount, String whoDealDamageName) {
|
||||||
|
this(amount);
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageAttachedEffect(DynamicValue amount) {
|
public DamageAttachedEffect(DynamicValue amount) {
|
||||||
super(Outcome.Damage);
|
super(Outcome.Damage);
|
||||||
this.amount = amount;
|
this.amount = amount;
|
||||||
|
@ -59,6 +65,7 @@ public class DamageAttachedEffect extends OneShotEffect {
|
||||||
public DamageAttachedEffect(final DamageAttachedEffect effect) {
|
public DamageAttachedEffect(final DamageAttachedEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.amount = effect.amount;
|
this.amount = effect.amount;
|
||||||
|
this.sourceName = effect.sourceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -86,8 +93,16 @@ public class DamageAttachedEffect extends OneShotEffect {
|
||||||
return staticText;
|
return staticText;
|
||||||
}
|
}
|
||||||
if ("equal to".equals(amount.toString())) {
|
if ("equal to".equals(amount.toString())) {
|
||||||
return "{this} deals damage " + amount + " that creatures toughness to that creature";
|
return this.sourceName + " deals damage " + amount + " that creatures toughness to that creature";
|
||||||
}
|
}
|
||||||
return "{this} deals " + amount + " damage to that creature";
|
return this.sourceName + " deals " + amount + " damage to that creature";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSourceName() {
|
||||||
|
return sourceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSourceName(String sourceName) {
|
||||||
|
this.sourceName = sourceName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,11 +45,23 @@ public class DamageControllerEffect extends OneShotEffect {
|
||||||
|
|
||||||
protected DynamicValue amount;
|
protected DynamicValue amount;
|
||||||
protected boolean preventable;
|
protected boolean preventable;
|
||||||
|
private String sourceName = "{source}";
|
||||||
|
|
||||||
|
public DamageControllerEffect(int amount, String whoDealDamageName) {
|
||||||
|
this(amount, true, whoDealDamageName);
|
||||||
|
}
|
||||||
|
|
||||||
public DamageControllerEffect(int amount) {
|
public DamageControllerEffect(int amount) {
|
||||||
this(amount, true);
|
this(amount, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageControllerEffect(int amount, boolean preventable, String whoDealDamageName) {
|
||||||
|
super(Outcome.Damage);
|
||||||
|
this.amount = new StaticValue(amount);
|
||||||
|
this.preventable = preventable;
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageControllerEffect(int amount, boolean preventable) {
|
public DamageControllerEffect(int amount, boolean preventable) {
|
||||||
super(Outcome.Damage);
|
super(Outcome.Damage);
|
||||||
this.amount = new StaticValue(amount);
|
this.amount = new StaticValue(amount);
|
||||||
|
@ -74,6 +86,7 @@ public class DamageControllerEffect extends OneShotEffect {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.amount = effect.amount;
|
this.amount = effect.amount;
|
||||||
this.preventable = effect.preventable;
|
this.preventable = effect.preventable;
|
||||||
|
this.sourceName = effect.sourceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -98,7 +111,7 @@ public class DamageControllerEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
String message = amount.getMessage();
|
String message = amount.getMessage();
|
||||||
sb.append("{source} deals ");
|
sb.append(this.sourceName).append(" deals ");
|
||||||
if (message.isEmpty() || !message.equals("1")) {
|
if (message.isEmpty() || !message.equals("1")) {
|
||||||
sb.append(amount);
|
sb.append(amount);
|
||||||
}
|
}
|
||||||
|
@ -121,4 +134,11 @@ public class DamageControllerEffect extends OneShotEffect {
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getSourceName() {
|
||||||
|
return sourceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSourceName(String sourceName) {
|
||||||
|
this.sourceName = sourceName;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,11 +46,17 @@ import mage.target.Target;
|
||||||
public class DamageMultiEffect extends OneShotEffect {
|
public class DamageMultiEffect extends OneShotEffect {
|
||||||
|
|
||||||
protected DynamicValue amount;
|
protected DynamicValue amount;
|
||||||
|
private String sourceName = "{source}";
|
||||||
|
|
||||||
public DamageMultiEffect(int amount) {
|
public DamageMultiEffect(int amount) {
|
||||||
this(new StaticValue(amount));
|
this(new StaticValue(amount));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageMultiEffect(int amount, String whoDealDamageName) {
|
||||||
|
this(new StaticValue(amount));
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageMultiEffect(DynamicValue amount) {
|
public DamageMultiEffect(DynamicValue amount) {
|
||||||
super(Outcome.Damage);
|
super(Outcome.Damage);
|
||||||
this.amount = amount;
|
this.amount = amount;
|
||||||
|
@ -59,6 +65,7 @@ public class DamageMultiEffect extends OneShotEffect {
|
||||||
public DamageMultiEffect(final DamageMultiEffect effect) {
|
public DamageMultiEffect(final DamageMultiEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.amount = effect.amount;
|
this.amount = effect.amount;
|
||||||
|
this.sourceName = effect.sourceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -90,6 +97,14 @@ public class DamageMultiEffect extends OneShotEffect {
|
||||||
if (staticText != null && !staticText.isEmpty()) {
|
if (staticText != null && !staticText.isEmpty()) {
|
||||||
return staticText;
|
return staticText;
|
||||||
}
|
}
|
||||||
return "{source} deals " + amount.toString() + " damage divided as you choose among any number of target " + mode.getTargets().get(0).getTargetName();
|
return this.sourceName + " deals " + amount.toString() + " damage divided as you choose among any number of target " + mode.getTargets().get(0).getTargetName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSourceName() {
|
||||||
|
return sourceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSourceName(String sourceName) {
|
||||||
|
this.sourceName = sourceName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,11 +51,17 @@ public class DamageTargetEffect extends OneShotEffect {
|
||||||
protected boolean preventable;
|
protected boolean preventable;
|
||||||
protected String targetDescription;
|
protected String targetDescription;
|
||||||
protected boolean useOnlyTargetPointer;
|
protected boolean useOnlyTargetPointer;
|
||||||
|
protected String sourceName = "{source}";
|
||||||
|
|
||||||
public DamageTargetEffect(int amount) {
|
public DamageTargetEffect(int amount) {
|
||||||
this(new StaticValue(amount), true);
|
this(new StaticValue(amount), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageTargetEffect(int amount, String whoDealDamageName) {
|
||||||
|
this(new StaticValue(amount), true);
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageTargetEffect(int amount, boolean preventable) {
|
public DamageTargetEffect(int amount, boolean preventable) {
|
||||||
this(new StaticValue(amount), preventable);
|
this(new StaticValue(amount), preventable);
|
||||||
}
|
}
|
||||||
|
@ -64,10 +70,20 @@ public class DamageTargetEffect extends OneShotEffect {
|
||||||
this(new StaticValue(amount), preventable, targetDescription);
|
this(new StaticValue(amount), preventable, targetDescription);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageTargetEffect(int amount, boolean preventable, String targetDescription, String whoDealDamageName) {
|
||||||
|
this(new StaticValue(amount), preventable, targetDescription);
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageTargetEffect(DynamicValue amount) {
|
public DamageTargetEffect(DynamicValue amount) {
|
||||||
this(amount, true);
|
this(amount, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DamageTargetEffect(DynamicValue amount, String whoDealDamageName) {
|
||||||
|
this(amount, true);
|
||||||
|
this.sourceName = whoDealDamageName;
|
||||||
|
}
|
||||||
|
|
||||||
public DamageTargetEffect(DynamicValue amount, boolean preventable) {
|
public DamageTargetEffect(DynamicValue amount, boolean preventable) {
|
||||||
this(amount, preventable, "");
|
this(amount, preventable, "");
|
||||||
}
|
}
|
||||||
|
@ -102,6 +118,15 @@ public class DamageTargetEffect extends OneShotEffect {
|
||||||
this.preventable = effect.preventable;
|
this.preventable = effect.preventable;
|
||||||
this.targetDescription = effect.targetDescription;
|
this.targetDescription = effect.targetDescription;
|
||||||
this.useOnlyTargetPointer = effect.useOnlyTargetPointer;
|
this.useOnlyTargetPointer = effect.useOnlyTargetPointer;
|
||||||
|
this.sourceName = effect.sourceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSourceName() {
|
||||||
|
return sourceName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSourceName(String sourceName) {
|
||||||
|
this.sourceName = sourceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -149,7 +174,7 @@ public class DamageTargetEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
String message = amount.getMessage();
|
String message = amount.getMessage();
|
||||||
sb.append("{source} deals ");
|
sb.append(this.sourceName).append(" deals ");
|
||||||
if (message.isEmpty() || !message.equals("1")) {
|
if (message.isEmpty() || !message.equals("1")) {
|
||||||
sb.append(amount);
|
sb.append(amount);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue