|
|
@ -230,36 +230,38 @@ namespace MWGui
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWBase::Environment::get().getWindowManager()->setKeyFocusWidget(mCloseButton);
|
|
|
|
MWBase::Environment::get().getWindowManager()->setKeyFocusWidget(mCloseButton);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Copy mPtr because onTakeAllButtonClicked closes the window which resets the reference
|
|
|
|
|
|
|
|
MWWorld::Ptr ptr = mPtr;
|
|
|
|
onTakeAllButtonClicked(mTakeButton);
|
|
|
|
onTakeAllButtonClicked(mTakeButton);
|
|
|
|
|
|
|
|
|
|
|
|
if (mPtr.getClass().isPersistent(mPtr))
|
|
|
|
if (ptr.getClass().isPersistent(ptr))
|
|
|
|
MWBase::Environment::get().getWindowManager()->messageBox("#{sDisposeCorpseFail}");
|
|
|
|
MWBase::Environment::get().getWindowManager()->messageBox("#{sDisposeCorpseFail}");
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWMechanics::CreatureStats& creatureStats = mPtr.getClass().getCreatureStats(mPtr);
|
|
|
|
MWMechanics::CreatureStats& creatureStats = ptr.getClass().getCreatureStats(ptr);
|
|
|
|
|
|
|
|
|
|
|
|
// If we dispose corpse before end of death animation, we should update death counter counter manually.
|
|
|
|
// If we dispose corpse before end of death animation, we should update death counter counter manually.
|
|
|
|
// Also we should run actor's script - it may react on actor's death.
|
|
|
|
// Also we should run actor's script - it may react on actor's death.
|
|
|
|
if (creatureStats.isDead() && !creatureStats.isDeathAnimationFinished())
|
|
|
|
if (creatureStats.isDead() && !creatureStats.isDeathAnimationFinished())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
creatureStats.setDeathAnimationFinished(true);
|
|
|
|
creatureStats.setDeathAnimationFinished(true);
|
|
|
|
MWBase::Environment::get().getMechanicsManager()->notifyDied(mPtr);
|
|
|
|
MWBase::Environment::get().getMechanicsManager()->notifyDied(ptr);
|
|
|
|
|
|
|
|
|
|
|
|
const std::string script = mPtr.getClass().getScript(mPtr);
|
|
|
|
const std::string script = ptr.getClass().getScript(ptr);
|
|
|
|
if (!script.empty() && MWBase::Environment::get().getWorld()->getScriptsEnabled())
|
|
|
|
if (!script.empty() && MWBase::Environment::get().getWorld()->getScriptsEnabled())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWScript::InterpreterContext interpreterContext (&mPtr.getRefData().getLocals(), mPtr);
|
|
|
|
MWScript::InterpreterContext interpreterContext (&ptr.getRefData().getLocals(), ptr);
|
|
|
|
MWBase::Environment::get().getScriptManager()->run (script, interpreterContext);
|
|
|
|
MWBase::Environment::get().getScriptManager()->run (script, interpreterContext);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Clean up summoned creatures as well
|
|
|
|
// Clean up summoned creatures as well
|
|
|
|
std::map<ESM::SummonKey, int>& creatureMap = creatureStats.getSummonedCreatureMap();
|
|
|
|
std::map<ESM::SummonKey, int>& creatureMap = creatureStats.getSummonedCreatureMap();
|
|
|
|
for (const auto& creature : creatureMap)
|
|
|
|
for (const auto& creature : creatureMap)
|
|
|
|
MWBase::Environment::get().getMechanicsManager()->cleanupSummonedCreature(mPtr, creature.second);
|
|
|
|
MWBase::Environment::get().getMechanicsManager()->cleanupSummonedCreature(ptr, creature.second);
|
|
|
|
creatureMap.clear();
|
|
|
|
creatureMap.clear();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MWBase::Environment::get().getWorld()->deleteObject(mPtr);
|
|
|
|
MWBase::Environment::get().getWorld()->deleteObject(ptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mPtr = MWWorld::Ptr();
|
|
|
|
mPtr = MWWorld::Ptr();
|
|
|
|