mirror of
https://github.com/OpenMW/openmw.git
synced 2025-06-19 10:41:36 +00:00
Merge branch 'baby_dont_throw_me_no_more' into 'master'
Catch exceptions in ResolutionListener Closes #5946 See merge request OpenMW/openmw!727
This commit is contained in:
commit
0818a10df2
1 changed files with 17 additions and 3 deletions
|
@ -77,10 +77,24 @@ MWWorld::ResolutionListener::~ResolutionListener()
|
||||||
{
|
{
|
||||||
if(!mStore.mModified && mStore.mResolved && !mStore.mPtr.isEmpty())
|
if(!mStore.mModified && mStore.mResolved && !mStore.mPtr.isEmpty())
|
||||||
{
|
{
|
||||||
for(const auto&& ptr : mStore)
|
try
|
||||||
ptr.getRefData().setCount(0);
|
{
|
||||||
|
for(const auto&& ptr : mStore)
|
||||||
|
ptr.getRefData().setCount(0);
|
||||||
|
}
|
||||||
|
catch(const std::exception& e)
|
||||||
|
{
|
||||||
|
Log(Debug::Warning) << "Failed to clear temporary container contents of " << mStore.mPtr.get<ESM::Container>()->mBase->mId << ": " << e.what();
|
||||||
|
}
|
||||||
mStore.fillNonRandom(mStore.mPtr.get<ESM::Container>()->mBase->mInventory, "", mStore.mSeed);
|
mStore.fillNonRandom(mStore.mPtr.get<ESM::Container>()->mBase->mInventory, "", mStore.mSeed);
|
||||||
addScripts(mStore, mStore.mPtr.mCell);
|
try
|
||||||
|
{
|
||||||
|
addScripts(mStore, mStore.mPtr.mCell);
|
||||||
|
}
|
||||||
|
catch(const std::exception& e)
|
||||||
|
{
|
||||||
|
Log(Debug::Warning) << "Failed to restart item scripts inside " << mStore.mPtr.get<ESM::Container>()->mBase->mId << ": " << e.what();
|
||||||
|
}
|
||||||
mStore.mResolved = false;
|
mStore.mResolved = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue