mirror of
https://github.com/correl/mage.git
synced 2024-11-15 11:09:30 +00:00
reworked AttacksWithCreaturesTriggeredAbility implementation and text generation, fixed issues where it could trigger when nothing attacked
This commit is contained in:
parent
1843459e84
commit
600b4fe110
12 changed files with 49 additions and 78 deletions
|
@ -47,7 +47,7 @@ public final class AlibouAncientWitness extends CardImpl {
|
|||
Ability ability = new AttacksWithCreaturesTriggeredAbility(
|
||||
new AlibouAncientWitnessEffect(), 1,
|
||||
StaticFilters.FILTER_PERMANENTS_ARTIFACT_CREATURE
|
||||
);
|
||||
).setTriggerPhrase("Whenever one or more artifact creatures you control attack, ");
|
||||
ability.addTarget(new TargetAnyTarget());
|
||||
this.addAbility(ability.addHint(AlibouAncientWitnessEffect.getHint()));
|
||||
}
|
||||
|
|
|
@ -1,20 +1,20 @@
|
|||
package mage.cards.a;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
import mage.MageInt;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.common.AttacksWithCreaturesTriggeredAbility;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
import mage.constants.SubType;
|
||||
import mage.abilities.keyword.FlyingAbility;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Outcome;
|
||||
import mage.constants.SubType;
|
||||
import mage.game.Game;
|
||||
import mage.players.Player;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
* @author TheElk801
|
||||
*/
|
||||
|
@ -31,7 +31,9 @@ public final class AncestorDragon extends CardImpl {
|
|||
this.addAbility(FlyingAbility.getInstance());
|
||||
|
||||
// Whenever one or more creatures you control attack, you gain 1 life for each attacking creature.
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new AncestorDragonEffect(), 1));
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(
|
||||
new AncestorDragonEffect(), 1
|
||||
).setTriggerPhrase("Whenever one or more creatures you control attack, "));
|
||||
}
|
||||
|
||||
private AncestorDragon(final AncestorDragon card) {
|
||||
|
|
|
@ -37,7 +37,9 @@ public final class AngelicGuardian extends CardImpl {
|
|||
this.addAbility(FlyingAbility.getInstance());
|
||||
|
||||
// Whenever one or more creatures you control attack, they gain indestructible until end of turn
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new AngelicGuardianGainEffect(), 1));
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(
|
||||
new AngelicGuardianGainEffect(), 1
|
||||
).setTriggerPhrase("Whenever one or more creatures you control attack, "));
|
||||
}
|
||||
|
||||
private AngelicGuardian(final AngelicGuardian card) {
|
||||
|
|
|
@ -47,7 +47,7 @@ public final class KrydleOfBaldursGate extends CardImpl {
|
|||
// Whenever you attack, you may pay {2}. If you do, target creature can't be blocked this turn.
|
||||
ability = new AttacksWithCreaturesTriggeredAbility(new DoIfCostPaid(
|
||||
new CantBeBlockedTargetEffect(), new GenericManaCost(2)
|
||||
), 0);
|
||||
), 1);
|
||||
ability.addTarget(new TargetCreaturePermanent());
|
||||
this.addAbility(ability);
|
||||
}
|
||||
|
|
|
@ -68,7 +68,7 @@ public final class PaladinClass extends CardImpl {
|
|||
new BoostTargetEffect(xValue, xValue, Duration.EndOfTurn, true)
|
||||
.setText("until end of turn, target attacking creature " +
|
||||
"gets +1/+1 for each other attacking creature"),
|
||||
0
|
||||
1
|
||||
);
|
||||
ability.addEffect(new GainAbilityTargetEffect(
|
||||
DoubleStrikeAbility.getInstance(), Duration.EndOfTurn
|
||||
|
|
|
@ -1,25 +1,25 @@
|
|||
|
||||
package mage.cards.p;
|
||||
|
||||
import java.util.UUID;
|
||||
import mage.abilities.Ability;
|
||||
import mage.abilities.common.AttacksWithCreaturesTriggeredAbility;
|
||||
import mage.abilities.common.SimpleStaticAbility;
|
||||
import mage.abilities.condition.Condition;
|
||||
import mage.abilities.decorator.ConditionalContinuousEffect;
|
||||
import mage.abilities.effects.OneShotEffect;
|
||||
import mage.abilities.dynamicvalue.DynamicValue;
|
||||
import mage.abilities.dynamicvalue.common.AttackingCreatureCount;
|
||||
import mage.abilities.effects.common.GainLifeEffect;
|
||||
import mage.abilities.effects.common.continuous.BoostAllEffect;
|
||||
import mage.cards.CardImpl;
|
||||
import mage.cards.CardSetInfo;
|
||||
import mage.constants.CardType;
|
||||
import mage.constants.Duration;
|
||||
import mage.constants.Outcome;
|
||||
import mage.constants.TargetController;
|
||||
import mage.constants.Zone;
|
||||
import mage.filter.common.FilterCreaturePermanent;
|
||||
import mage.game.Game;
|
||||
import mage.players.Player;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
* @author jeffwadsworth
|
||||
*/
|
||||
|
@ -32,16 +32,20 @@ public final class PathOfBravery extends CardImpl {
|
|||
}
|
||||
|
||||
static final String rule = "As long as your life total is greater than or equal to your starting life total, creatures you control get +1/+1";
|
||||
private static final DynamicValue xValue = new AttackingCreatureCount();
|
||||
|
||||
public PathOfBravery(UUID ownerId, CardSetInfo setInfo) {
|
||||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{W}");
|
||||
|
||||
// As long as your life total is greater than or equal to your starting life total, creatures you control get +1/+1.
|
||||
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new ConditionalContinuousEffect(new BoostAllEffect(1, 1, Duration.WhileOnBattlefield, filter, true), LifeCondition.instance, rule)));
|
||||
this.addAbility(new SimpleStaticAbility(new ConditionalContinuousEffect(new BoostAllEffect(
|
||||
1, 1, Duration.WhileOnBattlefield, filter, true
|
||||
), LifeCondition.instance, rule)));
|
||||
|
||||
// Whenever one or more creatures you control attack, you gain life equal to the number of attacking creatures.
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new PathOfBraveryEffect(), 1));
|
||||
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new GainLifeEffect(
|
||||
xValue, "you gain life equal to the number of attacking creatures"
|
||||
), 1).setTriggerPhrase("Whenever one or more creatures you control attack, "));
|
||||
}
|
||||
|
||||
private PathOfBravery(final PathOfBravery card) {
|
||||
|
@ -67,34 +71,3 @@ enum LifeCondition implements Condition {
|
|||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
class PathOfBraveryEffect extends OneShotEffect {
|
||||
|
||||
private int attackers;
|
||||
|
||||
public PathOfBraveryEffect() {
|
||||
super(Outcome.GainLife);
|
||||
staticText = "you gain life equal to the number of attacking creatures";
|
||||
}
|
||||
|
||||
public PathOfBraveryEffect(final PathOfBraveryEffect effect) {
|
||||
super(effect);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PathOfBraveryEffect copy() {
|
||||
return new PathOfBraveryEffect(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean apply(Game game, Ability source) {
|
||||
Player you = game.getPlayer(source.getControllerId());
|
||||
attackers = game.getCombat().getAttackers().size();
|
||||
if (you != null) {
|
||||
you.gainLife(attackers, game, source);
|
||||
attackers = 0;
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -82,7 +82,7 @@ public final class PlarggDeanOfChaos extends ModalDoubleFacesCard {
|
|||
|
||||
// Whenever you attack, untap each creature you control, then tap any number of creatures you control.
|
||||
AttacksWithCreaturesTriggeredAbility augustaAbility = new AttacksWithCreaturesTriggeredAbility(
|
||||
new UntapAllControllerEffect(StaticFilters.FILTER_PERMANENT_CREATURES, "untap each creature you control"), 0);
|
||||
new UntapAllControllerEffect(StaticFilters.FILTER_PERMANENT_CREATURES, "untap each creature you control"), 1);
|
||||
augustaAbility.addEffect(new AugustaDeanOfOrderEffect().concatBy(", then"));
|
||||
this.getRightHalfCard().addAbility(augustaAbility);
|
||||
}
|
||||
|
|
|
@ -1,4 +1,3 @@
|
|||
|
||||
package mage.cards.r;
|
||||
|
||||
import mage.MageObject;
|
||||
|
@ -33,7 +32,6 @@ import java.util.UUID;
|
|||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author L_J
|
||||
*/
|
||||
public final class RagingRiver extends CardImpl {
|
||||
|
@ -42,7 +40,9 @@ public final class RagingRiver extends CardImpl {
|
|||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{R}{R}");
|
||||
|
||||
// Whenever one or more creatures you control attack, each defending player divides all creatures without flying they control into a "left" pile and a "right" pile. Then, for each attacking creature you control, choose "left" or "right." That creature can't be blocked this combat except by creatures with flying and creatures in a pile with the chosen label.
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new RagingRiverEffect(), 1));
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(
|
||||
new RagingRiverEffect(), 1
|
||||
).setTriggerPhrase("Whenever one or more creatures you control attack, "));
|
||||
}
|
||||
|
||||
private RagingRiver(final RagingRiver card) {
|
||||
|
@ -92,20 +92,19 @@ class RagingRiverEffect extends OneShotEffect {
|
|||
if (target.getTargets().contains(permanent.getId())) {
|
||||
left.add(permanent);
|
||||
leftLog.add(permanent);
|
||||
}
|
||||
else if (filterBlockers.match(permanent, source.getSourceId(), defenderId, game)) {
|
||||
} else if (filterBlockers.match(permanent, source.getSourceId(), defenderId, game)) {
|
||||
right.add(permanent);
|
||||
rightLog.add(permanent);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// it could be nice to invoke some graphic indicator of which creature is Left or Right in this spot
|
||||
StringBuilder sb = new StringBuilder("Left pile of ").append(defender.getLogName()).append(": ");
|
||||
sb.append(leftLog.stream().map(MageObject::getLogName).collect(Collectors.joining(", ")));
|
||||
|
||||
game.informPlayers(sb.toString());
|
||||
|
||||
|
||||
sb = new StringBuilder("Right pile of ").append(defender.getLogName()).append(": ");
|
||||
sb.append(rightLog.stream().map(MageObject::getLogName).collect(Collectors.joining(", ")));
|
||||
|
||||
|
@ -135,7 +134,7 @@ class RagingRiverEffect extends OneShotEffect {
|
|||
.filter(permanent -> permanent.isControlledBy(defender.getId()))
|
||||
.collect(Collectors.toList());
|
||||
|
||||
|
||||
|
||||
if (controller.choosePile(outcome, attacker.getName() + ": attacking " + defender.getName(), leftLog, rightLog, game)) {
|
||||
filter.add(Predicates.not(Predicates.or(new AbilityPredicate(FlyingAbility.class), new PermanentInListPredicate(left))));
|
||||
game.informPlayers(attacker.getLogName() + ": attacks left (" + defender.getLogName() + ")");
|
||||
|
|
|
@ -47,7 +47,7 @@ public final class RangerClass extends CardImpl {
|
|||
|
||||
// Whenever you attack, put a +1/+1 counter on target attacking creature.
|
||||
Ability ability = new AttacksWithCreaturesTriggeredAbility(
|
||||
new AddCountersTargetEffect(CounterType.P1P1.createInstance()), 0
|
||||
new AddCountersTargetEffect(CounterType.P1P1.createInstance()), 1
|
||||
);
|
||||
ability.addTarget(new TargetAttackingCreature());
|
||||
this.addAbility(new SimpleStaticAbility(new GainClassAbilitySourceEffect(ability, 2)));
|
||||
|
|
|
@ -29,7 +29,7 @@ public final class SparringRegimen extends CardImpl {
|
|||
|
||||
// Whenever you attack, put a +1/+1 counter on target attacking creature and untap it.
|
||||
Ability ability = new AttacksWithCreaturesTriggeredAbility(
|
||||
new AddCountersTargetEffect(CounterType.P1P1.createInstance()), 0
|
||||
new AddCountersTargetEffect(CounterType.P1P1.createInstance()), 1
|
||||
);
|
||||
ability.addEffect(new UntapTargetEffect().setText("and untap it"));
|
||||
ability.addTarget(new TargetAttackingCreature());
|
||||
|
|
|
@ -23,7 +23,7 @@ public final class ThoroughInvestigation extends CardImpl {
|
|||
super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{W}");
|
||||
|
||||
// Whenever you attack, investigate.
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new InvestigateEffect(), 0));
|
||||
this.addAbility(new AttacksWithCreaturesTriggeredAbility(new InvestigateEffect(), 1));
|
||||
|
||||
// Whenever you sacrifice a Clue, venture into the dungeon.
|
||||
this.addAbility(new SacrificePermanentTriggeredAbility(new VentureIntoTheDungeonEffect(), filter));
|
||||
|
|
|
@ -7,18 +7,15 @@ import mage.filter.StaticFilters;
|
|||
import mage.filter.common.FilterCreaturePermanent;
|
||||
import mage.game.Game;
|
||||
import mage.game.events.GameEvent;
|
||||
import mage.game.permanent.Permanent;
|
||||
import mage.util.CardUtil;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
/**
|
||||
* @author Styxo
|
||||
*/
|
||||
public class AttacksWithCreaturesTriggeredAbility extends TriggeredAbilityImpl {
|
||||
|
||||
private FilterCreaturePermanent filter;
|
||||
private int minAttackers;
|
||||
private final FilterCreaturePermanent filter;
|
||||
private final int minAttackers;
|
||||
|
||||
public AttacksWithCreaturesTriggeredAbility(Effect effect, int minAttackers) {
|
||||
this(effect, minAttackers, StaticFilters.FILTER_PERMANENT_CREATURES);
|
||||
|
@ -52,28 +49,26 @@ public class AttacksWithCreaturesTriggeredAbility extends TriggeredAbilityImpl {
|
|||
|
||||
@Override
|
||||
public boolean checkTrigger(GameEvent event, Game game) {
|
||||
if (game.getCombat().getAttackingPlayerId().equals(getControllerId())) {
|
||||
int attackerCount = 0;
|
||||
for (UUID attackerId : game.getCombat().getAttackers()) {
|
||||
Permanent attacker = game.getPermanent(attackerId);
|
||||
if (filter.match(attacker, game)) {
|
||||
attackerCount++;
|
||||
}
|
||||
}
|
||||
return attackerCount >= minAttackers;
|
||||
}
|
||||
return false;
|
||||
return isControlledBy(game.getCombat().getAttackingPlayerId())
|
||||
&& game
|
||||
.getCombat()
|
||||
.getAttackers()
|
||||
.stream()
|
||||
.map(game::getPermanent)
|
||||
.filter(permanent -> filter.match(permanent, sourceId, controllerId, game))
|
||||
.mapToInt(x -> 1).sum() > minAttackers;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getTriggerPhrase() {
|
||||
if (minAttackers == 0) {
|
||||
if (minAttackers == 1) {
|
||||
return "Whenever you attack, ";
|
||||
}
|
||||
StringBuilder sb = new StringBuilder("Whenever you attack with " + CardUtil.numberToText(minAttackers) + " or more ");
|
||||
StringBuilder sb = new StringBuilder("Whenever you attack with ");
|
||||
sb.append(CardUtil.numberToText(minAttackers));
|
||||
sb.append(" or more ");
|
||||
sb.append(filter.getMessage());
|
||||
sb.append(", ");
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue