1
0
Fork 0
mirror of https://github.com/correl/mage.git synced 2025-04-03 01:08:59 -09:00

Fixed Morph handling, fixed that face down cards stay face down after zone change.

This commit is contained in:
LevelX2 2014-09-10 00:18:03 +02:00
parent c888957fa0
commit f137f9c49c
9 changed files with 59 additions and 7 deletions
Mage.Common/src/mage/view
Mage.Sets/src/mage/sets/khansoftarkir
Mage/src/mage

View file

@ -119,7 +119,7 @@ public class PermanentView extends CardView {
if (permanentAbility instanceof TurnFaceUpAbility && !permanentAbility.getRuleVisible()) {
this.rules.add(permanentAbility.getRule(true));
}
if (permanentAbility instanceof TurnedFaceUpTriggeredAbility) {
if (permanentAbility.getWorksFaceDown()) {
this.rules.add(permanentAbility.getRule());
}
}

View file

@ -82,8 +82,9 @@ public class HoodedHydra extends CardImpl {
Effect effect = new AddCountersSourceEffect(CounterType.P1P1.createInstance(5));
effect.setText("put five +1/+1 counters on it");
// TODO: Does not work because the ability is still removed from permanent while the effect checks if the ability still exosts.
this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD,
new AsTurnedFaceUpEffect(effect, false)));
Ability ability = new SimpleStaticAbility(Zone.BATTLEFIELD, new AsTurnedFaceUpEffect(effect, false));
ability.setWorksFaceDown(true);
this.addAbility(ability);
}
public HoodedHydra(final HoodedHydra card) {

View file

@ -385,6 +385,24 @@ public interface Ability extends Controllable, Serializable {
*/
void setRuleAtTheTop(boolean ruleAtTheTop);
/**
* Returns true if this ability has to work also with face down object
* (set to not visible normally).
*
* @return
*/
boolean getWorksFaceDown();
/**
* Sets the value for the worksFaceDown flag
*
* true = the ability works also if the object is face down
*
* @param worksFaceDown
*/
void setWorksFaceDown(boolean worksFaceDown);
/**
* Returns true if this ability's rule is visible on the card tooltip
*
@ -450,7 +468,7 @@ public interface Ability extends Controllable, Serializable {
/**
* Used to deactivate cost modification logic of ability activation for some special handling
* (e.g. FlashbackAbility gets cost modifiaction twice because of how it#s ahndled now)
* (e.g. FlashbackAbility gets cost modifiaction twice because of how it's handled now)
*
* @param active execute no cost modification
*/

View file

@ -83,6 +83,7 @@ public abstract class AbilityImpl implements Ability {
protected boolean ruleAdditionalCostsVisible = true;
protected boolean costModificationActive = true;
protected boolean activated = false;
protected boolean worksFaceDown = false;
public AbilityImpl(AbilityType abilityType, Zone zone) {
this.id = UUID.randomUUID();
@ -117,6 +118,7 @@ public abstract class AbilityImpl implements Ability {
this.ruleVisible = ability.ruleVisible;
this.ruleAdditionalCostsVisible = ability.ruleAdditionalCostsVisible;
this.costModificationActive = ability.costModificationActive;
this.worksFaceDown = ability.worksFaceDown;
}
@Override
@ -945,5 +947,17 @@ public abstract class AbilityImpl implements Ability {
this.costModificationActive = active;
}
@Override
public boolean getWorksFaceDown() {
return worksFaceDown;
}
@Override
public void setWorksFaceDown(boolean worksFaceDown) {
this.worksFaceDown = worksFaceDown;
}
}

View file

@ -22,6 +22,8 @@ public class TurnedFaceUpTriggeredAbility extends TriggeredAbilityImpl {
public TurnedFaceUpTriggeredAbility(Effect effect) {
super(Zone.BATTLEFIELD, effect);
// has to be set so the ability triggers if card is turn faced up
this.setWorksFaceDown(true);
}
public TurnedFaceUpTriggeredAbility(final TurnedFaceUpTriggeredAbility ability) {

View file

@ -48,6 +48,7 @@ import mage.abilities.costs.CostsImpl;
import mage.abilities.costs.mana.GenericManaCost;
import mage.abilities.costs.mana.ManaCosts;
import mage.abilities.costs.mana.ManaCostsImpl;
import mage.abilities.effects.AsTurnedFaceUpEffect;
import mage.abilities.effects.ContinuousEffectImpl;
import mage.abilities.effects.common.continious.SourceEffect;
import mage.cards.Card;
@ -301,7 +302,7 @@ class BecomesFaceDownCreatureEffect extends ContinuousEffectImpl implements Sour
List<Ability> abilities = new ArrayList<>();
for (Ability ability : permanent.getAbilities()) {
// TODO: Add flag "works also face down" to ability and use it to control ability removement instead of instanceof check
if (ability instanceof TurnedFaceUpTriggeredAbility) {
if (ability.getWorksFaceDown()) {
ability.setRuleVisible(false);
continue;
}

View file

@ -571,6 +571,11 @@ public abstract class CardImpl extends MageObjectImpl implements Card {
if (!game.replaceEvent(event)) {
setFaceDown(false);
game.getCard(objectId).setFaceDown(false); // Another instance?
for (Ability ability :abilities) { // abilities that were set to not visible face down must be set to visible again
if (ability.getWorksFaceDown() && !ability.getRuleVisible()) {
ability.setRuleVisible(true);
}
}
game.fireEvent(GameEvent.getEvent(GameEvent.EventType.TURNEDFACEUP, getId(), playerId));
return true;
}
@ -703,9 +708,9 @@ public abstract class CardImpl extends MageObjectImpl implements Card {
countersEvent.setAppliedEffects(appliedEffects);
if (!game.replaceEvent(countersEvent)) {
int amount = countersEvent.getAmount();
Counter eventCounter = counter.copy();
eventCounter.remove(amount - 1);
for (int i = 0; i < amount; i++) {
Counter eventCounter = counter.copy();
eventCounter.remove(amount - 1);
GameEvent event = GameEvent.getEvent(GameEvent.EventType.ADD_COUNTER, objectId, ownerId, counter.getName(), 1);
event.setAppliedEffects(appliedEffects);
if (!game.replaceEvent(event)) {

View file

@ -134,6 +134,7 @@ public class PermanentCard extends PermanentImpl {
if (controller != null && controller.removeFromBattlefield(this, game)) {
if (isFaceDown()) {
setFaceDown(false);
game.getCard(this.getId()).setFaceDown(false); //TODO: Do this in a better way
}
ZoneChangeEvent event = new ZoneChangeEvent(this, sourceId, controllerId, fromZone, toZone, appliedEffects);
if (!game.replaceEvent(event)) {

View file

@ -451,6 +451,16 @@ public class StackAbility implements StackObject, Ability {
public void setCostModificationActive(boolean active) {
throw new UnsupportedOperationException("Not supported. Only neede for flashbacked spells");
}
@Override
public boolean getWorksFaceDown() {
return this.ability.getWorksFaceDown();
}
@Override
public void setWorksFaceDown(boolean worksFaceDown) {
this.ability.setWorksFaceDown(worksFaceDown);
}
}