openmw-tes3coop/components/esm/loadcell.cpp

234 lines
5.1 KiB
C++
Raw Normal View History

#include "loadcell.hpp"
#include <string>
#include <sstream>
#include "esmreader.hpp"
#include "esmwriter.hpp"
2012-09-17 07:37:50 +00:00
namespace ESM
{
void CellRef::save(ESMWriter &esm)
{
2012-09-17 07:37:50 +00:00
esm.writeHNT("FRMR", mRefnum);
esm.writeHNCString("NAME", mRefID);
2012-09-17 07:37:50 +00:00
if (mScale != 1.0) {
esm.writeHNT("XSCL", mScale);
}
esm.writeHNOCString("ANAM", mOwner);
esm.writeHNOCString("BNAM", mGlob);
esm.writeHNOCString("XSOL", mSoul);
esm.writeHNOCString("CNAM", mFaction);
if (mFactIndex != -2) {
2012-09-17 07:37:50 +00:00
esm.writeHNT("INDX", mFactIndex);
}
2012-09-17 07:37:50 +00:00
if (mCharge != -1.0) {
esm.writeHNT("XCHG", mCharge);
}
if (mIntv != -1) {
2012-09-17 07:37:50 +00:00
esm.writeHNT("INTV", mIntv);
}
if (mNam9 != 0) {
esm.writeHNT("NAM9", mNam9);
}
2012-09-17 07:37:50 +00:00
if (mTeleport)
{
2012-09-17 07:37:50 +00:00
esm.writeHNT("DODT", mDoorDest);
esm.writeHNOCString("DNAM", mDestCell);
}
if (mLockLevel != -1) {
2012-09-17 07:37:50 +00:00
esm.writeHNT("FLTV", mLockLevel);
}
esm.writeHNOCString("KNAM", mKey);
esm.writeHNOCString("TNAM", mTrap);
if (mUnam != -1) {
2012-09-17 07:37:50 +00:00
esm.writeHNT("UNAM", mUnam);
}
if (mFltv != 0) {
esm.writeHNT("FLTV", mFltv);
}
2012-09-17 07:37:50 +00:00
esm.writeHNT("DATA", mPos, 24);
if (mNam0 != 0) {
esm.writeHNT("NAM0", mNam0);
}
}
void Cell::load(ESMReader &esm)
{
// Ignore this for now, it might mean we should delete the entire
// cell?
2012-09-17 07:37:50 +00:00
if (esm.isNextSub("DELE")) {
esm.skipHSub();
2012-09-17 07:37:50 +00:00
}
2012-09-17 07:37:50 +00:00
esm.getHNT(mData, "DATA", 12);
// Water level
mWater = -1;
2012-09-17 07:37:50 +00:00
mNAM0 = 0;
2012-09-17 07:37:50 +00:00
if (mData.mFlags & Interior)
{
// Interior cells
if (esm.isNextSub("INTV"))
{
int waterl;
esm.getHT(waterl);
2012-09-17 07:37:50 +00:00
mWater = (float) waterl;
mWaterInt = true;
}
else if (esm.isNextSub("WHGT"))
2012-09-17 07:37:50 +00:00
esm.getHT(mWater);
// Quasi-exterior cells have a region (which determines the
// weather), pure interior cells have ambient lighting
// instead.
2012-09-17 07:37:50 +00:00
if (mData.mFlags & QuasiEx)
mRegion = esm.getHNOString("RGNN");
else
2012-09-17 07:37:50 +00:00
esm.getHNT(mAmbi, "AMBI", 16);
}
else
{
// Exterior cells
2012-09-17 07:37:50 +00:00
mRegion = esm.getHNOString("RGNN");
mMapColor = 0;
2012-09-17 07:37:50 +00:00
esm.getHNOT(mMapColor, "NAM5");
}
if (esm.isNextSub("NAM0")) {
esm.getHT(mNAM0);
}
// Save position of the cell references and move on
2012-09-17 07:37:50 +00:00
mContext = esm.getContext();
esm.skipRecord();
}
void Cell::save(ESMWriter &esm)
{
2012-09-17 07:37:50 +00:00
esm.writeHNT("DATA", mData, 12);
if (mData.mFlags & Interior)
{
if (mWater != -1) {
if (mWaterInt) {
int water =
(mWater >= 0) ? (int) (mWater + 0.5) : (int) (mWater - 0.5);
esm.writeHNT("INTV", water);
} else {
esm.writeHNT("WHGT", mWater);
}
}
2012-04-06 19:14:52 +00:00
2012-09-17 07:37:50 +00:00
if (mData.mFlags & QuasiEx)
esm.writeHNOCString("RGNN", mRegion);
else
2012-09-17 07:37:50 +00:00
esm.writeHNT("AMBI", mAmbi, 16);
}
else
{
2012-09-17 07:37:50 +00:00
esm.writeHNOCString("RGNN", mRegion);
if (mMapColor != 0)
esm.writeHNT("NAM5", mMapColor);
}
2012-06-11 18:02:03 +00:00
2012-09-17 07:37:50 +00:00
if (mNAM0 != 0)
esm.writeHNT("NAM0", mNAM0);
}
void Cell::restore(ESMReader &esm) const
{
2012-09-17 07:37:50 +00:00
esm.restoreContext(mContext);
}
std::string Cell::getDescription() const
{
2012-09-17 07:37:50 +00:00
if (mData.mFlags & Interior)
{
2012-09-17 07:37:50 +00:00
return mName;
}
else
{
std::ostringstream stream;
2012-09-17 07:37:50 +00:00
stream << mData.mX << ", " << mData.mY;
return stream.str();
}
}
bool Cell::getNextRef(ESMReader &esm, CellRef &ref)
{
if (!esm.hasMoreSubs())
return false;
2012-09-17 07:37:50 +00:00
esm.getHNT(ref.mRefnum, "FRMR");
ref.mRefID = esm.getHNString("NAME");
// getHNOT will not change the existing value if the subrecord is
// missing
2012-09-17 07:37:50 +00:00
ref.mScale = 1.0;
esm.getHNOT(ref.mScale, "XSCL");
2012-09-17 07:37:50 +00:00
ref.mOwner = esm.getHNOString("ANAM");
ref.mGlob = esm.getHNOString("BNAM");
ref.mSoul = esm.getHNOString("XSOL");
2012-09-17 07:37:50 +00:00
ref.mFaction = esm.getHNOString("CNAM");
ref.mFactIndex = -2;
2012-09-17 07:37:50 +00:00
esm.getHNOT(ref.mFactIndex, "INDX");
2012-09-17 07:37:50 +00:00
ref.mCharge = -1.0;
esm.getHNOT(ref.mCharge, "XCHG");
ref.mIntv = -1;
2012-09-17 07:37:50 +00:00
ref.mNam9 = 0;
esm.getHNOT(ref.mIntv, "INTV");
esm.getHNOT(ref.mNam9, "NAM9");
// Present for doors that teleport you to another cell.
if (esm.isNextSub("DODT"))
{
2012-09-17 07:37:50 +00:00
ref.mTeleport = true;
esm.getHT(ref.mDoorDest);
ref.mDestCell = esm.getHNOString("DNAM");
} else {
ref.mTeleport = false;
}
// Integer, despite the name suggesting otherwise
ref.mLockLevel = -1;
2012-09-17 07:37:50 +00:00
esm.getHNOT(ref.mLockLevel, "FLTV");
ref.mKey = esm.getHNOString("KNAM");
ref.mTrap = esm.getHNOString("TNAM");
ref.mUnam = -1;
2012-09-17 07:37:50 +00:00
ref.mFltv = 0;
esm.getHNOT(ref.mUnam, "UNAM");
esm.getHNOT(ref.mFltv, "FLTV");
2012-09-17 07:37:50 +00:00
esm.getHNT(ref.mPos, "DATA", 24);
// Number of references in the cell? Maximum once in each cell,
// but not always at the beginning, and not always right. In other
// words, completely useless.
ref.mNam0 = 0;
if (esm.isNextSub("NAM0"))
{
esm.getHT(ref.mNam0);
//esm.getHNOT(NAM0, "NAM0");
}
return true;
}
}