mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
* Fixed that modes (if more than one was selected) did not resolve in the order they are written on the card but in order of selection by user.
This commit is contained in:
parent
0fb7cf8317
commit
4d7f1a05bf
8 changed files with 51 additions and 22 deletions
|
@ -280,7 +280,7 @@ public class CardView extends SimpleCardView {
|
||||||
Spell spell = (Spell) card;
|
Spell spell = (Spell) card;
|
||||||
for (SpellAbility spellAbility: spell.getSpellAbilities()) {
|
for (SpellAbility spellAbility: spell.getSpellAbilities()) {
|
||||||
for(UUID modeId : spellAbility.getModes().getSelectedModes()) {
|
for(UUID modeId : spellAbility.getModes().getSelectedModes()) {
|
||||||
spellAbility.getModes().setMode(spellAbility.getModes().get(modeId));
|
spellAbility.getModes().setActiveMode(modeId);
|
||||||
if (spellAbility.getTargets().size() > 0) {
|
if (spellAbility.getTargets().size() > 0) {
|
||||||
setTargets(spellAbility.getTargets());
|
setTargets(spellAbility.getTargets());
|
||||||
}
|
}
|
||||||
|
@ -290,7 +290,7 @@ public class CardView extends SimpleCardView {
|
||||||
if (spell.getSpellAbility().isModal()) {
|
if (spell.getSpellAbility().isModal()) {
|
||||||
Modes modes = spell.getSpellAbility().getModes();
|
Modes modes = spell.getSpellAbility().getModes();
|
||||||
for(UUID modeId : modes.getSelectedModes()) {
|
for(UUID modeId : modes.getSelectedModes()) {
|
||||||
modes.setMode(modes.get(modeId));
|
modes.setActiveMode(modeId);
|
||||||
this.rules.add("<span color='green'><i>Chosen mode: " + spell.getSpellAbility().getEffects().getText(modes.get(modeId))+"</i></span>");
|
this.rules.add("<span color='green'><i>Chosen mode: " + spell.getSpellAbility().getEffects().getText(modes.get(modeId))+"</i></span>");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,7 +98,7 @@ public class StackAbilityView extends CardView {
|
||||||
private void updateTargets(Game game, StackAbility ability) {
|
private void updateTargets(Game game, StackAbility ability) {
|
||||||
List<String> names = new ArrayList<>();
|
List<String> names = new ArrayList<>();
|
||||||
for(UUID modeId : ability.getModes().getSelectedModes()) {
|
for(UUID modeId : ability.getModes().getSelectedModes()) {
|
||||||
ability.getModes().setMode(ability.getModes().get(modeId));
|
ability.getModes().setActiveMode(modeId);
|
||||||
if (ability.getTargets().size() > 0) {
|
if (ability.getTargets().size() > 0) {
|
||||||
setTargets(ability.getTargets());
|
setTargets(ability.getTargets());
|
||||||
} else {
|
} else {
|
||||||
|
@ -129,7 +129,7 @@ public class StackAbilityView extends CardView {
|
||||||
if (ability.isModal()) {
|
if (ability.isModal()) {
|
||||||
Modes modes = ability.getModes();
|
Modes modes = ability.getModes();
|
||||||
for(UUID modeId : modes.getSelectedModes()) {
|
for(UUID modeId : modes.getSelectedModes()) {
|
||||||
modes.setMode(modes.get(modeId));
|
modes.setActiveMode(modeId);
|
||||||
this.rules.add("<span color='green'><i>Chosen mode: " + ability.getEffects().getText(modes.get(modeId))+"</i></span>");
|
this.rules.add("<span color='green'><i>Chosen mode: " + ability.getEffects().getText(modes.get(modeId))+"</i></span>");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,6 @@ import mage.game.command.Emblem;
|
||||||
import mage.game.events.GameEvent;
|
import mage.game.events.GameEvent;
|
||||||
import mage.game.events.ManaEvent;
|
import mage.game.events.ManaEvent;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.game.permanent.PermanentCard;
|
|
||||||
import mage.game.stack.Spell;
|
import mage.game.stack.Spell;
|
||||||
import mage.game.stack.StackAbility;
|
import mage.game.stack.StackAbility;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
@ -263,7 +262,7 @@ public abstract class AbilityImpl implements Ability {
|
||||||
// TODO: Because all (non targeted) choices have to be done during resolution
|
// TODO: Because all (non targeted) choices have to be done during resolution
|
||||||
// this has to be removed, if all using effects are changed
|
// this has to be removed, if all using effects are changed
|
||||||
for (UUID modeId :this.getModes().getSelectedModes()) {
|
for (UUID modeId :this.getModes().getSelectedModes()) {
|
||||||
this.getModes().setMode(this.getModes().get(modeId));
|
this.getModes().setActiveMode(modeId);
|
||||||
if (getChoices().size() > 0 && getChoices().choose(game, this) == false) {
|
if (getChoices().size() > 0 && getChoices().choose(game, this) == false) {
|
||||||
logger.debug("activate failed - choice");
|
logger.debug("activate failed - choice");
|
||||||
return false;
|
return false;
|
||||||
|
@ -302,7 +301,7 @@ public abstract class AbilityImpl implements Ability {
|
||||||
String announceString = handleOtherXCosts(game, controller);
|
String announceString = handleOtherXCosts(game, controller);
|
||||||
|
|
||||||
for (UUID modeId :this.getModes().getSelectedModes()) {
|
for (UUID modeId :this.getModes().getSelectedModes()) {
|
||||||
this.getModes().setMode(this.getModes().get(modeId));
|
this.getModes().setActiveMode(modeId);
|
||||||
//20121001 - 601.2c
|
//20121001 - 601.2c
|
||||||
// 601.2c The player announces his or her choice of an appropriate player, object, or zone for
|
// 601.2c The player announces his or her choice of an appropriate player, object, or zone for
|
||||||
// each target the spell requires. A spell may require some targets only if an alternative or
|
// each target the spell requires. A spell may require some targets only if an alternative or
|
||||||
|
@ -1037,7 +1036,7 @@ public abstract class AbilityImpl implements Ability {
|
||||||
for (Mode mode : spellModes.values()) {
|
for (Mode mode : spellModes.values()) {
|
||||||
item++;
|
item++;
|
||||||
if (spellModes.getSelectedModes().contains(mode.getId())) {
|
if (spellModes.getSelectedModes().contains(mode.getId())) {
|
||||||
spellModes.setMode(mode);
|
spellModes.setActiveMode(mode.getId());
|
||||||
sb.append(" (mode ").append(item).append(")");
|
sb.append(" (mode ").append(item).append(")");
|
||||||
sb.append(getTargetDescriptionForLog(getTargets(), game));
|
sb.append(getTargetDescriptionForLog(getTargets(), game));
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,6 +43,7 @@ import mage.cards.Card;
|
||||||
import mage.constants.AsThoughEffectType;
|
import mage.constants.AsThoughEffectType;
|
||||||
import mage.constants.TargetController;
|
import mage.constants.TargetController;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
|
import mage.game.permanent.Permanent;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -174,13 +175,21 @@ public abstract class ActivatedAbilityImpl extends AbilityImpl implements Activa
|
||||||
if (! game.getPlayer(controllerId).hasOpponent(playerId, game)){
|
if (! game.getPlayer(controllerId).hasOpponent(playerId, game)){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case YOU:
|
case YOU:
|
||||||
if(!controlsAbility(playerId, game)){
|
if(!controlsAbility(playerId, game)){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case CONTROLLER_ATTACHED_TO:
|
||||||
|
Permanent enchantment = game.getPermanent(getSourceId());
|
||||||
|
if (enchantment != null && enchantment.getAttachedTo() != null) {
|
||||||
|
Permanent enchanted = game.getPermanent(enchantment.getAttachedTo());
|
||||||
|
if (enchanted != null && enchanted.getControllerId().equals(playerId)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
//20091005 - 602.5d/602.5e
|
//20091005 - 602.5d/602.5e
|
||||||
if (timing == TimingRule.INSTANT || game.canPlaySorcery(playerId) ||
|
if (timing == TimingRule.INSTANT || game.canPlaySorcery(playerId) ||
|
||||||
|
|
|
@ -109,10 +109,24 @@ public class Modes extends LinkedHashMap<UUID, Mode> {
|
||||||
return this.modeChooser;
|
return this.modeChooser;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setActiveMode(UUID modeId) {
|
||||||
|
if (selectedModes.contains(modeId)) {
|
||||||
|
this.modeId = modeId;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void setMode(Mode mode) {
|
public void setMode(Mode mode) {
|
||||||
if (this.containsKey(mode.getId())) {
|
if (this.containsKey(mode.getId())) {
|
||||||
this.modeId = mode.getId();
|
this.modeId = mode.getId();
|
||||||
this.selectedModes.add(mode.getId());
|
this.selectedModes.add(mode.getId());
|
||||||
|
Set<UUID> copySelectedModes = new LinkedHashSet<>();
|
||||||
|
copySelectedModes.addAll(selectedModes);
|
||||||
|
selectedModes.clear();
|
||||||
|
for (UUID basicModeId: this.keySet()) {
|
||||||
|
if (copySelectedModes.contains(basicModeId)) {
|
||||||
|
selectedModes.add(basicModeId);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -167,7 +181,6 @@ public class Modes extends LinkedHashMap<UUID, Mode> {
|
||||||
return this.selectedModes.size() >= this.getMinModes();
|
return this.selectedModes.size() >= this.getMinModes();
|
||||||
}
|
}
|
||||||
setMode(choice);
|
setMode(choice);
|
||||||
this.selectedModes.add(choice.getId());
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,9 +66,13 @@ public class CostsImpl<T extends Cost> extends ArrayList<T> implements Costs<T>
|
||||||
StringBuilder sbText = new StringBuilder();
|
StringBuilder sbText = new StringBuilder();
|
||||||
for (T cost: this) {
|
for (T cost: this) {
|
||||||
String text = cost.getText();
|
String text = cost.getText();
|
||||||
sbText.append(Character.toUpperCase(text.charAt(0))).append(text.substring(1)).append(", ");
|
if (text != null && !text.isEmpty()) {
|
||||||
|
sbText.append(Character.toUpperCase(text.charAt(0))).append(text.substring(1)).append(", ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sbText.length() > 1){
|
||||||
|
sbText.setLength(sbText.length() - 2);
|
||||||
}
|
}
|
||||||
sbText.setLength(sbText.length() - 2);
|
|
||||||
return sbText.toString();
|
return sbText.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,11 +27,14 @@
|
||||||
*/
|
*/
|
||||||
package mage.abilities.effects.common;
|
package mage.abilities.effects.common;
|
||||||
|
|
||||||
import mage.constants.Outcome;
|
import mage.MageObject;
|
||||||
import mage.constants.Zone;
|
|
||||||
import mage.abilities.Ability;
|
import mage.abilities.Ability;
|
||||||
import mage.abilities.effects.OneShotEffect;
|
import mage.abilities.effects.OneShotEffect;
|
||||||
import mage.cards.Card;
|
import mage.cards.Card;
|
||||||
|
import mage.constants.Outcome;
|
||||||
|
import mage.constants.Zone;
|
||||||
|
import static mage.constants.Zone.BATTLEFIELD;
|
||||||
|
import static mage.constants.Zone.GRAVEYARD;
|
||||||
import mage.game.Game;
|
import mage.game.Game;
|
||||||
import mage.game.permanent.Permanent;
|
import mage.game.permanent.Permanent;
|
||||||
import mage.players.Player;
|
import mage.players.Player;
|
||||||
|
@ -67,9 +70,9 @@ public class ReturnToHandSourceEffect extends OneShotEffect {
|
||||||
public boolean apply(Game game, Ability source) {
|
public boolean apply(Game game, Ability source) {
|
||||||
Player controller = game.getPlayer(source.getControllerId());
|
Player controller = game.getPlayer(source.getControllerId());
|
||||||
if (controller != null) {
|
if (controller != null) {
|
||||||
Card card = game.getCard(source.getSourceId());
|
MageObject mageObject = source.getSourceObjectIfItStillExists(game);
|
||||||
if (card != null) {
|
if (mageObject != null) {
|
||||||
switch (game.getState().getZone(card.getId())) {
|
switch (game.getState().getZone(mageObject.getId())) {
|
||||||
case BATTLEFIELD:
|
case BATTLEFIELD:
|
||||||
Permanent permanent = game.getPermanent(source.getSourceId());
|
Permanent permanent = game.getPermanent(source.getSourceId());
|
||||||
if (permanent != null) {
|
if (permanent != null) {
|
||||||
|
@ -77,12 +80,13 @@ public class ReturnToHandSourceEffect extends OneShotEffect {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case GRAVEYARD:
|
case GRAVEYARD:
|
||||||
|
Card card = (Card) mageObject;
|
||||||
if (!fromBattlefieldOnly) {
|
if (!fromBattlefieldOnly) {
|
||||||
return controller.moveCardToHandWithInfo(card, source.getSourceId(), game, Zone.GRAVEYARD);
|
return controller.moveCardToHandWithInfo(card, source.getSourceId(), game, Zone.GRAVEYARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -190,7 +190,7 @@ public class Spell implements StackObject, Card {
|
||||||
for(SpellAbility spellAbility: this.spellAbilities) {
|
for(SpellAbility spellAbility: this.spellAbilities) {
|
||||||
if (spellAbilityHasLegalParts(spellAbility, game)) {
|
if (spellAbilityHasLegalParts(spellAbility, game)) {
|
||||||
for (UUID modeId :spellAbility.getModes().getSelectedModes()) {
|
for (UUID modeId :spellAbility.getModes().getSelectedModes()) {
|
||||||
spellAbility.getModes().setMode(spellAbility.getModes().get(modeId));
|
spellAbility.getModes().setActiveMode(modeId);
|
||||||
if (spellAbility.getTargets().stillLegal(spellAbility, game)) {
|
if (spellAbility.getTargets().stillLegal(spellAbility, game)) {
|
||||||
if (!spellAbility.getSpellAbilityType().equals(SpellAbilityType.SPLICE)) {
|
if (!spellAbility.getSpellAbilityType().equals(SpellAbilityType.SPLICE)) {
|
||||||
updateOptionalCosts(index);
|
updateOptionalCosts(index);
|
||||||
|
@ -269,7 +269,7 @@ public class Spell implements StackObject, Card {
|
||||||
boolean targetedMode = false;
|
boolean targetedMode = false;
|
||||||
boolean legalTargetedMode = false;
|
boolean legalTargetedMode = false;
|
||||||
for (UUID modeId :spellAbility.getModes().getSelectedModes()) {
|
for (UUID modeId :spellAbility.getModes().getSelectedModes()) {
|
||||||
spellAbility.getModes().setMode(spellAbility.getModes().get(modeId));
|
spellAbility.getModes().setActiveMode(modeId);
|
||||||
if (spellAbility.getTargets().size() > 0) {
|
if (spellAbility.getTargets().size() > 0) {
|
||||||
targetedMode = true;
|
targetedMode = true;
|
||||||
if (spellAbility.getTargets().stillLegal(spellAbility, game)) {
|
if (spellAbility.getTargets().stillLegal(spellAbility, game)) {
|
||||||
|
|
Loading…
Reference in a new issue