mirror of
https://github.com/Card-Forge/forge.git
synced 2025-11-16 10:48:00 +00:00
- Fixed incorrect remembered objects in delayed triggers (Necropotencenow draws one card for each of its delayed triggers). More cards will be converted
This commit is contained in:
@@ -173,6 +173,14 @@ public class AbilityUtils {
|
|||||||
cards.add(game.getCardState((Card) o));
|
cards.add(game.getCardState((Card) o));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (defined.equals("DelayTriggerRemembered")) {
|
||||||
|
if (sa.isTrigger()) {
|
||||||
|
for (Object o : sa.getTriggerRemembered()) {
|
||||||
|
if (o instanceof Card) {
|
||||||
|
cards.add(game.getCardState((Card) o));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
} else if (defined.equals("FirstRemembered")) {
|
} else if (defined.equals("FirstRemembered")) {
|
||||||
Object o = Iterables.getFirst(hostCard.getRemembered(), null);
|
Object o = Iterables.getFirst(hostCard.getRemembered(), null);
|
||||||
if (o != null && o instanceof Card) {
|
if (o != null && o instanceof Card) {
|
||||||
@@ -822,6 +830,15 @@ public class AbilityUtils {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (defined.equals("DelayTriggerRemembered")) {
|
||||||
|
if (sa.isTrigger()) {
|
||||||
|
for (Object o : sa.getTriggerRemembered()) {
|
||||||
|
if (o instanceof Player) {
|
||||||
|
players.add((Player) o);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
else if (defined.equals("RememberedOpponent")) {
|
else if (defined.equals("RememberedOpponent")) {
|
||||||
for (final Object rem : card.getRemembered()) {
|
for (final Object rem : card.getRemembered()) {
|
||||||
if (rem instanceof Player) {
|
if (rem instanceof Player) {
|
||||||
|
|||||||
@@ -45,14 +45,14 @@ public class DelayedTriggerEffect extends SpellAbilityEffect {
|
|||||||
triggerRemembered = sa.getParam("RememberObjects");
|
triggerRemembered = sa.getParam("RememberObjects");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final Trigger delTrig = TriggerHandler.parseTrigger(mapParams, sa.getHostCard(), true);
|
||||||
|
|
||||||
if (triggerRemembered != null) {
|
if (triggerRemembered != null) {
|
||||||
for (final Object o : AbilityUtils.getDefinedObjects(sa.getHostCard(), triggerRemembered, sa)) {
|
for (final Object o : AbilityUtils.getDefinedObjects(sa.getHostCard(), triggerRemembered, sa)) {
|
||||||
sa.getHostCard().addRemembered(o);
|
delTrig.addRemembered(o);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final Trigger delTrig = TriggerHandler.parseTrigger(mapParams, sa.getHostCard(), true);
|
|
||||||
|
|
||||||
sa.getActivatingPlayer().getGame().getTriggerHandler().registerDelayedTrigger(delTrig);
|
sa.getActivatingPlayer().getGame().getTriggerHandler().registerDelayedTrigger(delTrig);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -627,6 +627,7 @@ public class CardFactory {
|
|||||||
trig.setTrigger(true);
|
trig.setTrigger(true);
|
||||||
trig.setSourceTrigger(t.getId());
|
trig.setSourceTrigger(t.getId());
|
||||||
t.setTriggeringObjects(trig);
|
t.setTriggeringObjects(trig);
|
||||||
|
trig.setTriggerRemembered(t.getTriggerRemembered());
|
||||||
if (t.getStoredTriggeredObjects() != null) {
|
if (t.getStoredTriggeredObjects() != null) {
|
||||||
trig.setAllTriggeringObjects(t.getStoredTriggeredObjects());
|
trig.setAllTriggeringObjects(t.getStoredTriggeredObjects());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -81,6 +81,7 @@ public abstract class SpellAbility extends CardTraitBase implements ISpellAbilit
|
|||||||
private boolean trigger = false;
|
private boolean trigger = false;
|
||||||
private boolean optionalTrigger = false;
|
private boolean optionalTrigger = false;
|
||||||
private int sourceTrigger = -1;
|
private int sourceTrigger = -1;
|
||||||
|
private List<Object> triggerRemembered = new ArrayList<Object>();
|
||||||
|
|
||||||
private boolean flashBackAbility = false;
|
private boolean flashBackAbility = false;
|
||||||
private boolean cycling = false;
|
private boolean cycling = false;
|
||||||
@@ -692,6 +693,19 @@ public abstract class SpellAbility extends CardTraitBase implements ISpellAbilit
|
|||||||
this.triggeringObjects = new HashMap<String, Object>();
|
this.triggeringObjects = new HashMap<String, Object>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public List<Object> getTriggerRemembered() {
|
||||||
|
return this.triggerRemembered;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTriggerRemembered(List<Object> list) {
|
||||||
|
this.triggerRemembered = list;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void resetTriggerRemembered() {
|
||||||
|
this.triggerRemembered = new ArrayList<Object>();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the replacing objects.
|
* Gets the replacing objects.
|
||||||
*
|
*
|
||||||
@@ -735,6 +749,8 @@ public abstract class SpellAbility extends CardTraitBase implements ISpellAbilit
|
|||||||
this.resetPaidHash();
|
this.resetPaidHash();
|
||||||
this.resetTargets();
|
this.resetTargets();
|
||||||
this.resetTriggeringObjects();
|
this.resetTriggeringObjects();
|
||||||
|
this.resetTriggerRemembered();
|
||||||
|
|
||||||
|
|
||||||
// Clear SVars
|
// Clear SVars
|
||||||
for (final String store : Card.getStorableSVars()) {
|
for (final String store : Card.getStorableSVars()) {
|
||||||
|
|||||||
@@ -77,6 +77,8 @@ public abstract class Trigger extends TriggerReplacementBase {
|
|||||||
|
|
||||||
private HashMap<String, Object> storedTriggeredObjects = null;
|
private HashMap<String, Object> storedTriggeredObjects = null;
|
||||||
|
|
||||||
|
private List<Object> triggerRemembered = new ArrayList<Object>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>
|
* <p>
|
||||||
* Setter for the field <code>storedTriggeredObjects</code>.
|
* Setter for the field <code>storedTriggeredObjects</code>.
|
||||||
@@ -393,6 +395,14 @@ public abstract class Trigger extends TriggerReplacementBase {
|
|||||||
this.triggeredSA = sa;
|
this.triggeredSA = sa;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void addRemembered(Object o) {
|
||||||
|
this.triggerRemembered.add(o);
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Object> getTriggerRemembered() {
|
||||||
|
return this.triggerRemembered;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Write javadoc for this method.
|
* TODO: Write javadoc for this method.
|
||||||
* @return the mode
|
* @return the mode
|
||||||
@@ -435,4 +445,5 @@ public abstract class Trigger extends TriggerReplacementBase {
|
|||||||
public void setTriggerPhases(List<PhaseType> phases) {
|
public void setTriggerPhases(List<PhaseType> phases) {
|
||||||
validPhases = phases;
|
validPhases = phases;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -376,6 +376,7 @@ public class TriggerHandler {
|
|||||||
sa.setTrigger(true);
|
sa.setTrigger(true);
|
||||||
sa.setSourceTrigger(regtrig.getId());
|
sa.setSourceTrigger(regtrig.getId());
|
||||||
regtrig.setTriggeringObjects(sa);
|
regtrig.setTriggeringObjects(sa);
|
||||||
|
sa.setTriggerRemembered(regtrig.getTriggerRemembered());
|
||||||
if (regtrig.getStoredTriggeredObjects() != null) {
|
if (regtrig.getStoredTriggeredObjects() != null) {
|
||||||
sa.setAllTriggeringObjects(regtrig.getStoredTriggeredObjects());
|
sa.setAllTriggeringObjects(regtrig.getStoredTriggeredObjects());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import forge.game.card.Card;
|
|||||||
import forge.game.cost.Cost;
|
import forge.game.cost.Cost;
|
||||||
import forge.game.player.Player;
|
import forge.game.player.Player;
|
||||||
import forge.game.spellability.*;
|
import forge.game.spellability.*;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@@ -129,6 +130,21 @@ public class WrappedAbility extends Ability implements ISpellAbility {
|
|||||||
sa.resetTriggeringObjects();
|
sa.resetTriggeringObjects();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<Object> getTriggerRemembered() {
|
||||||
|
return sa.getTriggerRemembered();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void resetTriggerRemembered() {
|
||||||
|
sa.resetTriggerRemembered();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setTriggerRemembered(List<Object> list) {
|
||||||
|
sa.setTriggerRemembered(list);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canPlay() {
|
public boolean canPlay() {
|
||||||
return sa.canPlay();
|
return sa.canPlay();
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ S:Mode$ Continuous | Affected$ You | AddKeyword$ Skip your draw step. | Descript
|
|||||||
T:Mode$ Discarded | ValidCard$ Card.YouCtrl | TriggerZones$ Battlefield | Execute$ TrigChange | TriggerDescription$ Whenever you discard a card, exile that card from your graveyard.
|
T:Mode$ Discarded | ValidCard$ Card.YouCtrl | TriggerZones$ Battlefield | Execute$ TrigChange | TriggerDescription$ Whenever you discard a card, exile that card from your graveyard.
|
||||||
SVar:TrigChange:AB$ChangeZone | Cost$ 0 | Defined$ TriggeredCard | Origin$ Graveyard | Destination$ Exile
|
SVar:TrigChange:AB$ChangeZone | Cost$ 0 | Defined$ TriggeredCard | Origin$ Graveyard | Destination$ Exile
|
||||||
A:AB$ ChangeZone | Cost$ PayLife<1> | Defined$ TopOfLibrary | Origin$ Library | Destination$ Exile | ExileFaceDown$ True | RememberChanged$ True | SubAbility$ DelayedReturn | SpellDescription$ Exile the top card of your library face down. Put that card into your hand at the beginning of your next end step.
|
A:AB$ ChangeZone | Cost$ PayLife<1> | Defined$ TopOfLibrary | Origin$ Library | Destination$ Exile | ExileFaceDown$ True | RememberChanged$ True | SubAbility$ DelayedReturn | SpellDescription$ Exile the top card of your library face down. Put that card into your hand at the beginning of your next end step.
|
||||||
SVar:DelayedReturn:DB$ DelayedTrigger | Mode$ Phase | Phase$ End of Turn | ValidPlayer$ You | Execute$ TrigReturn | TriggerDescription$ Put the exiled card into your hand.
|
SVar:DelayedReturn:DB$ DelayedTrigger | Mode$ Phase | Phase$ End of Turn | ValidPlayer$ You | Execute$ TrigReturn | RememberObjects$ Remembered | TriggerDescription$ Put the exiled card into your hand. | SubAbility$ DBCleanup
|
||||||
SVar:TrigReturn:DB$ ChangeZone | Origin$ Exile | Destination$ Hand | Defined$ Remembered | SubAbility$ DBCleanup
|
SVar:TrigReturn:DB$ ChangeZone | Origin$ Exile | Destination$ Hand | Defined$ DelayTriggerRemembered
|
||||||
SVar:DBCleanup:DB$ Cleanup | ClearRemembered$ True
|
SVar:DBCleanup:DB$ Cleanup | ClearRemembered$ True
|
||||||
SVar:RemAIDeck:True
|
SVar:RemAIDeck:True
|
||||||
SVar:Picture:http://www.wizards.com/global/images/magic/general/necropotence.jpg
|
SVar:Picture:http://www.wizards.com/global/images/magic/general/necropotence.jpg
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ ManaCost:U
|
|||||||
Types:Instant
|
Types:Instant
|
||||||
A:SP$ Charm | Cost$ U | Choices$ DelTrigSlowtrip,Pump,Phases | CharmNum$ 1 | SpellDescription$ Choose one - Target player draws a card at the beginning of the next turn's upkeep; or target creature gains flying until end of turn; or target creature an opponent controls phases out.
|
A:SP$ Charm | Cost$ U | Choices$ DelTrigSlowtrip,Pump,Phases | CharmNum$ 1 | SpellDescription$ Choose one - Target player draws a card at the beginning of the next turn's upkeep; or target creature gains flying until end of turn; or target creature an opponent controls phases out.
|
||||||
SVar:DelTrigSlowtrip:DB$ DelayedTrigger | Mode$ Phase | Phase$ Upkeep | ValidTgts$ Player | RememberObjects$ Targeted | TgtPrompt$ Select target player | Execute$ DrawSlowtrip | SpellDescription$ Target player draws a card at the beginning of the next turn's upkeep
|
SVar:DelTrigSlowtrip:DB$ DelayedTrigger | Mode$ Phase | Phase$ Upkeep | ValidTgts$ Player | RememberObjects$ Targeted | TgtPrompt$ Select target player | Execute$ DrawSlowtrip | SpellDescription$ Target player draws a card at the beginning of the next turn's upkeep
|
||||||
SVar:DrawSlowtrip:DB$Draw | NumCards$ 1 | Defined$ Remembered | SpellDescription$ Draw a card.
|
SVar:DrawSlowtrip:DB$Draw | NumCards$ 1 | Defined$ DelayTriggerRemembered | SpellDescription$ Draw a card.
|
||||||
SVar:Pump:DB$ Pump | ValidTgts$ Creature | KW$ Flying | TgtPrompt$ Select target creature | SpellDescription$ Target creature gains flying until end of turn.
|
SVar:Pump:DB$ Pump | ValidTgts$ Creature | KW$ Flying | TgtPrompt$ Select target creature | SpellDescription$ Target creature gains flying until end of turn.
|
||||||
SVar:Phases:DB$ Phases | ValidTgts$ Creature.OppCtrl | TgtPrompt$ Select target creature an opponent controls | SpellDescription$ Target creature an opponent controls phases out.
|
SVar:Phases:DB$ Phases | ValidTgts$ Creature.OppCtrl | TgtPrompt$ Select target creature an opponent controls | SpellDescription$ Target creature an opponent controls phases out.
|
||||||
SVar:RemAIDeck:True
|
SVar:RemAIDeck:True
|
||||||
|
|||||||
Reference in New Issue
Block a user