mirror of
https://github.com/correl/mage.git
synced 2024-11-16 03:00:12 +00:00
Changed MonstosityAbility to support X value.
This commit is contained in:
parent
1304069de3
commit
4129838e36
3 changed files with 53 additions and 17 deletions
|
@ -40,12 +40,15 @@ import mage.game.events.GameEvent.EventType;
|
||||||
*/
|
*/
|
||||||
public class BecomesMonstrousSourceTriggeredAbility extends TriggeredAbilityImpl<BecomesMonstrousSourceTriggeredAbility> {
|
public class BecomesMonstrousSourceTriggeredAbility extends TriggeredAbilityImpl<BecomesMonstrousSourceTriggeredAbility> {
|
||||||
|
|
||||||
|
private int monstrosityValue;
|
||||||
|
|
||||||
public BecomesMonstrousSourceTriggeredAbility(Effect effect) {
|
public BecomesMonstrousSourceTriggeredAbility(Effect effect) {
|
||||||
super(Zone.BATTLEFIELD, effect, false);
|
super(Zone.BATTLEFIELD, effect, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public BecomesMonstrousSourceTriggeredAbility(final BecomesMonstrousSourceTriggeredAbility ability) {
|
public BecomesMonstrousSourceTriggeredAbility(final BecomesMonstrousSourceTriggeredAbility ability) {
|
||||||
super(ability);
|
super(ability);
|
||||||
|
this.monstrosityValue = ability.monstrosityValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -56,11 +59,16 @@ public class BecomesMonstrousSourceTriggeredAbility extends TriggeredAbilityImpl
|
||||||
@Override
|
@Override
|
||||||
public boolean checkTrigger(GameEvent event, Game game) {
|
public boolean checkTrigger(GameEvent event, Game game) {
|
||||||
if (event.getType().equals(EventType.BECOMES_MONSTROUS) && event.getSourceId().equals(this.getSourceId())) {
|
if (event.getType().equals(EventType.BECOMES_MONSTROUS) && event.getSourceId().equals(this.getSourceId())) {
|
||||||
|
this.monstrosityValue = event.getAmount();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getMonstrosityValue() {
|
||||||
|
return monstrosityValue;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getRule() {
|
public String getRule() {
|
||||||
return "When {this} becomes monstrous, " + super.getRule();
|
return "When {this} becomes monstrous, " + super.getRule();
|
||||||
|
|
|
@ -73,7 +73,6 @@ public class CreateDelayedTriggeredAbilityEffect extends OneShotEffect<CreateDel
|
||||||
if (this.copyTargets) {
|
if (this.copyTargets) {
|
||||||
delayedAbility.getTargets().addAll(source.getTargets());
|
delayedAbility.getTargets().addAll(source.getTargets());
|
||||||
for(Effect effect : delayedAbility.getEffects()) {
|
for(Effect effect : delayedAbility.getEffects()) {
|
||||||
effect.setTargetPointer(targetPointer);
|
|
||||||
effect.getTargetPointer().init(game, source);
|
effect.getTargetPointer().init(game, source);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,10 +30,7 @@ package mage.abilities.keyword;
|
||||||
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.ActivatedAbilityImpl;
|
import mage.abilities.ActivatedAbilityImpl;
|
||||||
import mage.abilities.condition.InvertCondition;
|
|
||||||
import mage.abilities.condition.common.MonstrousCondition;
|
|
||||||
import mage.abilities.costs.mana.ManaCostsImpl;
|
import mage.abilities.costs.mana.ManaCostsImpl;
|
||||||
import mage.abilities.decorator.ConditionalOneShotEffect;
|
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.abilities.effects.common.counter.AddCountersSourceEffect;
|
import mage.abilities.effects.common.counter.AddCountersSourceEffect;
|
||||||
import mage.constants.Outcome;
|
import mage.constants.Outcome;
|
||||||
|
@ -44,8 +41,29 @@ import mage.game.events.GameEvent;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.util.CardUtil;
|
import mage.util.CardUtil;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Monstrosity
|
||||||
*
|
*
|
||||||
|
* 701.28. Monstrosity
|
||||||
|
*
|
||||||
|
* 701.28a “Monstrosity N” means “If this permanent isn’t monstrous, put N +1/+1 counters on it
|
||||||
|
* and it becomes monstrous.” Monstrous is a condition of that permanent that can be
|
||||||
|
* referred to by other abilities.
|
||||||
|
*
|
||||||
|
* 701.28b If a permanent’s ability instructs a player to “monstrosity X,” other abilities of
|
||||||
|
* that permanent may also refer to X. The value of X in those abilities is equal to
|
||||||
|
* the value of X as that permanent became monstrous.
|
||||||
|
*
|
||||||
|
* * Once a creature becomes monstrous, it can’t become monstrous again. If the creature
|
||||||
|
* is already monstrous when the monstrosity ability resolves, nothing happens.
|
||||||
|
*
|
||||||
|
* * Monstrous isn’t an ability that a creature has. It’s just something true about that
|
||||||
|
* creature. If the creature stops being a creature or loses its abilities, it will
|
||||||
|
* continue to be monstrous.
|
||||||
|
*
|
||||||
|
* * An ability that triggers when a creature becomes monstrous won’t trigger if that creature
|
||||||
|
* isn’t on the battlefield when its monstrosity ability resolves.
|
||||||
*
|
*
|
||||||
* @author LevelX2
|
* @author LevelX2
|
||||||
*/
|
*/
|
||||||
|
@ -54,15 +72,13 @@ public class MonstrosityAbility extends ActivatedAbilityImpl<MonstrosityAbility>
|
||||||
|
|
||||||
private int monstrosityValue;
|
private int monstrosityValue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param manaString
|
||||||
|
* @param monstrosityValue use Integer.MAX_VALUE for monstrosity X.
|
||||||
|
*/
|
||||||
public MonstrosityAbility(String manaString, int monstrosityValue) {
|
public MonstrosityAbility(String manaString, int monstrosityValue) {
|
||||||
super(Zone.BATTLEFIELD, new ConditionalOneShotEffect(
|
super(Zone.BATTLEFIELD, new BecomeMonstrousSourceEffect(),new ManaCostsImpl(manaString));
|
||||||
new AddCountersSourceEffect(CounterType.P1P1.createInstance(monstrosityValue)),
|
|
||||||
new InvertCondition(MonstrousCondition.getInstance()),
|
|
||||||
""), new ManaCostsImpl(manaString));
|
|
||||||
this.addEffect(new ConditionalOneShotEffect(
|
|
||||||
new BecomeMonstrousSourceEffect(),
|
|
||||||
new InvertCondition(MonstrousCondition.getInstance()),""));
|
|
||||||
|
|
||||||
this.monstrosityValue = monstrosityValue;
|
this.monstrosityValue = monstrosityValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,13 +94,20 @@ public class MonstrosityAbility extends ActivatedAbilityImpl<MonstrosityAbility>
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getRule() {
|
public String getRule() {
|
||||||
return new StringBuilder(manaCosts.getText()).append(": Monstrosity ").append(monstrosityValue)
|
return new StringBuilder(manaCosts.getText()).append(": Monstrosity ")
|
||||||
.append(". <i>(If this creature isn't monstrous, put ").append(CardUtil.numberToText(monstrosityValue))
|
.append(monstrosityValue == Integer.MAX_VALUE ? "X":monstrosityValue)
|
||||||
|
.append(". <i>(If this creature isn't monstrous, put ")
|
||||||
|
.append(monstrosityValue == Integer.MAX_VALUE ? "X":CardUtil.numberToText(monstrosityValue))
|
||||||
.append(" +1/+1 counters on it and it becomes monstrous.)</i>").toString();
|
.append(" +1/+1 counters on it and it becomes monstrous.)</i>").toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getMonstrosityValue() {
|
||||||
|
return monstrosityValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
class BecomeMonstrousSourceEffect extends OneShotEffect<BecomeMonstrousSourceEffect> {
|
class BecomeMonstrousSourceEffect extends OneShotEffect<BecomeMonstrousSourceEffect> {
|
||||||
|
|
||||||
public BecomeMonstrousSourceEffect() {
|
public BecomeMonstrousSourceEffect() {
|
||||||
|
@ -104,9 +127,15 @@ class BecomeMonstrousSourceEffect extends OneShotEffect<BecomeMonstrousSourceEff
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Permanent permanent = game.getPermanent(source.getSourceId());
|
Permanent permanent = game.getPermanent(source.getSourceId());
|
||||||
if (permanent != null) {
|
if (permanent != null && !permanent.isMonstrous() && source instanceof MonstrosityAbility) {
|
||||||
|
int monstrosityValue = ((MonstrosityAbility) source).getMonstrosityValue();
|
||||||
|
// handle monstrosity = X
|
||||||
|
if (monstrosityValue == Integer.MAX_VALUE) {
|
||||||
|
monstrosityValue = source.getManaCostsToPay().getX();
|
||||||
|
}
|
||||||
|
new AddCountersSourceEffect(CounterType.P1P1.createInstance(monstrosityValue)).apply(game, source);
|
||||||
permanent.setMonstrous(true);
|
permanent.setMonstrous(true);
|
||||||
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.BECOMES_MONSTROUS, source.getSourceId(), source.getSourceId(), source.getControllerId()));
|
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.BECOMES_MONSTROUS, source.getSourceId(), source.getSourceId(), source.getControllerId(), monstrosityValue));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in a new issue