mirror of
https://github.com/magefree/mage.git
synced 2025-12-25 21:12:04 -08:00
* Fixed bug of any mana abilities not working correctly for mana abilities that could produce mana of any type other mana sources could produce.
This commit is contained in:
parent
6bf7a89d45
commit
1d438060fc
14 changed files with 49 additions and 45 deletions
|
|
@ -94,14 +94,16 @@ public abstract class ActivatedManaAbilityImpl extends ActivatedAbilityImpl impl
|
|||
* @return
|
||||
*/
|
||||
@Override
|
||||
public boolean definesMana() {
|
||||
return !netMana.isEmpty();
|
||||
public boolean definesMana(Game game) {
|
||||
return !getNetMana(game).isEmpty();
|
||||
}
|
||||
|
||||
/**
|
||||
* Is it allowed to undo the mana creation.
|
||||
* It's e.g. not allowed if some game revealing information is related (like reveal the top card of the library)
|
||||
* @return
|
||||
* Is it allowed to undo the mana creation. It's e.g. not allowed if some
|
||||
* game revealing information is related (like reveal the top card of the
|
||||
* library)
|
||||
*
|
||||
* @return
|
||||
*/
|
||||
public boolean isUndoPossible() {
|
||||
return undoPossible;
|
||||
|
|
|
|||
|
|
@ -73,7 +73,7 @@ public class AnyColorLandsProduceManaAbility extends ActivatedManaAbilityImpl {
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean definesMana() {
|
||||
public boolean definesMana(Game game) {
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
@ -169,7 +169,7 @@ class AnyColorLandsProduceManaEffect extends ManaEffect {
|
|||
for (Permanent land : lands) {
|
||||
Abilities<ActivatedManaAbilityImpl> mana = land.getAbilities().getActivatedManaAbilities(Zone.BATTLEFIELD);
|
||||
for (ActivatedManaAbilityImpl ability : mana) {
|
||||
if (!ability.equals(source) && ability.definesMana()) {
|
||||
if (!ability.equals(source) && ability.definesMana(game)) {
|
||||
for (Mana netMana : ability.getNetMana(game)) {
|
||||
types.add(netMana);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -99,7 +99,7 @@ public class CommanderColorIdentityManaAbility extends ActivatedManaAbilityImpl
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean definesMana() {
|
||||
public boolean definesMana(Game game) {
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -78,7 +78,7 @@ public class ConditionalAnyColorManaAbility extends ActivatedManaAbilityImpl {
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean definesMana() {
|
||||
public boolean definesMana(Game game) {
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -117,7 +117,7 @@ public class DynamicManaAbility extends ActivatedManaAbilityImpl {
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean definesMana() {
|
||||
public boolean definesMana(Game game) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -27,7 +27,8 @@ public interface ManaAbility {
|
|||
/**
|
||||
* Used to check if the ability itself defines mana types it can produce.
|
||||
*
|
||||
* @param game
|
||||
* @return
|
||||
*/
|
||||
boolean definesMana();
|
||||
boolean definesMana(Game game);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,16 +1,16 @@
|
|||
/*
|
||||
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
||||
*
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification, are
|
||||
* permitted provided that the following conditions are met:
|
||||
*
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||
* conditions and the following disclaimer.
|
||||
*
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||
* of conditions and the following disclaimer in the documentation and/or other materials
|
||||
* provided with the distribution.
|
||||
*
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
|
||||
|
|
@ -20,12 +20,11 @@
|
|||
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*
|
||||
* The views and conclusions contained in the software and documentation are those of the
|
||||
* authors and should not be interpreted as representing official policies, either expressed
|
||||
* or implied, of BetaSteward_at_googlemail.com.
|
||||
*/
|
||||
|
||||
package mage.abilities.mana;
|
||||
|
||||
import java.util.List;
|
||||
|
|
@ -44,16 +43,18 @@ import mage.game.Game;
|
|||
public class SimpleManaAbility extends ActivatedManaAbilityImpl {
|
||||
|
||||
private boolean predictable;
|
||||
|
||||
|
||||
public SimpleManaAbility(Zone zone, ManaEffect effect, Cost cost) {
|
||||
this(zone, effect, cost, true);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*
|
||||
* @param zone
|
||||
* @param effect
|
||||
* @param cost
|
||||
* @param predictable set to false if definig the mana type or amount needs to reveal information and can't be predicted
|
||||
* @param predictable set to false if definig the mana type or amount needs
|
||||
* to reveal information and can't be predicted
|
||||
*/
|
||||
public SimpleManaAbility(Zone zone, ManaEffect effect, Cost cost, boolean predictable) {
|
||||
super(zone, effect, cost);
|
||||
|
|
@ -79,9 +80,9 @@ public class SimpleManaAbility extends ActivatedManaAbilityImpl {
|
|||
@Override
|
||||
public List<Mana> getNetMana(Game game) {
|
||||
if (netMana.isEmpty() && predictable) {
|
||||
for (Effect effect: getEffects()) {
|
||||
for (Effect effect : getEffects()) {
|
||||
if (effect instanceof ManaEffect) {
|
||||
Mana effectMana =((ManaEffect)effect).getMana(game, this);
|
||||
Mana effectMana = ((ManaEffect) effect).getMana(game, this);
|
||||
if (effectMana != null) {
|
||||
netMana.add(effectMana);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -96,7 +96,7 @@ public abstract class TriggeredManaAbility extends TriggeredAbilityImpl implemen
|
|||
* @return
|
||||
*/
|
||||
@Override
|
||||
public boolean definesMana() {
|
||||
public boolean definesMana(Game game) {
|
||||
return !netMana.isEmpty();
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue