fix #12657 with common class, add test

This commit is contained in:
xenohedron 2024-08-16 23:12:15 -04:00
parent b9b89d7dff
commit 4c069754a6
5 changed files with 126 additions and 142 deletions

View file

@ -0,0 +1,78 @@
package mage.abilities.common;
import mage.MageObjectReference;
import mage.abilities.TriggeredAbilityImpl;
import mage.abilities.effects.Effect;
import mage.constants.AttachmentType;
import mage.constants.SetTargetPointer;
import mage.constants.Zone;
import mage.filter.StaticFilters;
import mage.filter.common.FilterCreaturePermanent;
import mage.game.Game;
import mage.game.events.GameEvent;
import mage.game.events.ZoneChangeEvent;
import mage.game.permanent.Permanent;
import mage.target.targetpointer.FixedTarget;
import mage.util.CardUtil;
public class DealtDamageAttachedAndDiedTriggeredAbility extends TriggeredAbilityImpl {
private final FilterCreaturePermanent filter;
private final SetTargetPointer setTargetPointer;
public DealtDamageAttachedAndDiedTriggeredAbility(Effect effect, boolean optional) {
this(effect, optional, StaticFilters.FILTER_PERMANENT_CREATURE, SetTargetPointer.PERMANENT, AttachmentType.EQUIPMENT);
}
public DealtDamageAttachedAndDiedTriggeredAbility(Effect effect, boolean optional, FilterCreaturePermanent filter,
SetTargetPointer setTargetPointer, AttachmentType attachmentType) {
super(Zone.ALL, effect, optional);
this.filter = filter;
this.setTargetPointer = setTargetPointer;
setTriggerPhrase(getWhen() + CardUtil.addArticle(filter.getMessage()) + " dealt damage by "
+ CardUtil.getTextWithFirstCharLowerCase(attachmentType.verb()) +
" creature this turn dies, ");
}
protected DealtDamageAttachedAndDiedTriggeredAbility(final DealtDamageAttachedAndDiedTriggeredAbility ability) {
super(ability);
this.filter = ability.filter;
this.setTargetPointer = ability.setTargetPointer;
}
@Override
public DealtDamageAttachedAndDiedTriggeredAbility copy() {
return new DealtDamageAttachedAndDiedTriggeredAbility(this);
}
@Override
public boolean checkEventType(GameEvent event, Game game) {
return event.getType() == GameEvent.EventType.ZONE_CHANGE;
}
@Override
public boolean checkTrigger(GameEvent event, Game game) {
Permanent attachment = getSourcePermanentOrLKI(game);
ZoneChangeEvent zEvent = (ZoneChangeEvent) event;
if (attachment == null || !zEvent.isDiesEvent() || !filter.match(zEvent.getTarget(), getControllerId(), this, game)) {
return false;
}
MageObjectReference creatureMOR = new MageObjectReference(attachment.getAttachedTo(), attachment.getAttachedToZoneChangeCounter(), game);
if (zEvent.getTarget().getDealtDamageByThisTurn()
.stream()
.noneMatch(mor -> {
if (mor.equals(creatureMOR)) {
return true;
}
Permanent permanent = (Permanent) game.getLastKnownInformation(mor.getSourceId(),
Zone.BATTLEFIELD, mor.getZoneChangeCounter());
return permanent != null && permanent.getAttachments().contains(getSourceId());
})) {
return false;
}
if (this.setTargetPointer == SetTargetPointer.PERMANENT) {
getEffects().setTargetPointer(new FixedTarget(event.getTargetId(), game));
}
return true;
}
}