Merge branch 'pathstore' into 'master'

Unify pathgrid store containers

See merge request OpenMW/openmw!2941
7344-support-launching-the-example-suite
psi29a 2 years ago
commit f15e371e89

@ -896,72 +896,36 @@ namespace MWWorld
bool interior = pathgrid.mData.mX == 0 && pathgrid.mData.mY == 0 bool interior = pathgrid.mData.mX == 0 && pathgrid.mData.mY == 0
&& mCells->search(pathgrid.mCell.getRefIdString()) != nullptr; && mCells->search(pathgrid.mCell.getRefIdString()) != nullptr;
ESM::RefId cell
= interior ? pathgrid.mCell : ESM::RefId::esm3ExteriorCell(pathgrid.mData.mX, pathgrid.mData.mY);
// deal with mods that have empty pathgrid records (Issue #6209) // deal with mods that have empty pathgrid records (Issue #6209)
// we assume that these records are empty on purpose (i.e. to remove old pathgrid on an updated cell) // we assume that these records are empty on purpose (i.e. to remove old pathgrid on an updated cell)
if (isDeleted || pathgrid.mPoints.empty() || pathgrid.mEdges.empty()) if (isDeleted || pathgrid.mPoints.empty() || pathgrid.mEdges.empty())
{ {
if (interior) mStatic.erase(cell);
{
Interior::iterator it = mInt.find(pathgrid.mCell);
if (it != mInt.end())
mInt.erase(it);
}
else
{
Exterior::iterator it = mExt.find(std::make_pair(pathgrid.mData.mX, pathgrid.mData.mY));
if (it != mExt.end())
mExt.erase(it);
}
return RecordId(ESM::RefId(), isDeleted); return RecordId(ESM::RefId(), isDeleted);
} }
// Try to overwrite existing record // Try to overwrite existing record
if (interior) auto ret = mStatic.emplace(cell, pathgrid);
{
std::pair<Interior::iterator, bool> ret = mInt.insert(std::make_pair(pathgrid.mCell, pathgrid));
if (!ret.second) if (!ret.second)
ret.first->second = pathgrid; ret.first->second = pathgrid;
}
else
{
std::pair<Exterior::iterator, bool> ret
= mExt.insert(std::make_pair(std::make_pair(pathgrid.mData.mX, pathgrid.mData.mY), pathgrid));
if (!ret.second)
ret.first->second = pathgrid;
}
return RecordId(ESM::RefId(), isDeleted); return RecordId(ESM::RefId(), isDeleted);
} }
size_t Store<ESM::Pathgrid>::getSize() const size_t Store<ESM::Pathgrid>::getSize() const
{ {
return mInt.size() + mExt.size(); return mStatic.size();
} }
void Store<ESM::Pathgrid>::setUp() {} void Store<ESM::Pathgrid>::setUp() {}
const ESM::Pathgrid* Store<ESM::Pathgrid>::search(int x, int y) const
{
Exterior::const_iterator it = mExt.find(std::make_pair(x, y));
if (it != mExt.end())
return &(it->second);
return nullptr;
}
const ESM::Pathgrid* Store<ESM::Pathgrid>::search(const ESM::RefId& name) const const ESM::Pathgrid* Store<ESM::Pathgrid>::search(const ESM::RefId& name) const
{ {
Interior::const_iterator it = mInt.find(ESM::RefId(name)); auto it = mStatic.find(name);
if (it != mInt.end()) if (it != mStatic.end())
return &(it->second); return &(it->second);
return nullptr; return nullptr;
} }
const ESM::Pathgrid* Store<ESM::Pathgrid>::find(int x, int y) const
{
const ESM::Pathgrid* pathgrid = search(x, y);
if (!pathgrid)
{
const std::string msg = "Pathgrid in cell '" + std::to_string(x) + " " + std::to_string(y) + "' not found";
throw std::runtime_error(msg);
}
return pathgrid;
}
const ESM::Pathgrid* Store<ESM::Pathgrid>::find(const ESM::RefId& name) const const ESM::Pathgrid* Store<ESM::Pathgrid>::find(const ESM::RefId& name) const
{ {
const ESM::Pathgrid* pathgrid = search(name); const ESM::Pathgrid* pathgrid = search(name);
@ -971,10 +935,7 @@ namespace MWWorld
} }
const ESM::Pathgrid* Store<ESM::Pathgrid>::search(const ESM::Cell& cell) const const ESM::Pathgrid* Store<ESM::Pathgrid>::search(const ESM::Cell& cell) const
{ {
if (!(cell.mData.mFlags & ESM::Cell::Interior)) return search(cell.mId);
return search(cell.mData.mX, cell.mData.mY);
else
return search(ESM::RefId::stringRefId(cell.mName));
} }
const ESM::Pathgrid* Store<ESM::Pathgrid>::search(const MWWorld::Cell& cellVariant) const const ESM::Pathgrid* Store<ESM::Pathgrid>::search(const MWWorld::Cell& cellVariant) const
{ {
@ -986,10 +947,7 @@ namespace MWWorld
} }
const ESM::Pathgrid* Store<ESM::Pathgrid>::find(const ESM::Cell& cell) const const ESM::Pathgrid* Store<ESM::Pathgrid>::find(const ESM::Cell& cell) const
{ {
if (!(cell.mData.mFlags & ESM::Cell::Interior)) return find(cell.mId);
return find(cell.mData.mX, cell.mData.mY);
else
return find(ESM::RefId::stringRefId(cell.mName));
} }
// Skill // Skill

@ -414,12 +414,7 @@ namespace MWWorld
class Store<ESM::Pathgrid> : public DynamicStore class Store<ESM::Pathgrid> : public DynamicStore
{ {
private: private:
typedef std::unordered_map<ESM::RefId, ESM::Pathgrid> Interior; std::unordered_map<ESM::RefId, ESM::Pathgrid> mStatic;
typedef std::map<std::pair<int, int>, ESM::Pathgrid> Exterior;
Interior mInt;
Exterior mExt;
Store<ESM::Cell>* mCells; Store<ESM::Cell>* mCells;
public: public:
@ -431,9 +426,7 @@ namespace MWWorld
void setUp() override; void setUp() override;
const ESM::Pathgrid* search(int x, int y) const;
const ESM::Pathgrid* search(const ESM::RefId& name) const; const ESM::Pathgrid* search(const ESM::RefId& name) const;
const ESM::Pathgrid* find(int x, int y) const;
const ESM::Pathgrid* find(const ESM::RefId& name) const; const ESM::Pathgrid* find(const ESM::RefId& name) const;
const ESM::Pathgrid* search(const ESM::Cell& cell) const; const ESM::Pathgrid* search(const ESM::Cell& cell) const;
const ESM::Pathgrid* search(const MWWorld::Cell& cell) const; const ESM::Pathgrid* search(const MWWorld::Cell& cell) const;

Loading…
Cancel
Save