openmw-tes3coop/apps/openmw/mwworld/refdata.hpp

93 lines
2.3 KiB
C++
Raw Normal View History

2010-07-03 13:41:20 +00:00
#ifndef GAME_MWWORLD_REFDATA_H
#define GAME_MWWORLD_REFDATA_H
2010-07-02 12:00:28 +00:00
#include <string>
#include <components/esm/defs.hpp>
2010-07-02 12:31:29 +00:00
#include "../mwscript/locals.hpp"
2010-08-04 12:37:23 +00:00
namespace Ogre
{
class SceneNode;
}
2010-07-02 12:31:29 +00:00
namespace ESM
{
class Script;
class CellRef;
2010-07-02 12:31:29 +00:00
}
2010-07-03 13:41:20 +00:00
namespace MWWorld
{
class CustomData;
2010-07-02 12:31:29 +00:00
class RefData
{
2011-10-30 21:31:49 +00:00
Ogre::SceneNode* mBaseNode;
2011-10-30 20:59:40 +00:00
2010-08-04 12:04:22 +00:00
2010-07-02 12:31:29 +00:00
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.
2010-07-02 15:21:27 +00:00
bool mHasLocals;
2010-07-09 14:07:03 +00:00
bool mEnabled;
2010-08-04 12:04:22 +00:00
int mCount; // 0: deleted
ESM::Position mPosition;
CustomData *mCustomData;
void copy (const RefData& refData);
void cleanup();
2010-08-04 12:04:22 +00:00
public:
/// @param cellRef Used to copy constant data such as position into this class where it can
/// be altered without effecting the original data. This makes it possible
/// to reset the position as the orignal data is still held in the CellRef
RefData (const ESM::CellRef& cellRef);
RefData (const RefData& refData);
~RefData();
RefData& operator= (const RefData& refData);
/// Return OGRE handle (may be empty).
std::string getHandle();
/// Return OGRE base node (can be a null pointer).
Ogre::SceneNode* getBaseNode();
/// Set OGRE base node (can be a null pointer).
void setBaseNode (Ogre::SceneNode* base);
int getCount() const;
void setLocals (const ESM::Script& script);
void setCount (int count);
MWScript::Locals& getLocals();
bool isEnabled() const;
void enable();
void disable();
ESM::Position& getPosition();
void setCustomData (CustomData *data);
///< Set custom data (potentially replacing old custom data). The ownership of \æ data is
/// transferred to this.
CustomData *getCustomData();
///< May return a 0-pointer. The ownership of the return data object is not transferred.
2010-08-04 12:04:22 +00:00
};
}
#endif