1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-12-14 10:12:59 +02:00
vcmi/lib/spells/ISpellMechanics.h

153 lines
4.7 KiB
C
Raw Normal View History

/*
2015-02-02 11:22:19 +02:00
* ISpellMechanics.h, part of VCMI engine
*
* Authors: listed in file AUTHORS in main folder
*
* License: GNU General Public License v2.0 or later
* Full text of license available in license.txt file, in main folder
*
*/
2015-02-26 19:59:18 +02:00
#pragma once
#include "CSpellHandler.h"
#include "../battle/BattleHex.h"
2015-09-17 07:42:30 +02:00
struct Query;
2015-09-16 09:50:33 +02:00
///callback to be provided by server
class DLL_LINKAGE SpellCastEnvironment
{
public:
virtual ~SpellCastEnvironment(){};
virtual void sendAndApply(CPackForClient * info) const = 0;
virtual CRandomGenerator & getRandomGenerator() const = 0;
virtual void complain(const std::string & problem) const = 0;
virtual const CMap * getMap() const = 0;
virtual const CGameInfoCallback * getCb() const = 0;
virtual bool moveHero(ObjectInstanceID hid, int3 dst, bool teleporting) const = 0; //TODO: remove
virtual void genericQuery(Query * request, PlayerColor color, std::function<void(const JsonNode &)> callback) const = 0;//TODO: type safety on query, use generic query packet when implemented
2015-09-16 09:50:33 +02:00
};
///all parameters of particular cast event
2015-09-16 09:50:33 +02:00
struct DLL_LINKAGE BattleSpellCastParameters
{
public:
2016-02-15 12:34:37 +02:00
///Single spell destination.
/// (assumes that anything but battle stack can share same hex)
struct DLL_LINKAGE Destination
{
2016-02-15 12:34:37 +02:00
explicit Destination(const CStack * destination);
explicit Destination(const BattleHex & destination);
2016-02-15 12:34:37 +02:00
const CStack * stackValue;
const BattleHex hexValue;
};
2016-09-06 12:51:53 +02:00
//normal constructor
2016-09-06 12:33:11 +02:00
BattleSpellCastParameters(const BattleInfo * cb, const ISpellCaster * caster, const CSpell * spell_);
2016-09-06 12:51:53 +02:00
//magic mirror constructor
BattleSpellCastParameters(const BattleSpellCastParameters & orig, const ISpellCaster * caster);
void aimToHex(const BattleHex & destination);
void aimToStack(const CStack * destination);
2016-09-06 12:33:11 +02:00
void cast(const SpellCastEnvironment * env);
2017-03-18 13:08:02 +02:00
///cast with silent check for permitted cast
2017-06-05 20:41:27 +02:00
///returns true if cast was permitted
bool castIfPossible(const SpellCastEnvironment * env);
2017-03-18 13:08:02 +02:00
BattleHex getFirstDestinationHex() const;
2016-02-15 12:34:37 +02:00
int getEffectValue() const;
2016-09-06 12:33:11 +02:00
const CSpell * spell;
2015-09-17 07:42:30 +02:00
const BattleInfo * cb;
const ISpellCaster * caster;
2016-02-15 12:34:37 +02:00
const PlayerColor casterColor;
2015-09-17 08:29:57 +02:00
const ui8 casterSide;
std::vector<Destination> destinations;
2015-09-16 09:50:33 +02:00
const CGHeroInstance * casterHero; //deprecated
ECastingMode::ECastingMode mode;
2015-09-17 07:42:30 +02:00
const CStack * casterStack; //deprecated
2015-09-17 08:29:57 +02:00
///spell school level
2016-02-15 12:34:37 +02:00
int spellLvl;
2015-09-17 07:42:30 +02:00
///spell school level to use for effects
int effectLevel;
2015-09-17 07:42:30 +02:00
///actual spell-power affecting effect values
int effectPower;
2015-09-17 07:42:30 +02:00
///actual spell-power affecting effect duration
int enchantPower;
private:
2015-09-17 07:42:30 +02:00
///for Archangel-like casting
int effectValue;
2015-09-16 09:50:33 +02:00
};
2016-09-04 04:15:37 +02:00
struct DLL_LINKAGE SpellTargetingContext
{
2016-09-04 04:15:37 +02:00
CSpell::TargetInfo ti;
ECastingMode::ECastingMode mode;
BattleHex destination;
const ISpellCaster * caster;
int schoolLvl;
2015-02-26 19:59:18 +02:00
2016-09-04 04:15:37 +02:00
SpellTargetingContext(const CSpell * s, ECastingMode::ECastingMode mode_, const ISpellCaster * caster_, int schoolLvl_, BattleHex destination_)
: ti(s,schoolLvl_, mode_), mode(mode_), destination(destination_), caster(caster_), schoolLvl(schoolLvl_)
{};
};
class DLL_LINKAGE ISpellMechanics
{
public:
ISpellMechanics(const CSpell * s);
2015-02-26 19:59:18 +02:00
virtual ~ISpellMechanics(){};
virtual std::vector<BattleHex> rangeInHexes(BattleHex centralHex, ui8 schoolLvl, ui8 side, bool * outDroppedHexes = nullptr) const = 0;
virtual std::vector<const CStack *> getAffectedStacks(const CBattleInfoCallback * cb, const SpellTargetingContext & ctx) const = 0;
2016-02-15 12:34:37 +02:00
2016-09-18 15:30:03 +02:00
virtual ESpellCastProblem::ESpellCastProblem canBeCast(const CBattleInfoCallback * cb, const ECastingMode::ECastingMode mode, const ISpellCaster * caster) const = 0;
2016-02-15 12:34:37 +02:00
2016-09-04 04:15:37 +02:00
virtual ESpellCastProblem::ESpellCastProblem canBeCast(const CBattleInfoCallback * cb, const SpellTargetingContext & ctx) const = 0;
2016-03-01 08:50:04 +02:00
2015-09-26 19:09:54 +02:00
virtual ESpellCastProblem::ESpellCastProblem isImmuneByStack(const ISpellCaster * caster, const CStack * obj) const = 0;
2016-02-15 12:34:37 +02:00
2015-03-09 21:07:28 +02:00
virtual void applyBattle(BattleInfo * battle, const BattleSpellCast * packet) const = 0;
2016-09-06 05:40:23 +02:00
virtual void battleCast(const SpellCastEnvironment * env, const BattleSpellCastParameters & parameters) const = 0;
2015-02-26 19:59:18 +02:00
//if true use generic algorithm for target existence check, see CSpell::canBeCast
virtual bool requiresCreatureTarget() const = 0;
static std::unique_ptr<ISpellMechanics> createMechanics(const CSpell * s);
protected:
const CSpell * owner;
};
struct DLL_LINKAGE AdventureSpellCastParameters
{
const CGHeroInstance * caster;
int3 pos;
};
class DLL_LINKAGE IAdventureSpellMechanics
{
public:
IAdventureSpellMechanics(const CSpell * s);
virtual ~IAdventureSpellMechanics() = default;
virtual bool adventureCast(const SpellCastEnvironment * env, const AdventureSpellCastParameters & parameters) const = 0;
static std::unique_ptr<IAdventureSpellMechanics> createMechanics(const CSpell * s);
protected:
const CSpell * owner;
};