1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 06:35:30 +00:00
OpenMW/apps/openmw/mwworld/cellstore.cpp

123 lines
3.9 KiB
C++
Raw Normal View History

#include "cellstore.hpp"
#include <iostream>
#include "../mwbase/environment.hpp"
#include "../mwbase/world.hpp"
#include "ptr.hpp"
2012-10-01 19:17:04 +04:00
#include "esmstore.hpp"
namespace MWWorld
{
2012-11-05 16:07:59 +04:00
CellStore::CellStore (const ESM::Cell *cell)
: mCell (cell), mState (State_Unloaded)
{
2012-09-17 11:37:50 +04:00
mWaterLevel = cell->mWater;
}
2012-10-01 19:17:04 +04:00
void CellStore::load (const MWWorld::ESMStore &store, ESM::ESMReader &esm)
{
if (mState!=State_Loaded)
{
if (mState==State_Preloaded)
mIds.clear();
2012-11-05 16:07:59 +04:00
std::cout << "loading cell " << mCell->getDescription() << std::endl;
loadRefs (store, esm);
mState = State_Loaded;
}
}
2012-10-01 19:17:04 +04:00
void CellStore::preload (const MWWorld::ESMStore &store, ESM::ESMReader &esm)
{
if (mState==State_Unloaded)
{
listRefs (store, esm);
mState = State_Preloaded;
}
}
2012-10-01 19:17:04 +04:00
void CellStore::listRefs(const MWWorld::ESMStore &store, ESM::ESMReader &esm)
{
2012-11-05 16:07:59 +04:00
assert (mCell);
2012-11-05 16:07:59 +04:00
if (mCell->mContext.filename.empty())
return; // this is a dynamically generated cell -> skipping.
// Reopen the ESM reader and seek to the right position.
2012-11-05 16:07:59 +04:00
mCell->restore (esm);
ESM::CellRef ref;
// Get each reference in turn
2012-11-05 16:07:59 +04:00
while (mCell->getNextRef (esm, ref))
{
2013-01-09 20:51:52 +01:00
std::string lowerCase = Misc::StringUtils::lowerCase (ref.mRefID);
mIds.push_back (lowerCase);
}
std::sort (mIds.begin(), mIds.end());
}
2012-10-01 19:17:04 +04:00
void CellStore::loadRefs(const MWWorld::ESMStore &store, ESM::ESMReader &esm)
{
2012-11-05 16:07:59 +04:00
assert (mCell);
2012-11-05 16:07:59 +04:00
if (mCell->mContext.filename.empty())
return; // this is a dynamically generated cell -> skipping.
// Reopen the ESM reader and seek to the right position.
2012-11-05 16:07:59 +04:00
mCell->restore(esm);
ESM::CellRef ref;
// Get each reference in turn
2012-11-05 16:07:59 +04:00
while(mCell->getNextRef(esm, ref))
{
2013-01-09 20:51:52 +01:00
std::string lowerCase = Misc::StringUtils::lowerCase(ref.mRefID);
2012-09-17 11:37:50 +04:00
int rec = store.find(ref.mRefID);
2012-09-17 11:37:50 +04:00
ref.mRefID = lowerCase;
/* We can optimize this further by storing the pointer to the
record itself in store.all, so that we don't need to look it
up again here. However, never optimize. There are infinite
opportunities to do that later.
*/
switch(rec)
{
case ESM::REC_ACTI: mActivators.load(ref, store); break;
case ESM::REC_ALCH: mPotions.load(ref, store); break;
case ESM::REC_APPA: mAppas.load(ref, store); break;
case ESM::REC_ARMO: mArmors.load(ref, store); break;
case ESM::REC_BOOK: mBooks.load(ref, store); break;
case ESM::REC_CLOT: mClothes.load(ref, store); break;
case ESM::REC_CONT: mContainers.load(ref, store); break;
case ESM::REC_CREA: mCreatures.load(ref, store); break;
case ESM::REC_DOOR: mDoors.load(ref, store); break;
case ESM::REC_INGR: mIngreds.load(ref, store); break;
case ESM::REC_LEVC: mCreatureLists.load(ref, store); break;
case ESM::REC_LEVI: mItemLists.load(ref, store); break;
case ESM::REC_LIGH: mLights.load(ref, store); break;
case ESM::REC_LOCK: mLockpicks.load(ref, store); break;
case ESM::REC_MISC: mMiscItems.load(ref, store); break;
case ESM::REC_NPC_: mNpcs.load(ref, store); break;
case ESM::REC_PROB: mProbes.load(ref, store); break;
case ESM::REC_REPA: mRepairs.load(ref, store); break;
case ESM::REC_STAT: mStatics.load(ref, store); break;
case ESM::REC_WEAP: mWeapons.load(ref, store); break;
2012-09-17 11:37:50 +04:00
case 0: std::cout << "Cell reference " + ref.mRefID + " not found!\n"; break;
default:
2012-09-17 11:37:50 +04:00
std::cout << "WARNING: Ignoring reference '" << ref.mRefID << "' of unhandled type\n";
}
}
}
}