#ifndef GAME_MWWORLD_REFDATA_H #define GAME_MWWORLD_REFDATA_H #include #include #include "../mwscript/locals.hpp" #include "containerstore.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; int mCount; // 0: deleted // 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 mCreatureStats; boost::shared_ptr > mContainerStore; public: RefData() : mHasLocals (false), mEnabled (true), mCount (1) {} std::string getHandle() { return mHandle; } int getCount() const { return mCount; } void setLocals (const ESM::Script& script) { if (!mHasLocals) { mLocals.configure (script); mHasLocals = true; } } void setHandle (const std::string& handle) { mHandle = handle; } void setCount (int count) { mCount = count; } MWScript::Locals& getLocals() { return mLocals; } bool isEnabled() const { return mEnabled; } void enable() { mEnabled = true; } void disable() { mEnabled = true; } boost::shared_ptr& getCreatureStats() { return mCreatureStats; } boost::shared_ptr >& getContainerStore() { return mContainerStore; } }; } #endif