* Ethersworn Canonist - Code cleanup.

This commit is contained in:
LevelX2 2016-10-02 07:26:59 +02:00
parent cfcefb3877
commit da0080e2e1

View file

@ -27,10 +27,11 @@
*/ */
package mage.sets.shardsofalara; package mage.sets.shardsofalara;
import java.util.HashMap; import java.util.HashSet;
import java.util.Map; import java.util.Set;
import java.util.UUID; import java.util.UUID;
import mage.MageInt; import mage.MageInt;
import mage.MageObject;
import mage.abilities.Ability; import mage.abilities.Ability;
import mage.abilities.common.SimpleStaticAbility; import mage.abilities.common.SimpleStaticAbility;
import mage.abilities.effects.ContinuousRuleModifyingEffectImpl; import mage.abilities.effects.ContinuousRuleModifyingEffectImpl;
@ -44,6 +45,7 @@ import mage.constants.WatcherScope;
import mage.constants.Zone; import mage.constants.Zone;
import mage.game.Game; import mage.game.Game;
import mage.game.events.GameEvent; import mage.game.events.GameEvent;
import mage.game.stack.Spell;
import mage.watchers.Watcher; import mage.watchers.Watcher;
/** /**
@ -77,29 +79,30 @@ public class EtherswornCanonist extends CardImpl {
class EtherswornCanonistWatcher extends Watcher { class EtherswornCanonistWatcher extends Watcher {
private Map<UUID, Boolean> castNonartifactSpell = new HashMap<>(); private Set<UUID> castNonartifactSpell = new HashSet<>();
public EtherswornCanonistWatcher() { public EtherswornCanonistWatcher() {
super("EtherswornCanonistWatcher", WatcherScope.GAME); super(EtherswornCanonistWatcher.class.getName(), WatcherScope.GAME);
} }
public EtherswornCanonistWatcher(final EtherswornCanonistWatcher watcher) { public EtherswornCanonistWatcher(final EtherswornCanonistWatcher watcher) {
super(watcher); super(watcher);
for (Map.Entry<UUID, Boolean> entry: watcher.castNonartifactSpell.entrySet()) { this.castNonartifactSpell.addAll(watcher.castNonartifactSpell);
castNonartifactSpell.put(entry.getKey(), entry.getValue());
}
} }
@Override @Override
public void watch(GameEvent event, Game game) { public void watch(GameEvent event, Game game) {
if (event.getType() == GameEvent.EventType.SPELL_CAST) { if (event.getType() == GameEvent.EventType.SPELL_CAST && event.getPlayerId() != null) {
Card card = game.getCard(event.getSourceId()); Spell spell = game.getStack().getSpell(event.getTargetId());
if(card != null && !card.getCardType().contains(CardType.ARTIFACT)){ if (spell == null) {
UUID playerId = event.getPlayerId(); MageObject mageObject = game.getLastKnownInformation(event.getTargetId(), Zone.STACK);
if (playerId != null) { if (mageObject instanceof Spell) {
castNonartifactSpell.put(playerId, true); spell = (Spell) mageObject;
} }
} }
if (spell != null && !spell.getCardType().contains(CardType.ARTIFACT)) {
castNonartifactSpell.add(event.getPlayerId());
}
} }
} }
@ -107,12 +110,10 @@ class EtherswornCanonistWatcher extends Watcher {
public void reset() { public void reset() {
castNonartifactSpell.clear(); castNonartifactSpell.clear();
} }
public boolean castNonArtifactSpell(UUID player){
Boolean value = castNonartifactSpell.get(player);
return value != null && value;
}
public boolean castNonArtifactSpell(UUID playerId) {
return castNonartifactSpell.contains(playerId);
}
@Override @Override
public EtherswornCanonistWatcher copy() { public EtherswornCanonistWatcher copy() {
@ -144,12 +145,12 @@ class EtherswornCanonistReplacementEffect extends ContinuousRuleModifyingEffectI
@Override @Override
public boolean applies(GameEvent event, Ability source, Game game) { public boolean applies(GameEvent event, Ability source, Game game) {
EtherswornCanonistWatcher watcher = (EtherswornCanonistWatcher)game.getState().getWatchers().get("EtherswornCanonistWatcher"); EtherswornCanonistWatcher watcher = (EtherswornCanonistWatcher) game.getState().getWatchers().get(EtherswornCanonistWatcher.class.getName());
Card card = game.getCard(event.getSourceId()); Card card = game.getCard(event.getSourceId());
if (card != null && !card.getCardType().contains(CardType.ARTIFACT) && watcher.castNonArtifactSpell(event.getPlayerId())) { if (card != null && !card.getCardType().contains(CardType.ARTIFACT) && watcher.castNonArtifactSpell(event.getPlayerId())) {
return true; return true;
} }
return false; return false;
} }
} }