openmw-tes3coop/apps/openmw/mwworld/ptr.hpp
scrawl 039398c8ae Basic RefData and CellRef change tracking
Wrapped item charge handling in getItemHealth function
2014-05-25 14:30:07 +02:00

119 lines
2.9 KiB
C++

#ifndef GAME_MWWORLD_PTR_H
#define GAME_MWWORLD_PTR_H
#include <cassert>
#include <string>
#include <sstream>
#include "cellreflist.hpp"
namespace MWWorld
{
class ContainerStore;
class CellStore;
class LiveCellRefBase;
/// \brief Pointer to a LiveCellRef
class Ptr
{
public:
MWWorld::LiveCellRefBase *mRef;
CellStore *mCell;
ContainerStore *mContainerStore;
public:
Ptr(MWWorld::LiveCellRefBase *liveCellRef=0, CellStore *cell=0)
: mRef(liveCellRef), mCell(cell), mContainerStore(0)
{
}
bool isEmpty() const
{
return mRef == 0;
}
const std::string& getTypeName() const;
const Class& getClass() const
{
if(mRef != 0)
return *(mRef->mClass);
throw std::runtime_error("Cannot get class of an empty object");
}
template<typename T>
MWWorld::LiveCellRef<T> *get() const
{
MWWorld::LiveCellRef<T> *ref = dynamic_cast<MWWorld::LiveCellRef<T>*>(mRef);
if(ref) return ref;
std::stringstream str;
str<< "Bad LiveCellRef cast to "<<typeid(T).name()<<" from ";
if(mRef != 0) str<< getTypeName();
else str<< "an empty object";
throw std::runtime_error(str.str());
}
MWWorld::LiveCellRefBase *getBase() const;
MWWorld::CellRef& getCellRef() const;
RefData& getRefData() const;
CellStore *getCell() const
{
assert(mCell);
return mCell;
}
bool isInCell() const
{
return (mContainerStore == 0) && (mCell != 0);
}
void setContainerStore (ContainerStore *store);
///< Must not be called on references that are in a cell.
ContainerStore *getContainerStore() const;
///< May return a 0-pointer, if reference is not in a container.
operator const void *();
///< Return a 0-pointer, if Ptr is empty; return a non-0-pointer, if Ptr is not empty
};
inline bool operator== (const Ptr& left, const Ptr& right)
{
return left.mRef==right.mRef;
}
inline bool operator!= (const Ptr& left, const Ptr& right)
{
return !(left==right);
}
inline bool operator< (const Ptr& left, const Ptr& right)
{
return left.mRef<right.mRef;
}
inline bool operator>= (const Ptr& left, const Ptr& right)
{
return !(left<right);
}
inline bool operator> (const Ptr& left, const Ptr& right)
{
return right<left;
}
inline bool operator<= (const Ptr& left, const Ptr& right)
{
return !(left>right);
}
}
#endif