mirror of
https://github.com/correl/mage.git
synced 2025-04-04 17:00:13 -09:00
[CLB] Implement Minthara, Merciless Soul (#9972)
This commit is contained in:
parent
6a4ead88e2
commit
7172027cde
4 changed files with 165 additions and 9 deletions
Mage.Sets/src/mage
Mage/src/main/java/mage/abilities
91
Mage.Sets/src/mage/cards/m/MintharaMercilessSoul.java
Normal file
91
Mage.Sets/src/mage/cards/m/MintharaMercilessSoul.java
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
package mage.cards.m;
|
||||||
|
|
||||||
|
import mage.MageInt;
|
||||||
|
import mage.abilities.Ability;
|
||||||
|
import mage.abilities.common.BeginningOfEndStepTriggeredAbility;
|
||||||
|
import mage.abilities.common.SimpleStaticAbility;
|
||||||
|
import mage.abilities.condition.common.RevoltCondition;
|
||||||
|
import mage.abilities.dynamicvalue.DynamicValue;
|
||||||
|
import mage.abilities.dynamicvalue.common.StaticValue;
|
||||||
|
import mage.abilities.effects.Effect;
|
||||||
|
import mage.abilities.effects.common.continuous.BoostAllEffect;
|
||||||
|
import mage.abilities.effects.common.counter.AddCountersPlayersEffect;
|
||||||
|
import mage.abilities.keyword.WardAbility;
|
||||||
|
import mage.cards.CardImpl;
|
||||||
|
import mage.cards.CardSetInfo;
|
||||||
|
import mage.constants.*;
|
||||||
|
import mage.counters.CounterType;
|
||||||
|
import mage.filter.StaticFilters;
|
||||||
|
import mage.game.Game;
|
||||||
|
import mage.players.Player;
|
||||||
|
import mage.watchers.common.RevoltWatcher;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author TheElk801
|
||||||
|
*/
|
||||||
|
public final class MintharaMercilessSoul extends CardImpl {
|
||||||
|
|
||||||
|
public MintharaMercilessSoul(UUID ownerId, CardSetInfo setInfo) {
|
||||||
|
super(ownerId, setInfo, new CardType[]{CardType.CREATURE}, "{2}{W}{B}");
|
||||||
|
|
||||||
|
this.addSuperType(SuperType.LEGENDARY);
|
||||||
|
this.subtype.add(SubType.ELF);
|
||||||
|
this.subtype.add(SubType.CLERIC);
|
||||||
|
this.power = new MageInt(2);
|
||||||
|
this.toughness = new MageInt(2);
|
||||||
|
|
||||||
|
// Ward {X}, where X is the number of experience counters you have.
|
||||||
|
DynamicValue value = new MintharaMercilessSoulCount();
|
||||||
|
Ability ability = new WardAbility(value, "the number of experience counters you have");
|
||||||
|
this.addAbility(ability);
|
||||||
|
|
||||||
|
// At the beginning of your end step, if a permanent you controlled left the battlefield this turn, you get an experience counter.
|
||||||
|
this.addAbility(new BeginningOfEndStepTriggeredAbility(
|
||||||
|
new AddCountersPlayersEffect(CounterType.EXPERIENCE.createInstance(), TargetController.YOU),
|
||||||
|
TargetController.YOU, RevoltCondition.instance, false
|
||||||
|
), new RevoltWatcher());
|
||||||
|
|
||||||
|
// Creatures you control get +1/+0 for each experience counter you have.
|
||||||
|
this.addAbility(new SimpleStaticAbility(new BoostAllEffect(value, StaticValue.get(0),
|
||||||
|
Duration.WhileOnBattlefield, StaticFilters.FILTER_CONTROLLED_CREATURES, false)));
|
||||||
|
}
|
||||||
|
|
||||||
|
private MintharaMercilessSoul(final MintharaMercilessSoul card) {
|
||||||
|
super(card);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public MintharaMercilessSoul copy() {
|
||||||
|
return new MintharaMercilessSoul(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MintharaMercilessSoulCount implements DynamicValue {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int calculate(Game game, Ability sourceAbility, Effect effect) {
|
||||||
|
int amount = 0;
|
||||||
|
Player player = game.getPlayer(sourceAbility.getControllerId());
|
||||||
|
if (player != null) {
|
||||||
|
amount = player.getCounters().getCount(CounterType.EXPERIENCE);
|
||||||
|
}
|
||||||
|
return amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public MintharaMercilessSoulCount copy() {
|
||||||
|
return new MintharaMercilessSoulCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "1";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getMessage() {
|
||||||
|
return "experience counter you have";
|
||||||
|
}
|
||||||
|
}
|
|
@ -384,6 +384,7 @@ public final class CommanderLegendsBattleForBaldursGate extends ExpansionSet {
|
||||||
cards.add(new SetCardInfo("Mindcrank", 866, Rarity.UNCOMMON, mage.cards.m.Mindcrank.class));
|
cards.add(new SetCardInfo("Mindcrank", 866, Rarity.UNCOMMON, mage.cards.m.Mindcrank.class));
|
||||||
cards.add(new SetCardInfo("Minimus Containment", 34, Rarity.COMMON, mage.cards.m.MinimusContainment.class));
|
cards.add(new SetCardInfo("Minimus Containment", 34, Rarity.COMMON, mage.cards.m.MinimusContainment.class));
|
||||||
cards.add(new SetCardInfo("Minsc & Boo, Timeless Heroes", 285, Rarity.MYTHIC, mage.cards.m.MinscBooTimelessHeroes.class));
|
cards.add(new SetCardInfo("Minsc & Boo, Timeless Heroes", 285, Rarity.MYTHIC, mage.cards.m.MinscBooTimelessHeroes.class));
|
||||||
|
cards.add(new SetCardInfo("Minthara, Merciless Soul", 286, Rarity.UNCOMMON, mage.cards.m.MintharaMercilessSoul.class));
|
||||||
cards.add(new SetCardInfo("Mirror Entity", 701, Rarity.RARE, mage.cards.m.MirrorEntity.class));
|
cards.add(new SetCardInfo("Mirror Entity", 701, Rarity.RARE, mage.cards.m.MirrorEntity.class));
|
||||||
cards.add(new SetCardInfo("Mizzium Mortars", 803, Rarity.RARE, mage.cards.m.MizziumMortars.class));
|
cards.add(new SetCardInfo("Mizzium Mortars", 803, Rarity.RARE, mage.cards.m.MizziumMortars.class));
|
||||||
cards.add(new SetCardInfo("Mocking Doppelganger", 667, Rarity.RARE, mage.cards.m.MockingDoppelganger.class));
|
cards.add(new SetCardInfo("Mocking Doppelganger", 667, Rarity.RARE, mage.cards.m.MockingDoppelganger.class));
|
||||||
|
|
|
@ -9,7 +9,9 @@ import mage.constants.Duration;
|
||||||
import mage.constants.Layer;
|
import mage.constants.Layer;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
import mage.constants.SubLayer;
|
import mage.constants.SubLayer;
|
||||||
|
import mage.filter.FilterPermanent;
|
||||||
import mage.filter.StaticFilters;
|
import mage.filter.StaticFilters;
|
||||||
|
import mage.filter.common.FilterControlledCreaturePermanent;
|
||||||
import mage.filter.common.FilterCreaturePermanent;
|
import mage.filter.common.FilterCreaturePermanent;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
|
@ -26,7 +28,7 @@ public class BoostAllEffect extends ContinuousEffectImpl {
|
||||||
protected DynamicValue power;
|
protected DynamicValue power;
|
||||||
protected DynamicValue toughness;
|
protected DynamicValue toughness;
|
||||||
protected boolean excludeSource;
|
protected boolean excludeSource;
|
||||||
protected FilterCreaturePermanent filter;
|
protected FilterPermanent filter;
|
||||||
|
|
||||||
public BoostAllEffect(int power, int toughness, Duration duration) {
|
public BoostAllEffect(int power, int toughness, Duration duration) {
|
||||||
this(power, toughness, duration, false);
|
this(power, toughness, duration, false);
|
||||||
|
@ -62,6 +64,28 @@ public class BoostAllEffect extends ContinuousEffectImpl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public BoostAllEffect(int power, int toughness, Duration duration, FilterControlledCreaturePermanent filter, boolean excludeSource) {
|
||||||
|
this(StaticValue.get(power), StaticValue.get(toughness), duration, filter, excludeSource);
|
||||||
|
}
|
||||||
|
|
||||||
|
public BoostAllEffect(DynamicValue power, DynamicValue toughness, Duration duration, FilterControlledCreaturePermanent filter, boolean excludeSource) {
|
||||||
|
this(power, toughness, duration, filter, excludeSource, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public BoostAllEffect(DynamicValue power, DynamicValue toughness, Duration duration, FilterControlledCreaturePermanent filter, boolean excludeSource, String rule) {
|
||||||
|
super(duration, Layer.PTChangingEffects_7, SubLayer.ModifyPT_7c, CardUtil.getBoostOutcome(power, toughness));
|
||||||
|
this.power = power;
|
||||||
|
this.toughness = toughness;
|
||||||
|
this.filter = filter;
|
||||||
|
this.excludeSource = excludeSource;
|
||||||
|
|
||||||
|
if (rule == null || rule.isEmpty()) {
|
||||||
|
setText();
|
||||||
|
} else {
|
||||||
|
this.staticText = rule;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public BoostAllEffect(final BoostAllEffect effect) {
|
public BoostAllEffect(final BoostAllEffect effect) {
|
||||||
super(effect);
|
super(effect);
|
||||||
this.power = effect.power;
|
this.power = effect.power;
|
||||||
|
|
|
@ -3,6 +3,7 @@ package mage.abilities.keyword;
|
||||||
import mage.abilities.TriggeredAbilityImpl;
|
import mage.abilities.TriggeredAbilityImpl;
|
||||||
import mage.abilities.costs.Cost;
|
import mage.abilities.costs.Cost;
|
||||||
import mage.abilities.costs.mana.ManaCost;
|
import mage.abilities.costs.mana.ManaCost;
|
||||||
|
import mage.abilities.dynamicvalue.DynamicValue;
|
||||||
import mage.abilities.effects.common.CounterUnlessPaysEffect;
|
import mage.abilities.effects.common.CounterUnlessPaysEffect;
|
||||||
import mage.constants.Zone;
|
import mage.constants.Zone;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
|
@ -18,7 +19,10 @@ import mage.util.CardUtil;
|
||||||
public class WardAbility extends TriggeredAbilityImpl {
|
public class WardAbility extends TriggeredAbilityImpl {
|
||||||
|
|
||||||
private final Cost cost;
|
private final Cost cost;
|
||||||
|
private final DynamicValue genericMana;
|
||||||
|
|
||||||
private final boolean showAbilityHint;
|
private final boolean showAbilityHint;
|
||||||
|
private final String whereXIs;
|
||||||
|
|
||||||
public WardAbility(Cost cost) {
|
public WardAbility(Cost cost) {
|
||||||
this(cost, true);
|
this(cost, true);
|
||||||
|
@ -27,13 +31,34 @@ public class WardAbility extends TriggeredAbilityImpl {
|
||||||
public WardAbility(Cost cost, boolean showAbilityHint) {
|
public WardAbility(Cost cost, boolean showAbilityHint) {
|
||||||
super(Zone.BATTLEFIELD, new CounterUnlessPaysEffect(cost), false);
|
super(Zone.BATTLEFIELD, new CounterUnlessPaysEffect(cost), false);
|
||||||
this.cost = cost;
|
this.cost = cost;
|
||||||
|
this.genericMana = null;
|
||||||
this.showAbilityHint = showAbilityHint;
|
this.showAbilityHint = showAbilityHint;
|
||||||
|
this.whereXIs = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public WardAbility(DynamicValue genericMana) {
|
||||||
|
this(genericMana, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public WardAbility(DynamicValue genericMana, String whereXIs) {
|
||||||
|
super(Zone.BATTLEFIELD, new CounterUnlessPaysEffect(genericMana), false);
|
||||||
|
this.genericMana = genericMana;
|
||||||
|
this.whereXIs = whereXIs;
|
||||||
|
this.cost = null;
|
||||||
|
this.showAbilityHint = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private WardAbility(final WardAbility ability) {
|
private WardAbility(final WardAbility ability) {
|
||||||
super(ability);
|
super(ability);
|
||||||
|
if (ability.cost != null) {
|
||||||
this.cost = ability.cost.copy();
|
this.cost = ability.cost.copy();
|
||||||
|
this.genericMana = null;
|
||||||
|
} else {
|
||||||
|
this.genericMana = ability.genericMana.copy();
|
||||||
|
this.cost = null;
|
||||||
|
}
|
||||||
this.showAbilityHint = ability.showAbilityHint;
|
this.showAbilityHint = ability.showAbilityHint;
|
||||||
|
this.whereXIs = ability.whereXIs;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -75,21 +100,36 @@ public class WardAbility extends TriggeredAbilityImpl {
|
||||||
@Override
|
@Override
|
||||||
public String getRule() {
|
public String getRule() {
|
||||||
StringBuilder sb = new StringBuilder("ward");
|
StringBuilder sb = new StringBuilder("ward");
|
||||||
|
if (cost != null) {
|
||||||
if (cost instanceof ManaCost) {
|
if (cost instanceof ManaCost) {
|
||||||
sb.append(' ').append(cost.getText());
|
sb.append(' ').append(cost.getText());
|
||||||
} else {
|
} else {
|
||||||
sb.append("—").append(CardUtil.getTextWithFirstCharUpperCase(cost.getText())).append('.');
|
sb.append("—").append(CardUtil.getTextWithFirstCharUpperCase(cost.getText())).append('.');
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
sb.append(" {X}");
|
||||||
|
if (whereXIs != null) {
|
||||||
|
sb.append(", where X is ").append(whereXIs).append('.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (showAbilityHint) {
|
if (showAbilityHint) {
|
||||||
sb.append(" <i>(Whenever this creature becomes the target of a spell or ability an opponent controls, " +
|
sb.append(" <i>(Whenever this creature becomes the target of a spell or ability an opponent controls, " +
|
||||||
"counter it unless that player ");
|
"counter it unless that player ");
|
||||||
|
if (cost != null) {
|
||||||
if (cost instanceof ManaCost) {
|
if (cost instanceof ManaCost) {
|
||||||
sb.append("pays ").append(cost.getText());
|
sb.append("pays ").append(cost.getText());
|
||||||
} else {
|
} else {
|
||||||
sb.append(cost.getText().replace("pay ", "pays "));
|
sb.append(cost.getText().replace("pay ", "pays "));
|
||||||
}
|
}
|
||||||
sb.append(".)</i>");
|
sb.append(".)</i>");
|
||||||
|
} else {
|
||||||
|
sb.append("pays {X}");
|
||||||
|
if (whereXIs != null) {
|
||||||
|
sb.append(whereXIs);
|
||||||
|
}
|
||||||
|
sb.append(".)</i>");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
|
|
Loading…
Add table
Reference in a new issue