2014-01-16 12:03:23 +01:00
|
|
|
#include "livecellref.hpp"
|
|
|
|
|
2018-08-14 23:05:43 +04:00
|
|
|
#include <components/debug/debuglog.hpp>
|
2014-01-16 12:03:23 +01:00
|
|
|
#include <components/esm/objectstate.hpp>
|
|
|
|
|
2014-03-22 16:39:24 +01:00
|
|
|
#include "../mwbase/environment.hpp"
|
|
|
|
#include "../mwbase/world.hpp"
|
2021-01-29 02:38:09 +01:00
|
|
|
#include "../mwbase/luamanager.hpp"
|
2014-03-22 16:39:24 +01:00
|
|
|
|
2014-01-30 11:50:13 +01:00
|
|
|
#include "ptr.hpp"
|
|
|
|
#include "class.hpp"
|
2014-03-22 16:39:24 +01:00
|
|
|
#include "esmstore.hpp"
|
2014-01-30 11:50:13 +01:00
|
|
|
|
2015-12-18 17:08:26 +01:00
|
|
|
MWWorld::LiveCellRefBase::LiveCellRefBase(const std::string& type, const ESM::CellRef &cref)
|
2014-05-25 14:13:07 +02:00
|
|
|
: mClass(&Class::get(type)), mRef(cref), mData(cref)
|
2014-05-08 13:47:54 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-01-16 12:03:23 +01:00
|
|
|
void MWWorld::LiveCellRefBase::loadImp (const ESM::ObjectState& state)
|
|
|
|
{
|
|
|
|
mRef = state.mRef;
|
2015-12-12 22:33:14 +01:00
|
|
|
mData = RefData (state, mData.isDeletedByContentFile());
|
2014-03-22 15:00:49 +01:00
|
|
|
|
2014-01-30 11:50:13 +01:00
|
|
|
Ptr ptr (this);
|
2014-03-22 15:00:49 +01:00
|
|
|
|
|
|
|
if (state.mHasLocals)
|
2014-03-22 16:39:24 +01:00
|
|
|
{
|
|
|
|
std::string scriptId = mClass->getScript (ptr);
|
2014-05-10 18:14:35 +02:00
|
|
|
// Make sure we still have a script. It could have been coming from a content file that is no longer active.
|
|
|
|
if (!scriptId.empty())
|
|
|
|
{
|
|
|
|
if (const ESM::Script* script = MWBase::Environment::get().getWorld()->getStore().get<ESM::Script>().search (scriptId))
|
|
|
|
{
|
2014-09-22 10:12:07 +02:00
|
|
|
try
|
|
|
|
{
|
|
|
|
mData.setLocals (*script);
|
|
|
|
mData.getLocals().read (state.mLocals, scriptId);
|
|
|
|
}
|
|
|
|
catch (const std::exception& exception)
|
|
|
|
{
|
2018-08-14 23:05:43 +04:00
|
|
|
Log(Debug::Error)
|
2017-03-02 22:07:43 +01:00
|
|
|
<< "Error: failed to load state for local script " << scriptId
|
2018-08-14 23:05:43 +04:00
|
|
|
<< " because an exception has been thrown: " << exception.what();
|
2014-09-22 10:12:07 +02:00
|
|
|
}
|
2014-05-10 18:14:35 +02:00
|
|
|
}
|
|
|
|
}
|
2014-03-22 16:39:24 +01:00
|
|
|
}
|
2014-03-22 15:00:49 +01:00
|
|
|
|
2014-01-30 11:50:13 +01:00
|
|
|
mClass->readAdditionalState (ptr, state);
|
2018-03-08 23:38:04 +00:00
|
|
|
|
|
|
|
if (!mRef.getSoul().empty() && !MWBase::Environment::get().getWorld()->getStore().get<ESM::Creature>().search(mRef.getSoul()))
|
|
|
|
{
|
2018-08-14 23:05:43 +04:00
|
|
|
Log(Debug::Warning) << "Soul '" << mRef.getSoul() << "' not found, removing the soul from soul gem";
|
2018-03-08 23:38:04 +00:00
|
|
|
mRef.setSoul(std::string());
|
|
|
|
}
|
2021-01-29 02:38:09 +01:00
|
|
|
|
|
|
|
MWBase::Environment::get().getLuaManager()->loadLocalScripts(ptr, state.mLuaScripts);
|
2014-01-16 12:03:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void MWWorld::LiveCellRefBase::saveImp (ESM::ObjectState& state) const
|
|
|
|
{
|
2014-05-25 14:13:07 +02:00
|
|
|
mRef.writeState(state);
|
2014-03-22 15:00:49 +01:00
|
|
|
|
2015-12-18 00:18:06 +01:00
|
|
|
ConstPtr ptr (this);
|
2014-03-22 15:00:49 +01:00
|
|
|
|
|
|
|
mData.write (state, mClass->getScript (ptr));
|
2021-01-29 02:38:09 +01:00
|
|
|
MWBase::Environment::get().getLuaManager()->saveLocalScripts(Ptr(const_cast<LiveCellRefBase*>(this)), state.mLuaScripts);
|
2014-03-22 15:00:49 +01:00
|
|
|
|
2014-01-30 11:50:13 +01:00
|
|
|
mClass->writeAdditionalState (ptr, state);
|
2014-01-16 12:03:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool MWWorld::LiveCellRefBase::checkStateImp (const ESM::ObjectState& state)
|
|
|
|
{
|
|
|
|
return true;
|
2014-05-09 23:58:24 +02:00
|
|
|
}
|