|
|
@ -114,10 +114,8 @@ void adjustCommandedActor (const MWWorld::Ptr& actor)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!check.mCommanded && hasCommandPackage)
|
|
|
|
if (!check.mCommanded && hasCommandPackage)
|
|
|
|
{
|
|
|
|
|
|
|
|
stats.getAiSequence().erase(it);
|
|
|
|
stats.getAiSequence().erase(it);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void getRestorationPerHourOfSleep (const MWWorld::Ptr& ptr, float& health, float& magicka)
|
|
|
|
void getRestorationPerHourOfSleep (const MWWorld::Ptr& ptr, float& health, float& magicka)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -708,15 +706,7 @@ namespace MWMechanics
|
|
|
|
// any value of calm > 0 will stop the actor from fighting
|
|
|
|
// any value of calm > 0 will stop the actor from fighting
|
|
|
|
if ((effects.get(ESM::MagicEffect::CalmHumanoid).getMagnitude() > 0 && ptr.getClass().isNpc())
|
|
|
|
if ((effects.get(ESM::MagicEffect::CalmHumanoid).getMagnitude() > 0 && ptr.getClass().isNpc())
|
|
|
|
|| (effects.get(ESM::MagicEffect::CalmCreature).getMagnitude() > 0 && !ptr.getClass().isNpc()))
|
|
|
|
|| (effects.get(ESM::MagicEffect::CalmCreature).getMagnitude() > 0 && !ptr.getClass().isNpc()))
|
|
|
|
{
|
|
|
|
creatureStats.getAiSequence().stopCombat();
|
|
|
|
for (std::list<AiPackage*>::const_iterator it = creatureStats.getAiSequence().begin(); it != creatureStats.getAiSequence().end(); )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if ((*it)->getTypeId() == AiPackage::TypeIdCombat)
|
|
|
|
|
|
|
|
it = creatureStats.getAiSequence().erase(it);
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
++it;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Update bound effects
|
|
|
|
// Update bound effects
|
|
|
|
// Note: in vanilla MW multiple bound items of the same type can be created by different spells.
|
|
|
|
// Note: in vanilla MW multiple bound items of the same type can be created by different spells.
|
|
|
|