1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-12 02:28:11 +02:00
This commit is contained in:
AlexVinS 2018-02-10 07:31:02 +03:00
parent 10dd7e8a43
commit c94daf6faa
4 changed files with 54 additions and 15 deletions

View File

@ -580,12 +580,7 @@ CSpell::TargetInfo::TargetInfo(const CSpell * spell, const int level, spells::Mo
clearAffected = levelInfo.clearAffected; clearAffected = levelInfo.clearAffected;
clearTarget = levelInfo.clearTarget; clearTarget = levelInfo.clearTarget;
if(mode == spells::Mode::ENCHANTER) if(mode == spells::Mode::CREATURE_ACTIVE)
{
smart = true; //FIXME: not sure about that, this makes all spells smart in this mode
massive = true;
}
else if(mode == spells::Mode::CREATURE_ACTIVE)
{ {
massive = false;//FIXME: find better solution for Commander spells massive = false;//FIXME: find better solution for Commander spells
} }

View File

@ -162,7 +162,9 @@ BattleCast::BattleCast(const CBattleInfoCallback * cb, const Caster * caster_, c
effectLevel(), effectLevel(),
effectPower(), effectPower(),
effectDuration(), effectDuration(),
effectValue() effectValue(),
smart(boost::logic::indeterminate),
massive(boost::logic::indeterminate)
{ {
} }
@ -176,7 +178,9 @@ BattleCast::BattleCast(const BattleCast & orig, const Caster * caster_)
effectLevel(orig.effectLevel), effectLevel(orig.effectLevel),
effectPower(orig.effectPower), effectPower(orig.effectPower),
effectDuration(orig.effectDuration), effectDuration(orig.effectDuration),
effectValue(orig.effectValue) effectValue(orig.effectValue),
smart(true),
massive(false)
{ {
} }
@ -233,6 +237,16 @@ BattleCast::OptionalValue64 BattleCast::getEffectValue() const
return effectValue; return effectValue;
} }
boost::logic::tribool BattleCast::isSmart() const
{
return smart;
}
boost::logic::tribool BattleCast::isMassive() const
{
return massive;
}
void BattleCast::setSpellLevel(BattleCast::Value value) void BattleCast::setSpellLevel(BattleCast::Value value)
{ {
spellLvl = boost::make_optional(value); spellLvl = boost::make_optional(value);
@ -455,7 +469,9 @@ Mechanics::~Mechanics() = default;
BaseMechanics::BaseMechanics(const IBattleCast * event) BaseMechanics::BaseMechanics(const IBattleCast * event)
: Mechanics(), : Mechanics(),
owner(event->getSpell()), owner(event->getSpell()),
mode(event->getMode()) mode(event->getMode()),
smart(event->isSmart()),
massive(event->isMassive())
{ {
cb = event->getBattle(); cb = event->getBattle();
caster = event->getCaster(); caster = event->getCaster();
@ -611,16 +627,30 @@ int32_t BaseMechanics::getSpellLevel() const
} }
bool BaseMechanics::isSmart() const bool BaseMechanics::isSmart() const
{
if(boost::logic::indeterminate(smart))
{ {
const CSpell::TargetInfo targetInfo(owner, getRangeLevel(), mode); const CSpell::TargetInfo targetInfo(owner, getRangeLevel(), mode);
return targetInfo.smart; return targetInfo.smart;
} }
else
{
return smart;
}
}
bool BaseMechanics::isMassive() const bool BaseMechanics::isMassive() const
{
if(boost::logic::indeterminate(massive))
{ {
const CSpell::TargetInfo targetInfo(owner, getRangeLevel(), mode); const CSpell::TargetInfo targetInfo(owner, getRangeLevel(), mode);
return targetInfo.massive; return targetInfo.massive;
} }
else
{
return massive;
}
}
bool BaseMechanics::requiresClearTiles() const bool BaseMechanics::requiresClearTiles() const
{ {

View File

@ -74,7 +74,6 @@ private:
IBattleState * battleState; IBattleState * battleState;
}; };
class DLL_LINKAGE IBattleCast class DLL_LINKAGE IBattleCast
{ {
public: public:
@ -96,6 +95,9 @@ public:
virtual OptionalValue getEffectDuration() const = 0; virtual OptionalValue getEffectDuration() const = 0;
virtual OptionalValue64 getEffectValue() const = 0; virtual OptionalValue64 getEffectValue() const = 0;
virtual boost::logic::tribool isSmart() const = 0;
virtual boost::logic::tribool isMassive() const = 0;
}; };
///all parameters of particular cast event ///all parameters of particular cast event
@ -104,6 +106,9 @@ class DLL_LINKAGE BattleCast : public IBattleCast
public: public:
Target target; Target target;
boost::logic::tribool smart;
boost::logic::tribool massive;
//normal constructor //normal constructor
BattleCast(const CBattleInfoCallback * cb, const Caster * caster_, const Mode mode_, const CSpell * spell_); BattleCast(const CBattleInfoCallback * cb, const Caster * caster_, const Mode mode_, const CSpell * spell_);
@ -126,6 +131,9 @@ public:
OptionalValue64 getEffectValue() const override; OptionalValue64 getEffectValue() const override;
boost::logic::tribool isSmart() const override;
boost::logic::tribool isMassive() const override;
void setSpellLevel(Value value); void setSpellLevel(Value value);
void setEffectLevel(Value value); void setEffectLevel(Value value);
void setRangeLevel(Value value); void setRangeLevel(Value value);
@ -306,8 +314,8 @@ public:
protected: protected:
const CSpell * owner; const CSpell * owner;
Mode mode; Mode mode;
private:
private:
IBattleCast::Value rangeLevel; IBattleCast::Value rangeLevel;
IBattleCast::Value effectLevel; IBattleCast::Value effectLevel;
@ -318,6 +326,9 @@ private:
///raw damage/heal amount ///raw damage/heal amount
IBattleCast::Value64 effectValue; IBattleCast::Value64 effectValue;
boost::logic::tribool smart;
boost::logic::tribool massive;
}; };
class DLL_LINKAGE IReceptiveCheck class DLL_LINKAGE IReceptiveCheck

View File

@ -4818,6 +4818,8 @@ void CGameHandler::stackTurnTrigger(const CStack *st)
}); });
spells::BattleCast parameters(gs->curB, st, spells::Mode::ENCHANTER, spell); spells::BattleCast parameters(gs->curB, st, spells::Mode::ENCHANTER, spell);
parameters.setSpellLevel(bonus->val); parameters.setSpellLevel(bonus->val);
parameters.massive = true;
parameters.smart = true;
//todo: recheck effect level //todo: recheck effect level
if(parameters.castIfPossible(spellEnv)) if(parameters.castIfPossible(spellEnv))
{ {
@ -5985,6 +5987,7 @@ void CGameHandler::runBattle()
spells::BattleCast parameters(gs->curB, h, spells::Mode::PASSIVE, spell); spells::BattleCast parameters(gs->curB, h, spells::Mode::PASSIVE, spell);
parameters.setSpellLevel(3); parameters.setSpellLevel(3);
parameters.setEffectDuration(b->val); parameters.setEffectDuration(b->val);
parameters.massive = true;
parameters.castIfPossible(spellEnv); parameters.castIfPossible(spellEnv);
} }
} }