#include "cell.hpp" #include "esmstore.hpp" #include "../mwbase/environment.hpp" #include #include #include #include #include #include namespace MWWorld { namespace { std::string getDescription(const ESM4::World& value) { if (!value.mEditorId.empty()) return value.mEditorId; return ESM::RefId(value.mId).serializeText(); } std::string getCellDescription(const ESM4::Cell& cell, const ESM4::World* world) { std::string result; if (!cell.mEditorId.empty()) result = cell.mEditorId; else if (world != nullptr && cell.isExterior()) result = getDescription(*world); else result = cell.mId.serializeText(); if (cell.isExterior()) result += " (" + std::to_string(cell.mX) + ", " + std::to_string(cell.mY) + ")"; return result; } } Cell::Cell(const ESM4::Cell& cell) : ESM::CellVariant(cell) , mIsExterior(!(cell.mCellFlags & ESM4::CELL_Interior)) , mIsQuasiExterior(cell.mCellFlags & ESM4::CELL_QuasiExt) , mHasWater(cell.mCellFlags & ESM4::CELL_HasWater) , mNoSleep(false) // No such notion in ESM4 , mGridPos(cell.mX, cell.mY) , mDisplayname(cell.mFullName) , mNameID(cell.mEditorId) , mRegion(ESM::RefId()) // Unimplemented for now , mId(cell.mId) , mParent(cell.mParent) , mWaterHeight(cell.mWaterHeight) , mMood{ .mAmbiantColor = cell.mLighting.ambient, .mDirectionalColor = cell.mLighting.directional, .mFogColor = cell.mLighting.fogColor, // TODO: use ESM4::Lighting fog parameters .mFogDensity = 1.f, } { const ESM4::World* world = MWBase::Environment::get().getESMStore()->get().search(mParent); if (isExterior()) { if (world == nullptr) throw std::runtime_error( "Cell " + cell.mId.toDebugString() + " parent world " + mParent.toDebugString() + " is not found"); mWaterHeight = world->mWaterLevel; } mDescription = getCellDescription(cell, world); } Cell::Cell(const ESM::Cell& cell) : ESM::CellVariant(cell) , mIsExterior(!(cell.mData.mFlags & ESM::Cell::Interior)) , mIsQuasiExterior(cell.mData.mFlags & ESM::Cell::QuasiEx) , mHasWater(cell.mData.mFlags & ESM::Cell::HasWater) , mNoSleep(cell.mData.mFlags & ESM::Cell::NoSleep) , mGridPos(cell.getGridX(), cell.getGridY()) , mDisplayname(cell.mName) , mNameID(cell.mName) , mRegion(cell.mRegion) , mId(cell.mId) , mParent(ESM::Cell::sDefaultWorldspaceId) , mWaterHeight(cell.mWater) , mDescription(cell.getDescription()) , mMood{ .mAmbiantColor = cell.mAmbi.mAmbient, .mDirectionalColor = cell.mAmbi.mSunlight, .mFogColor = cell.mAmbi.mFog, .mFogDensity = cell.mAmbi.mFogDensity, } { if (isExterior()) { mWaterHeight = -1.f; mHasWater = true; } else mGridPos = {}; } ESM::RefId Cell::getWorldSpace() const { if (isExterior()) return mParent; else return mId; } ESM::ExteriorCellLocation Cell::getExteriorCellLocation() const { return { mGridPos.x(), mGridPos.y(), getWorldSpace() }; } }