mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
fixes
This commit is contained in:
parent
d71f48c2ce
commit
e8be81cd34
11 changed files with 28 additions and 24 deletions
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue