[Client] Iterate through CellStore's mergedRefs when initializing Actors

0.6.1
David Cernat 8 years ago
parent ebf9df3fe2
commit cad3eb8968

@ -1,6 +1,8 @@
#include <components/esm/cellid.hpp> #include <components/esm/cellid.hpp>
#include <components/openmw-mp/Log.hpp> #include <components/openmw-mp/Log.hpp>
#include "../mwworld/class.hpp"
#include "../mwworld/livecellref.hpp"
#include "../mwworld/worldimp.hpp" #include "../mwworld/worldimp.hpp"
#include "Cell.hpp" #include "Cell.hpp"
@ -272,25 +274,13 @@ void Cell::initializeLocalActor(const MWWorld::Ptr& ptr)
void Cell::initializeLocalActors() void Cell::initializeLocalActors()
{ {
MWWorld::CellRefList<ESM::NPC> *npcList = store->getNpcs(); std::vector<MWWorld::LiveCellRefBase*> *mergedRefs = store->getMergedRefs();
for (typename MWWorld::CellRefList<ESM::NPC>::List::iterator listIter(npcList->mList.begin()); for (std::vector<MWWorld::LiveCellRefBase*>::iterator it = mergedRefs->begin(); it != mergedRefs->end(); ++it)
listIter != npcList->mList.end(); ++listIter)
{ {
MWWorld::Ptr ptr(&*listIter, store); if ((*it)->mClass->isActor())
// If this Ptr is lacking a unique index, ignore it
if (ptr.getCellRef().getRefNum().mIndex == 0 && ptr.getCellRef().getMpNum() == 0) continue;
initializeLocalActor(ptr);
}
MWWorld::CellRefList<ESM::Creature> *creatureList = store->getCreatures();
for (typename MWWorld::CellRefList<ESM::Creature>::List::iterator listIter(creatureList->mList.begin());
listIter != creatureList->mList.end(); ++listIter)
{ {
MWWorld::Ptr ptr(&*listIter, store); MWWorld::Ptr ptr(*it, store);
// If this Ptr is lacking a unique index, ignore it // If this Ptr is lacking a unique index, ignore it
if (ptr.getCellRef().getRefNum().mIndex == 0 && ptr.getCellRef().getMpNum() == 0) continue; if (ptr.getCellRef().getRefNum().mIndex == 0 && ptr.getCellRef().getMpNum() == 0) continue;
@ -298,6 +288,7 @@ void Cell::initializeLocalActors()
initializeLocalActor(ptr); initializeLocalActor(ptr);
} }
} }
}
void Cell::initializeDedicatedActor(const MWWorld::Ptr& ptr) void Cell::initializeDedicatedActor(const MWWorld::Ptr& ptr)
{ {

Loading…
Cancel
Save