2014-02-23 20:11:05 +01:00
|
|
|
#ifndef GAME_MWWORLD_CELLREFLIST_H
|
|
|
|
#define GAME_MWWORLD_CELLREFLIST_H
|
|
|
|
|
|
|
|
#include <list>
|
|
|
|
|
|
|
|
#include "livecellref.hpp"
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
2022-09-08 20:52:00 +02:00
|
|
|
struct CellRefListBase
|
|
|
|
{
|
|
|
|
};
|
|
|
|
|
2014-02-23 20:11:05 +01:00
|
|
|
/// \brief Collection of references of one type
|
|
|
|
template <typename X>
|
2022-09-08 20:52:00 +02:00
|
|
|
struct CellRefList : public CellRefListBase
|
2014-02-23 20:11:05 +01:00
|
|
|
{
|
|
|
|
typedef LiveCellRef<X> LiveRef;
|
|
|
|
typedef std::list<LiveRef> List;
|
|
|
|
List mList;
|
|
|
|
|
|
|
|
/// Search for the given reference in the given reclist from
|
|
|
|
/// ESMStore. Insert the reference into the list if a match is
|
|
|
|
/// found. If not, throw an exception.
|
|
|
|
/// Moved to cpp file, as we require a custom compare operator for it,
|
|
|
|
/// and the build will fail with an ugly three-way cyclic header dependence
|
|
|
|
/// so we need to pass the instantiation of the method to the linker, when
|
|
|
|
/// all methods are known.
|
|
|
|
void load(ESM::CellRef& ref, bool deleted, const MWWorld::ESMStore& esmStore);
|
|
|
|
|
2023-01-23 23:51:45 +01:00
|
|
|
void load(const ESM4::Reference& ref, bool deleted, const MWWorld::ESMStore& esmStore);
|
|
|
|
|
2014-02-23 20:11:05 +01:00
|
|
|
LiveRef& insert(const LiveRef& item)
|
|
|
|
{
|
|
|
|
mList.push_back(item);
|
|
|
|
return mList.back();
|
|
|
|
}
|
2016-07-22 03:58:23 +02:00
|
|
|
|
|
|
|
/// Remove all references with the given refNum from this list.
|
|
|
|
void remove(const ESM::RefNum& refNum)
|
|
|
|
{
|
|
|
|
for (typename List::iterator it = mList.begin(); it != mList.end();)
|
|
|
|
{
|
|
|
|
if (*it == refNum)
|
|
|
|
mList.erase(it++);
|
|
|
|
else
|
|
|
|
++it;
|
|
|
|
}
|
|
|
|
}
|
2014-02-23 20:11:05 +01:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|