This commit is contained in:
BetaSteward 2010-11-15 03:40:47 +00:00
parent d71f48c2ce
commit e8be81cd34
11 changed files with 28 additions and 24 deletions

View file

@ -97,7 +97,7 @@ class FrostTitanAbility1 extends TriggeredAbilityImpl<FrostTitanAbility1> {
@Override @Override
public boolean checkTrigger(GameEvent event, Game game) { public boolean checkTrigger(GameEvent event, Game game) {
if (event.getType() == EventType.TARGET && event.getTargetId().equals(this.getSourceId()) && game.getOpponents(this.controllerId).contains(event.getPlayerId())) { if (event.getType() == EventType.TARGETED && event.getTargetId().equals(this.getSourceId()) && game.getOpponents(this.controllerId).contains(event.getPlayerId())) {
this.getTargets().clear(); this.getTargets().clear();
TargetStackObject target = new TargetStackObject(); TargetStackObject target = new TargetStackObject();
target.add(event.getSourceId(), game); target.add(event.getSourceId(), game);

View file

@ -56,7 +56,7 @@ public class GaeasRevenge extends CardImpl<GaeasRevenge> {
} }
public GaeasRevenge(UUID ownerId) { public GaeasRevenge(UUID ownerId) {
super(ownerId, 174, "GaeasRevenge", Rarity.MYTHIC, new CardType[]{CardType.CREATURE}, "{5}{G}{G}"); super(ownerId, 174, "Gaea's Revenge", Rarity.MYTHIC, new CardType[]{CardType.CREATURE}, "{5}{G}{G}");
this.expansionSetCode = "M11"; this.expansionSetCode = "M11";
this.subtype.add("Elemental"); this.subtype.add("Elemental");
this.color.setGreen(true); this.color.setGreen(true);

View file

@ -28,6 +28,7 @@
package mage.abilities.effects.common; package mage.abilities.effects.common;
import java.util.UUID;
import mage.Constants.Duration; import mage.Constants.Duration;
import mage.Constants.Outcome; import mage.Constants.Outcome;
import mage.abilities.Ability; import mage.abilities.Ability;
@ -67,8 +68,11 @@ public class CantCounterSourceEffect extends ReplacementEffectImpl<CantCounterSo
@Override @Override
public boolean applies(GameEvent event, Ability source, Game game) { public boolean applies(GameEvent event, Ability source, Game game) {
if (event.getType() == EventType.COUNTER && event.getTargetId().equals(source.getSourceId())) if (event.getType() == EventType.COUNTER) {
return true; UUID spellId = game.getCard(source.getSourceId()).getSpellAbility().getId();
if (event.getTargetId().equals(spellId))
return true;
}
return false; return false;
} }

View file

@ -87,8 +87,6 @@ public class CantTargetControlledEffect extends ReplacementEffectImpl<CantTarget
public boolean applies(GameEvent event, Ability source, Game game) { public boolean applies(GameEvent event, Ability source, Game game) {
if (event.getType() == EventType.TARGET) { if (event.getType() == EventType.TARGET) {
filterTarget.setTargetController(TargetController.YOU); filterTarget.setTargetController(TargetController.YOU);
// filterTarget.getControllerId().clear();
// filterTarget.getControllerId().add(source.getControllerId());
Permanent permanent = game.getPermanent(event.getTargetId()); Permanent permanent = game.getPermanent(event.getTargetId());
if (permanent != null && filterTarget.match(permanent, source.getControllerId(), game)) { if (permanent != null && filterTarget.match(permanent, source.getControllerId(), game)) {
if (filterSource == null) if (filterSource == null)

View file

@ -34,9 +34,11 @@ import mage.MageObject;
import mage.abilities.Ability; import mage.abilities.Ability;
import mage.abilities.effects.ReplacementEffectImpl; import mage.abilities.effects.ReplacementEffectImpl;
import mage.filter.FilterObject; import mage.filter.FilterObject;
import mage.filter.FilterStackObject;
import mage.game.Game; import mage.game.Game;
import mage.game.events.GameEvent; import mage.game.events.GameEvent;
import mage.game.events.GameEvent.EventType; import mage.game.events.GameEvent.EventType;
import mage.game.stack.StackObject;
/** /**
* *
@ -44,9 +46,9 @@ import mage.game.events.GameEvent.EventType;
*/ */
public class CantTargetControllerEffect extends ReplacementEffectImpl<CantTargetControllerEffect> { public class CantTargetControllerEffect extends ReplacementEffectImpl<CantTargetControllerEffect> {
private FilterObject filterSource; private FilterStackObject filterSource;
public CantTargetControllerEffect(FilterObject filterSource, Duration duration) { public CantTargetControllerEffect(FilterStackObject filterSource, Duration duration) {
super(duration, Outcome.Benefit); super(duration, Outcome.Benefit);
this.filterSource = filterSource; this.filterSource = filterSource;
} }
@ -74,7 +76,7 @@ public class CantTargetControllerEffect extends ReplacementEffectImpl<CantTarget
@Override @Override
public boolean applies(GameEvent event, Ability source, Game game) { public boolean applies(GameEvent event, Ability source, Game game) {
if (event.getType() == EventType.TARGET && event.getTargetId().equals(source.getControllerId())) { if (event.getType() == EventType.TARGET && event.getTargetId().equals(source.getControllerId())) {
MageObject sourceObject = game.getObject(source.getSourceId()); StackObject sourceObject = game.getStack().getStackObject(source.getSourceId());
if (sourceObject != null && filterSource.match(sourceObject)) { if (sourceObject != null && filterSource.match(sourceObject)) {
return true; return true;
} }

View file

@ -34,9 +34,11 @@ import mage.MageObject;
import mage.abilities.Ability; import mage.abilities.Ability;
import mage.abilities.effects.ReplacementEffectImpl; import mage.abilities.effects.ReplacementEffectImpl;
import mage.filter.FilterObject; import mage.filter.FilterObject;
import mage.filter.FilterStackObject;
import mage.game.Game; import mage.game.Game;
import mage.game.events.GameEvent; import mage.game.events.GameEvent;
import mage.game.events.GameEvent.EventType; import mage.game.events.GameEvent.EventType;
import mage.game.stack.StackObject;
/** /**
* *
@ -44,9 +46,9 @@ import mage.game.events.GameEvent.EventType;
*/ */
public class CantTargetSourceEffect extends ReplacementEffectImpl<CantTargetSourceEffect> { public class CantTargetSourceEffect extends ReplacementEffectImpl<CantTargetSourceEffect> {
private FilterObject filterSource; private FilterStackObject filterSource;
public CantTargetSourceEffect(FilterObject filterSource, Duration duration) { public CantTargetSourceEffect(FilterStackObject filterSource, Duration duration) {
super(duration, Outcome.Benefit); super(duration, Outcome.Benefit);
this.filterSource = filterSource; this.filterSource = filterSource;
} }
@ -74,7 +76,7 @@ public class CantTargetSourceEffect extends ReplacementEffectImpl<CantTargetSour
@Override @Override
public boolean applies(GameEvent event, Ability source, Game game) { public boolean applies(GameEvent event, Ability source, Game game) {
if (event.getType() == EventType.TARGET && event.getTargetId().equals(source.getSourceId())) { if (event.getType() == EventType.TARGET && event.getTargetId().equals(source.getSourceId())) {
MageObject sourceObject = game.getObject(source.getSourceId()); StackObject sourceObject = game.getStack().getStackObject(event.getSourceId());
if (sourceObject != null && filterSource.match(sourceObject)) { if (sourceObject != null && filterSource.match(sourceObject)) {
return true; return true;
} }

View file

@ -51,7 +51,7 @@ public class CounterUnlessPaysEffect extends OneShotEffect<CounterUnlessPaysEffe
public CounterUnlessPaysEffect(final CounterUnlessPaysEffect effect) { public CounterUnlessPaysEffect(final CounterUnlessPaysEffect effect) {
super(effect); super(effect);
this.cost = effect.cost; this.cost = effect.cost.copy();
} }
@Override @Override

View file

@ -230,7 +230,7 @@ public class Spell<T extends Spell<T>> implements StackObject, Card {
@Override @Override
public UUID getId() { public UUID getId() {
return card.getId(); return ability.getId();
} }
@Override @Override

View file

@ -115,7 +115,8 @@ public class SpellStack extends Stack<StackObject> {
public StackObject getStackObject(UUID id) { public StackObject getStackObject(UUID id) {
for (StackObject stackObject: this) { for (StackObject stackObject: this) {
if (stackObject.getId().equals(id)) UUID objectId = stackObject.getId();
if (objectId.equals(id))
return stackObject; return stackObject;
} }
return null; return null;

View file

@ -70,10 +70,8 @@ public class StackAbility implements StackObject, Ability {
private Ability ability; private Ability ability;
private UUID controllerId; private UUID controllerId;
private UUID id;
public StackAbility(Ability ability, UUID controllerId) { public StackAbility(Ability ability, UUID controllerId) {
this.id = UUID.randomUUID();
this.ability = ability; this.ability = ability;
this.controllerId = controllerId; this.controllerId = controllerId;
} }
@ -81,7 +79,6 @@ public class StackAbility implements StackObject, Ability {
public StackAbility(final StackAbility spell) { public StackAbility(final StackAbility spell) {
this.ability = spell.ability.copy(); this.ability = spell.ability.copy();
this.controllerId = spell.controllerId; this.controllerId = spell.controllerId;
this.id = spell.id;
} }
@Override @Override
@ -164,7 +161,7 @@ public class StackAbility implements StackObject, Ability {
@Override @Override
public UUID getId() { public UUID getId() {
return this.id; return this.ability.getId();
} }
@Override @Override

View file

@ -160,10 +160,10 @@ public abstract class TargetImpl<T extends TargetImpl<T>> implements Target {
if (maxNumberOfTargets == 0 || targets.size() < maxNumberOfTargets) { if (maxNumberOfTargets == 0 || targets.size() < maxNumberOfTargets) {
if (!targets.containsKey(id)) { if (!targets.containsKey(id)) {
if (source != null) { if (source != null) {
if (!game.replaceEvent(GameEvent.getEvent(EventType.TARGET, id, source.getSourceId(), source.getControllerId()))) { if (!game.replaceEvent(GameEvent.getEvent(EventType.TARGET, id, source.getId(), source.getControllerId()))) {
targets.put(id, 0); targets.put(id, 0);
chosen = targets.size() >= minNumberOfTargets; chosen = targets.size() >= minNumberOfTargets;
game.fireEvent(GameEvent.getEvent(EventType.TARGETED, id, source.getSourceId(), source.getControllerId())); game.fireEvent(GameEvent.getEvent(EventType.TARGETED, id, source.getId(), source.getControllerId()));
} }
} }
else { else {
@ -179,10 +179,10 @@ public abstract class TargetImpl<T extends TargetImpl<T>> implements Target {
amount += targets.get(id); amount += targets.get(id);
} }
if (source != null) { if (source != null) {
if (!game.replaceEvent(GameEvent.getEvent(EventType.TARGET, id, source.getSourceId(), source.getControllerId()))) { if (!game.replaceEvent(GameEvent.getEvent(EventType.TARGET, id, source.getId(), source.getControllerId()))) {
targets.put(id, amount); targets.put(id, amount);
chosen = targets.size() >= minNumberOfTargets; chosen = targets.size() >= minNumberOfTargets;
game.fireEvent(GameEvent.getEvent(EventType.TARGETED, id, source.getSourceId(), source.getControllerId())); game.fireEvent(GameEvent.getEvent(EventType.TARGETED, id, source.getId(), source.getControllerId()));
} }
} }
else { else {
@ -229,7 +229,7 @@ public abstract class TargetImpl<T extends TargetImpl<T>> implements Target {
@Override @Override
public boolean isLegal(Ability source, Game game) { public boolean isLegal(Ability source, Game game) {
for (UUID targetId: targets.keySet()) { for (UUID targetId: targets.keySet()) {
if (game.replaceEvent(GameEvent.getEvent(EventType.TARGET, targetId, source.getSourceId(), source.getControllerId()))) if (game.replaceEvent(GameEvent.getEvent(EventType.TARGET, targetId, source.getId(), source.getControllerId())))
return false; return false;
if (!canTarget(targetId, source, game)) if (!canTarget(targetId, source, game))
return false; return false;