1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 15:35:23 +00:00

103 lines
2.8 KiB
C++
Raw Normal View History

#ifndef AISTATE_H
#define AISTATE_H
#include <typeinfo>
2014-10-10 23:28:49 +02:00
namespace MWMechanics
{
2014-10-10 23:28:49 +02:00
/** \brief stores one object of any class derived from Base.
* Requesting a certain derived class via get() either returns
2014-10-10 23:28:49 +02:00
* the stored object if it has the correct type or otherwise replaces
* it with an object of the requested type.
*/
template< class Base >
class DerivedClassStorage
{
private:
Base* mStorage;
2014-10-10 23:28:49 +02:00
//if needed you have to provide a clone member function
DerivedClassStorage( const DerivedClassStorage& other );
DerivedClassStorage& operator=( const DerivedClassStorage& );
public:
/// \brief returns reference to stored object or deletes it and creates a fitting
template< class Derived >
Derived& get()
{
Derived* result = dynamic_cast<Derived*>(mStorage);
if(!result)
{
if(mStorage)
delete mStorage;
mStorage = result = new Derived();
}
//return a reference to the (new allocated) object
return *result;
}
template< class Derived >
void copy(DerivedClassStorage& destination) const
{
Derived* result = dynamic_cast<Derived*>(mStorage);
if (result != nullptr)
destination.store<Derived>(*result);
}
2014-10-10 23:28:49 +02:00
template< class Derived >
void store( const Derived& payload )
{
if(mStorage)
delete mStorage;
2014-10-10 23:28:49 +02:00
mStorage = new Derived(payload);
}
2014-10-10 23:28:49 +02:00
/// \brief takes ownership of the passed object
template< class Derived >
void moveIn( Derived* p )
{
if(mStorage)
delete mStorage;
mStorage = p;
}
2014-10-10 23:28:49 +02:00
bool empty() const
{
2018-10-09 10:21:12 +04:00
return mStorage == nullptr;
2014-10-10 23:28:49 +02:00
}
const std::type_info& getType() const
{
return typeid(mStorage);
}
2018-10-09 10:21:12 +04:00
DerivedClassStorage():mStorage(nullptr){}
2014-10-10 23:28:49 +02:00
~DerivedClassStorage()
{
if(mStorage)
delete mStorage;
}
};
2014-10-10 23:28:49 +02:00
2014-10-10 00:15:01 +02:00
/// \brief base class for the temporary storage of AiPackages.
/**
* Each AI package with temporary values needs a AiPackageStorage class
* which is derived from AiTemporaryBase. The Actor holds a container
2014-10-10 00:15:01 +02:00
* AiState where one of these storages can be stored at a time.
* The execute(...) member function takes this container as an argument.
* */
struct AiTemporaryBase
{
virtual ~AiTemporaryBase(){}
};
2014-10-10 00:15:01 +02:00
/// \brief Container for AI package status.
typedef DerivedClassStorage<AiTemporaryBase> AiState;
}
#endif // AISTATE_H