package net.demilich.metastone.game.spells; import java.util.Map; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import net.demilich.metastone.game.GameContext; import net.demilich.metastone.game.Player; import net.demilich.metastone.game.entities.Entity; import net.demilich.metastone.game.spells.desc.SpellArg; import net.demilich.metastone.game.spells.desc.SpellDesc; import net.demilich.metastone.game.targeting.EntityReference; public class GainManaSpell extends Spell { private static Logger logger = LoggerFactory.getLogger(GainManaSpell.class); public static SpellDesc create(int mana) { Map<SpellArg, Object> arguments = SpellDesc.build(GainManaSpell.class); arguments.put(SpellArg.VALUE, mana); arguments.put(SpellArg.TARGET, EntityReference.NONE); return new SpellDesc(arguments); } @Override protected void onCast(GameContext context, Player player, SpellDesc desc, Entity source, Entity target) { int mana = desc.getValue(SpellArg.VALUE, context, player, target, source, 0); logger.debug("{} gains {} mana", player.getName(), mana); context.getLogic().modifyCurrentMana(player.getId(), mana); } }