mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-25 03:53:50 +00:00
7aa0f887c0
1. Changed mIndex to unsigned, to solve potential implementation defined behavior with right shift. 2. Refactoring to minimize use of magic number -1 to indicate "no Content File".
56 lines
1.8 KiB
C++
56 lines
1.8 KiB
C++
#ifndef GAME_MWWORLD_CELLREFLIST_H
|
|
#define GAME_MWWORLD_CELLREFLIST_H
|
|
|
|
#include <list>
|
|
|
|
#include "livecellref.hpp"
|
|
|
|
namespace MWWorld
|
|
{
|
|
/// \brief Collection of references of one type
|
|
template <typename X>
|
|
struct CellRefList
|
|
{
|
|
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);
|
|
|
|
LiveRef *find (const std::string& name)
|
|
{
|
|
for (typename List::iterator iter (mList.begin()); iter!=mList.end(); ++iter)
|
|
if (!iter->mData.isDeletedByContentFile()
|
|
&& (iter->mRef.hasContentFile() || iter->mData.getCount() > 0)
|
|
&& iter->mRef.getRefId() == name)
|
|
return &*iter;
|
|
|
|
return 0;
|
|
}
|
|
|
|
LiveRef &insert (const LiveRef &item)
|
|
{
|
|
mList.push_back(item);
|
|
return mList.back();
|
|
}
|
|
|
|
LiveCellRef<X> *searchViaHandle (const std::string& handle)
|
|
{
|
|
for (typename List::iterator iter (mList.begin()); iter!=mList.end(); ++iter)
|
|
if (iter->mData.getBaseNode() &&
|
|
iter->mData.getHandle()==handle)
|
|
return &*iter;
|
|
|
|
return 0;
|
|
}
|
|
};
|
|
}
|
|
|
|
#endif
|