mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-25 15:35:23 +00:00
89 lines
2.3 KiB
C++
89 lines
2.3 KiB
C++
#ifndef GAME_MWWORLD_REFDATA_H
|
|
#define GAME_MWWORLD_REFDATA_H
|
|
|
|
#include <string>
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
#include "../mwscript/locals.hpp"
|
|
|
|
namespace ESM
|
|
{
|
|
class Script;
|
|
}
|
|
|
|
namespace MWMechanics
|
|
{
|
|
struct CreatureStats;
|
|
}
|
|
|
|
namespace MWWorld
|
|
{
|
|
class RefData
|
|
{
|
|
std::string mHandle;
|
|
|
|
MWScript::Locals mLocals; // if we find the overhead of heaving a locals
|
|
// object in the refdata of refs without a script,
|
|
// we can make this a pointer later.
|
|
bool mHasLocals;
|
|
bool mEnabled;
|
|
|
|
// we are using shared pointer here to avoid having to create custom copy-constructor,
|
|
// assignment operator and destructor. As a consequence though copying a RefData object
|
|
// manually will probably give unexcepted results. This is not a problem since RefData
|
|
// are never copied outside of container operations.
|
|
boost::shared_ptr<MWMechanics::CreatureStats> mCreatureStats;
|
|
|
|
public:
|
|
|
|
RefData() : mHasLocals (false), mEnabled (true) {}
|
|
|
|
std::string getHandle()
|
|
{
|
|
return mHandle;
|
|
}
|
|
|
|
void setLocals (const ESM::Script& script)
|
|
{
|
|
if (!mHasLocals)
|
|
{
|
|
mLocals.configure (script);
|
|
mHasLocals = true;
|
|
}
|
|
}
|
|
|
|
void setHandle (const std::string& handle)
|
|
{
|
|
mHandle = handle;
|
|
}
|
|
|
|
MWScript::Locals& getLocals()
|
|
{
|
|
return mLocals;
|
|
}
|
|
|
|
bool isEnabled() const
|
|
{
|
|
return mEnabled;
|
|
}
|
|
|
|
void enable()
|
|
{
|
|
mEnabled = true;
|
|
}
|
|
|
|
void disable()
|
|
{
|
|
mEnabled = true;
|
|
}
|
|
|
|
boost::shared_ptr<MWMechanics::CreatureStats>& getCreatureStats()
|
|
{
|
|
return mCreatureStats;
|
|
}
|
|
};
|
|
}
|
|
|
|
#endif
|