forked from mirror/openmw-tes3mp
Port LocalScripts::addCell to new CellStore interfaces
This commit is contained in:
parent
a517f4f9ba
commit
9ea475d00c
1 changed files with 41 additions and 48 deletions
|
@ -11,46 +11,54 @@
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
template<typename T>
|
|
||||||
void listCellScripts (MWWorld::LocalScripts& localScripts,
|
|
||||||
MWWorld::CellRefList<T>& cellRefList, MWWorld::CellStore *cell)
|
|
||||||
{
|
|
||||||
for (typename MWWorld::CellRefList<T>::List::iterator iter (
|
|
||||||
cellRefList.mList.begin());
|
|
||||||
iter!=cellRefList.mList.end(); ++iter)
|
|
||||||
{
|
|
||||||
if (!iter->mBase->mScript.empty() && !iter->mData.isDeleted())
|
|
||||||
{
|
|
||||||
localScripts.add (iter->mBase->mScript, MWWorld::Ptr (&*iter, cell));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Adds scripts for items in containers (containers/npcs/creatures)
|
struct AddScriptsVisitor
|
||||||
template<typename T>
|
|
||||||
void listCellScriptsCont (MWWorld::LocalScripts& localScripts,
|
|
||||||
MWWorld::CellRefList<T>& cellRefList, MWWorld::CellStore *cell)
|
|
||||||
{
|
{
|
||||||
for (typename MWWorld::CellRefList<T>::List::iterator iter (
|
AddScriptsVisitor(MWWorld::LocalScripts& scripts)
|
||||||
cellRefList.mList.begin());
|
: mScripts(scripts)
|
||||||
iter!=cellRefList.mList.end(); ++iter)
|
|
||||||
{
|
{
|
||||||
|
}
|
||||||
|
MWWorld::LocalScripts& mScripts;
|
||||||
|
|
||||||
MWWorld::Ptr containerPtr (&*iter, cell);
|
bool operator()(const MWWorld::Ptr& ptr)
|
||||||
|
{
|
||||||
|
if (ptr.getRefData().isDeleted())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
std::string script = ptr.getClass().getScript(ptr);
|
||||||
|
|
||||||
|
if (!script.empty())
|
||||||
|
mScripts.add(script, ptr);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
struct AddContainerItemScriptsVisitor
|
||||||
|
{
|
||||||
|
AddContainerItemScriptsVisitor(MWWorld::LocalScripts& scripts)
|
||||||
|
: mScripts(scripts)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
MWWorld::LocalScripts& mScripts;
|
||||||
|
|
||||||
|
bool operator()(const MWWorld::Ptr& containerPtr)
|
||||||
|
{
|
||||||
MWWorld::ContainerStore& container = containerPtr.getClass().getContainerStore(containerPtr);
|
MWWorld::ContainerStore& container = containerPtr.getClass().getContainerStore(containerPtr);
|
||||||
for(MWWorld::ContainerStoreIterator it3 = container.begin(); it3 != container.end(); ++it3)
|
for(MWWorld::ContainerStoreIterator it = container.begin(); it != container.end(); ++it)
|
||||||
{
|
{
|
||||||
std::string script = it3->getClass().getScript(*it3);
|
std::string script = it->getClass().getScript(*it);
|
||||||
if(script != "")
|
if(script != "")
|
||||||
{
|
{
|
||||||
MWWorld::Ptr item = *it3;
|
MWWorld::Ptr item = *it;
|
||||||
item.mCell = cell;
|
item.mCell = containerPtr.getCell();
|
||||||
localScripts.add (script, item);
|
mScripts.add (script, item);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MWWorld::LocalScripts::LocalScripts (const MWWorld::ESMStore& store) : mStore (store) {}
|
MWWorld::LocalScripts::LocalScripts (const MWWorld::ESMStore& store) : mStore (store) {}
|
||||||
|
@ -116,28 +124,13 @@ void MWWorld::LocalScripts::add (const std::string& scriptName, const Ptr& ptr)
|
||||||
|
|
||||||
void MWWorld::LocalScripts::addCell (CellStore *cell)
|
void MWWorld::LocalScripts::addCell (CellStore *cell)
|
||||||
{
|
{
|
||||||
/*
|
AddScriptsVisitor addScriptsVisitor(*this);
|
||||||
listCellScripts (*this, cell->get<ESM::Activator>(), cell);
|
cell->forEach(addScriptsVisitor);
|
||||||
listCellScripts (*this, cell->get<ESM::Potion>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Apparatus>(), cell);
|
AddContainerItemScriptsVisitor addContainerItemScriptsVisitor(*this);
|
||||||
listCellScripts (*this, cell->get<ESM::Armor>(), cell);
|
cell->forEachType<ESM::NPC>(addContainerItemScriptsVisitor);
|
||||||
listCellScripts (*this, cell->get<ESM::Book>(), cell);
|
cell->forEachType<ESM::Creature>(addContainerItemScriptsVisitor);
|
||||||
listCellScripts (*this, cell->get<ESM::Clothing>(), cell);
|
cell->forEachType<ESM::Container>(addContainerItemScriptsVisitor);
|
||||||
listCellScripts (*this, cell->get<ESM::Container>(), cell);
|
|
||||||
listCellScriptsCont (*this, cell->get<ESM::Container>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Creature>(), cell);
|
|
||||||
listCellScriptsCont (*this, cell->get<ESM::Creature>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Door>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Ingredient>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Light>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Lockpick>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Miscellaneous>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::NPC>(), cell);
|
|
||||||
listCellScriptsCont (*this, cell->get<ESM::NPC>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Probe>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Repair>(), cell);
|
|
||||||
listCellScripts (*this, cell->get<ESM::Weapon>(), cell);
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MWWorld::LocalScripts::clear()
|
void MWWorld::LocalScripts::clear()
|
||||||
|
|
Loading…
Reference in a new issue