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.Actor; import net.demilich.metastone.game.entities.Entity; import net.demilich.metastone.game.spells.desc.SpellArg; import net.demilich.metastone.game.spells.desc.SpellDesc; public class SetHeroHpSpell extends Spell { private static final Logger logger = LoggerFactory.getLogger(SetHeroHpSpell.class); public static SpellDesc create(int value) { Map<SpellArg, Object> arguments = SpellDesc.build(SetHeroHpSpell.class); arguments.put(SpellArg.VALUE, value); return new SpellDesc(arguments); } @Override protected void onCast(GameContext context, Player player, SpellDesc desc, Entity source, Entity target) { Actor actor = (Actor) target; int value = desc.getValue(SpellArg.VALUE, context, player, target, source, 0); if (actor.getMaxHp() < value) { actor.setMaxHp(value); logger.debug("{}'s Max Hp have been set to {}", actor, actor.getMaxHp()); } actor.setHp(value); logger.debug("{}'s Hp have been set to {}", actor, actor.getHp()); } }