forked from External/mage
252 lines
9.5 KiB
Java
252 lines
9.5 KiB
Java
/*
|
|
* 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
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* 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.util;
|
|
|
|
import mage.Constants;
|
|
import mage.Mana;
|
|
import mage.abilities.Ability;
|
|
import mage.abilities.SpellAbility;
|
|
import mage.abilities.costs.mana.GenericManaCost;
|
|
import mage.abilities.costs.mana.ManaCost;
|
|
import mage.abilities.costs.mana.ManaCosts;
|
|
import mage.abilities.costs.mana.ManaCostsImpl;
|
|
import mage.cards.Card;
|
|
import mage.game.permanent.token.Token;
|
|
import mage.util.functions.CopyFunction;
|
|
import mage.util.functions.CopyTokenFunction;
|
|
|
|
/**
|
|
* @author nantuko
|
|
*/
|
|
public class CardUtil {
|
|
|
|
/**
|
|
* Checks whether two cards share card types.
|
|
*
|
|
* @param card1
|
|
* @param card2
|
|
* @return
|
|
*/
|
|
public static boolean shareTypes(Card card1, Card card2) {
|
|
|
|
if (card1 == null || card2 == null) {
|
|
throw new IllegalArgumentException("Params can't be null");
|
|
}
|
|
|
|
for (Constants.CardType type : card1.getCardType()) {
|
|
if (card2.getCardType().contains(type)) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
/**
|
|
* Checks whether two cards share card subtypes.
|
|
*
|
|
* @param card1
|
|
* @param card2
|
|
* @return
|
|
*/
|
|
public static boolean shareSubtypes(Card card1, Card card2) {
|
|
|
|
if (card1 == null || card2 == null) {
|
|
throw new IllegalArgumentException("Params can't be null");
|
|
}
|
|
|
|
for (String subtype : card1.getSubtype()) {
|
|
if (card2.getSubtype().contains(subtype)) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
/**
|
|
* Adjusts spell or ability cost to be paid.
|
|
*
|
|
* @param spellAbility
|
|
* @param reduceCount
|
|
*/
|
|
public static void adjustCost(SpellAbility spellAbility, int reduceCount) {
|
|
Ability ability = (Ability) spellAbility;
|
|
CardUtil.adjustCost(ability, reduceCount);
|
|
}
|
|
/**
|
|
* Adjusts ability cost to be paid.
|
|
*
|
|
* @param ability
|
|
* @param reduceCount
|
|
*/
|
|
public static void adjustCost(Ability ability, int reduceCount) {
|
|
ManaCosts<ManaCost> previousCost = ability.getManaCostsToPay();
|
|
ManaCosts<ManaCost> adjustedCost = new ManaCostsImpl<ManaCost>();
|
|
boolean reduced = false;
|
|
for (ManaCost manaCost : previousCost) {
|
|
Mana mana = manaCost.getOptions().get(0);
|
|
int colorless = mana != null ? mana.getColorless() : 0;
|
|
if (!reduced && colorless > 0) {
|
|
if ((colorless - reduceCount) > 0) {
|
|
int newColorless = colorless - reduceCount;
|
|
adjustedCost.add(new GenericManaCost(newColorless));
|
|
}
|
|
reduced = true;
|
|
} else {
|
|
adjustedCost.add(manaCost);
|
|
}
|
|
}
|
|
ability.getManaCostsToPay().clear();
|
|
ability.getManaCostsToPay().addAll(adjustedCost);
|
|
}
|
|
|
|
/**
|
|
* Adjusts spell or ability cost to be paid by colored and generic mana.
|
|
*
|
|
* @param spellAbility
|
|
* @param mana costs to reduce
|
|
*/
|
|
public static void adjustCost(SpellAbility spellAbility, ManaCosts<ManaCost> manaCostsToReduce) {
|
|
ManaCosts<ManaCost> previousCost = spellAbility.getManaCostsToPay();
|
|
ManaCosts<ManaCost> adjustedCost = new ManaCostsImpl<ManaCost>();
|
|
|
|
Mana reduceMana = new Mana();
|
|
for (ManaCost manaCost : manaCostsToReduce) {
|
|
reduceMana.add(manaCost.getMana());
|
|
}
|
|
// subtract colored mana
|
|
for (ManaCost newManaCost : previousCost) {
|
|
Mana mana = newManaCost.getMana();
|
|
if (mana.getColorless() > 0) {
|
|
continue;
|
|
}
|
|
if (mana.getBlack() > 0 && reduceMana.getBlack() > 0) {
|
|
if (reduceMana.getBlack() > mana.getBlack()) {
|
|
reduceMana.setBlack(reduceMana.getBlack()-mana.getBlack());
|
|
mana.setBlack(0);
|
|
} else {
|
|
mana.setBlack(mana.getBlack()-reduceMana.getBlack());
|
|
reduceMana.setBlack(0);
|
|
}
|
|
}
|
|
if (mana.getRed() > 0 && reduceMana.getRed() > 0) {
|
|
if (reduceMana.getRed() > mana.getRed()) {
|
|
reduceMana.setRed(reduceMana.getRed()-mana.getRed());
|
|
mana.setRed(0);
|
|
} else {
|
|
mana.setRed(mana.getRed()-reduceMana.getRed());
|
|
reduceMana.setRed(0);
|
|
}
|
|
}
|
|
if (mana.getBlue() > 0 && reduceMana.getBlue() > 0) {
|
|
if (reduceMana.getBlue() > mana.getBlue()) {
|
|
reduceMana.setBlue(reduceMana.getBlue()-mana.getBlue());
|
|
mana.setBlue(0);
|
|
} else {
|
|
mana.setBlue(mana.getBlue()-reduceMana.getBlue());
|
|
reduceMana.setBlue(0);
|
|
}
|
|
}
|
|
if (mana.getGreen() > 0 && reduceMana.getGreen() > 0) {
|
|
if (reduceMana.getGreen() > mana.getGreen()) {
|
|
reduceMana.setGreen(reduceMana.getGreen()-mana.getGreen());
|
|
mana.setGreen(0);
|
|
} else {
|
|
mana.setGreen(mana.getGreen()-reduceMana.getGreen());
|
|
reduceMana.setGreen(0);
|
|
}
|
|
}
|
|
if (mana.getWhite() > 0 && reduceMana.getWhite() > 0) {
|
|
if (reduceMana.getWhite() > mana.getWhite()) {
|
|
reduceMana.setWhite(reduceMana.getWhite()-mana.getWhite());
|
|
mana.setWhite(0);
|
|
} else {
|
|
mana.setWhite(mana.getWhite()-reduceMana.getWhite());
|
|
reduceMana.setWhite(0);
|
|
}
|
|
}
|
|
if (mana.count() > 0) {
|
|
adjustedCost.add(newManaCost);
|
|
}
|
|
}
|
|
// subtract colorless mana, use all mana that is left
|
|
int reduceAmount = reduceMana.count();
|
|
for (ManaCost newManaCost : previousCost) {
|
|
Mana mana = newManaCost.getMana();
|
|
if (mana.getColorless() == 0) {
|
|
continue;
|
|
}
|
|
if (mana.getColorless() > 0 && reduceAmount > 0) {
|
|
if (reduceAmount > mana.getColorless()) {
|
|
reduceAmount -= mana.getColorless();
|
|
mana.setColorless(0);
|
|
} else {
|
|
mana.setColorless(mana.getColorless() - reduceAmount);
|
|
reduceAmount = 0;
|
|
}
|
|
}
|
|
if (mana.count() > 0) {
|
|
adjustedCost.add(0, new GenericManaCost(mana.count()));
|
|
}
|
|
}
|
|
|
|
spellAbility.getManaCostsToPay().clear();
|
|
spellAbility.getManaCostsToPay().addAll(adjustedCost);
|
|
}
|
|
/**
|
|
* Returns function that copies params\abilities from one card to another.
|
|
*
|
|
* @param target
|
|
*/
|
|
@Deprecated
|
|
//public static CopyFunction copyTo(Card target) {
|
|
private static CopyFunction copyTo(Card target) {
|
|
return new CopyFunction(target);
|
|
}
|
|
|
|
/**
|
|
* Returns function that copies params\abilities from one card to {@link Token}.
|
|
*
|
|
* @param target
|
|
*/
|
|
public static CopyTokenFunction copyTo(Token target) {
|
|
return new CopyTokenFunction(target);
|
|
}
|
|
|
|
public static boolean isPermanentCard ( Card card ) {
|
|
boolean permanent = false;
|
|
|
|
permanent |= card.getCardType().contains(Constants.CardType.ARTIFACT);
|
|
permanent |= card.getCardType().contains(Constants.CardType.CREATURE);
|
|
permanent |= card.getCardType().contains(Constants.CardType.ENCHANTMENT);
|
|
permanent |= card.getCardType().contains(Constants.CardType.LAND);
|
|
permanent |= card.getCardType().contains(Constants.CardType.PLANESWALKER);
|
|
|
|
return permanent;
|
|
}
|
|
}
|