|
|
@ -31,33 +31,41 @@ void CellStore::loadRefs(const Cell &cell, const ESMStore &store, ESMReader &esm
|
|
|
|
// Get each reference in turn
|
|
|
|
// Get each reference in turn
|
|
|
|
while(cell.getNextRef(esm, ref))
|
|
|
|
while(cell.getNextRef(esm, ref))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
cout << "Reference: " << ref.refID;
|
|
|
|
int rec = store.find(ref.refID);
|
|
|
|
|
|
|
|
|
|
|
|
// Check each list in turn. Potential for optimization.
|
|
|
|
/* We can optimize this further by storing the pointer to the
|
|
|
|
if(
|
|
|
|
record itself in store.all, so that we don't need to look it
|
|
|
|
activators .find(ref, store.activators) &&
|
|
|
|
up again here. However, never optimize. There are infinite
|
|
|
|
potions .find(ref, store.potions) &&
|
|
|
|
opportunities to do that later.
|
|
|
|
appas .find(ref, store.appas) &&
|
|
|
|
*/
|
|
|
|
armors .find(ref, store.armors) &&
|
|
|
|
switch(rec)
|
|
|
|
books .find(ref, store.books) &&
|
|
|
|
{
|
|
|
|
clothes .find(ref, store.clothes) &&
|
|
|
|
case REC_ACTI: activators.find(ref, store.activators); break;
|
|
|
|
containers .find(ref, store.containers) &&
|
|
|
|
case REC_ALCH: potions.find(ref, store.potions); break;
|
|
|
|
creatures .find(ref, store.creatures) &&
|
|
|
|
case REC_APPA: appas.find(ref, store.appas); break;
|
|
|
|
doors .find(ref, store.doors) &&
|
|
|
|
case REC_ARMO: armors.find(ref, store.armors); break;
|
|
|
|
ingreds .find(ref, store.ingreds) &&
|
|
|
|
case REC_BOOK: books.find(ref, store.books); break;
|
|
|
|
creatureLists .find(ref, store.creatureLists) &&
|
|
|
|
case REC_CLOT: clothes.find(ref, store.clothes); break;
|
|
|
|
itemLists .find(ref, store.itemLists) &&
|
|
|
|
case REC_CONT: containers.find(ref, store.containers); break;
|
|
|
|
lights .find(ref, store.lights) &&
|
|
|
|
case REC_CREA: creatures.find(ref, store.creatures); break;
|
|
|
|
lockpicks .find(ref, store.lockpicks) &&
|
|
|
|
case REC_DOOR: doors.find(ref, store.doors); break;
|
|
|
|
miscItems .find(ref, store.miscItems) &&
|
|
|
|
case REC_INGR: ingreds.find(ref, store.ingreds); break;
|
|
|
|
npcs .find(ref, store.npcs) &&
|
|
|
|
case REC_LEVC: creatureLists.find(ref, store.creatureLists); break;
|
|
|
|
probes .find(ref, store.probes) &&
|
|
|
|
case REC_LEVI: itemLists.find(ref, store.itemLists); break;
|
|
|
|
repairs .find(ref, store.repairs) &&
|
|
|
|
case REC_LIGH: lights.find(ref, store.lights); break;
|
|
|
|
statics .find(ref, store.statics) &&
|
|
|
|
case REC_LOCK: lockpicks.find(ref, store.lockpicks); break;
|
|
|
|
weapons .find(ref, store.weapons)
|
|
|
|
case REC_MISC: miscItems.find(ref, store.miscItems); break;
|
|
|
|
|
|
|
|
case REC_NPC_: npcs.find(ref, store.npcs); break;
|
|
|
|
) cout << " (NOT FOUND)";
|
|
|
|
case REC_PROB: probes.find(ref, store.probes); break;
|
|
|
|
|
|
|
|
case REC_REPA: repairs.find(ref, store.repairs); break;
|
|
|
|
cout << endl;
|
|
|
|
case REC_STAT: statics.find(ref, store.statics); break;
|
|
|
|
|
|
|
|
case REC_WEAP: weapons.find(ref, store.weapons); break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case 0: cout << "Cell reference " + ref.refID + " not found!\n"; break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
assert(0);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cout << "Statics in cell: " << statics.list.size() << endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|