|
|
@ -9,19 +9,41 @@
|
|
|
|
#include "esmwriter.hpp"
|
|
|
|
#include "esmwriter.hpp"
|
|
|
|
#include "defs.hpp"
|
|
|
|
#include "defs.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
///< Translate 8bit/24bit code (stored in refNum.mIndex) into a proper refNum
|
|
|
|
|
|
|
|
void adjustRefNum (ESM::CellRef::RefNum& refNum, ESM::ESMReader& reader)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
int local = (refNum.mIndex & 0xff000000) >> 24;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (local)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// If the most significant 8 bits are used, then this reference already exists.
|
|
|
|
|
|
|
|
// In this case, do not spawn a new reference, but overwrite the old one.
|
|
|
|
|
|
|
|
refNum.mIndex &= 0x00ffffff; // delete old plugin ID
|
|
|
|
|
|
|
|
refNum.mContentFile = reader.getGameFiles()[local-1].index;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// This is an addition by the present plugin. Set the corresponding plugin index.
|
|
|
|
|
|
|
|
refNum.mContentFile = reader.getIndex();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
{
|
|
|
|
unsigned int Cell::sRecordId = REC_CELL;
|
|
|
|
unsigned int Cell::sRecordId = REC_CELL;
|
|
|
|
|
|
|
|
|
|
|
|
/// Some overloaded compare operators.
|
|
|
|
// Some overloaded compare operators.
|
|
|
|
bool operator==(const MovedCellRef& ref, int pRefnum)
|
|
|
|
bool operator== (const MovedCellRef& ref, const CellRef::RefNum& refNum)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return (ref.mRefnum == pRefnum);
|
|
|
|
return ref.mRefNum == refNum;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool operator==(const CellRef& ref, int pRefnum)
|
|
|
|
bool operator== (const CellRef& ref, const CellRef::RefNum& refNum)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return (ref.mRefnum == pRefnum);
|
|
|
|
return ref.mRefNum == refNum;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -163,49 +185,17 @@ bool Cell::getNextRef(ESMReader &esm, CellRef &ref, bool& deleted)
|
|
|
|
//esm.getHNOT(NAM0, "NAM0");
|
|
|
|
//esm.getHNOT(NAM0, "NAM0");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
esm.getHNT(ref.mRefnum, "FRMR");
|
|
|
|
esm.getHNT (ref.mRefNum.mIndex, "FRMR");
|
|
|
|
ref.mRefID = esm.getHNString("NAME");
|
|
|
|
ref.mRefID = esm.getHNString("NAME");
|
|
|
|
|
|
|
|
|
|
|
|
// Identify references belonging to a parent file and adapt the ID accordingly.
|
|
|
|
// Identify references belonging to a parent file and adapt the ID accordingly.
|
|
|
|
int local = (ref.mRefnum & 0xff000000) >> 24;
|
|
|
|
adjustRefNum (ref.mRefNum, esm);
|
|
|
|
size_t global = esm.getIndex() + 1;
|
|
|
|
|
|
|
|
if (local)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// If the most significant 8 bits are used, then this reference already exists.
|
|
|
|
|
|
|
|
// In this case, do not spawn a new reference, but overwrite the old one.
|
|
|
|
|
|
|
|
ref.mRefnum &= 0x00ffffff; // delete old plugin ID
|
|
|
|
|
|
|
|
const std::vector<Header::MasterData> &masters = esm.getGameFiles();
|
|
|
|
|
|
|
|
global = masters[local-1].index + 1;
|
|
|
|
|
|
|
|
ref.mRefnum |= global << 24; // insert global plugin ID
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// This is an addition by the present plugin. Set the corresponding plugin index.
|
|
|
|
|
|
|
|
ref.mRefnum |= global << 24; // insert global plugin ID
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// getHNOT will not change the existing value if the subrecord is
|
|
|
|
// getHNOT will not change the existing value if the subrecord is
|
|
|
|
// missing
|
|
|
|
// missing
|
|
|
|
ref.mScale = 1.0;
|
|
|
|
ref.mScale = 1.0;
|
|
|
|
esm.getHNOT(ref.mScale, "XSCL");
|
|
|
|
esm.getHNOT(ref.mScale, "XSCL");
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: support loading references from saves, there are tons of keys not recognized yet.
|
|
|
|
|
|
|
|
// The following is just an incomplete list.
|
|
|
|
|
|
|
|
if (esm.isNextSub("ACTN"))
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
if (esm.isNextSub("STPR"))
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
if (esm.isNextSub("ACDT"))
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
if (esm.isNextSub("ACSC"))
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
if (esm.isNextSub("ACSL"))
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
if (esm.isNextSub("CHRD"))
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
else if (esm.isNextSub("CRED")) // ???
|
|
|
|
|
|
|
|
esm.skipHSub();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ref.mOwner = esm.getHNOString("ANAM");
|
|
|
|
ref.mOwner = esm.getHNOString("ANAM");
|
|
|
|
ref.mGlob = esm.getHNOString("BNAM");
|
|
|
|
ref.mGlob = esm.getHNOString("BNAM");
|
|
|
|
ref.mSoul = esm.getHNOString("XSOL");
|
|
|
|
ref.mSoul = esm.getHNOString("XSOL");
|
|
|
@ -272,16 +262,10 @@ bool Cell::getNextRef(ESMReader &esm, CellRef &ref, bool& deleted)
|
|
|
|
|
|
|
|
|
|
|
|
bool Cell::getNextMVRF(ESMReader &esm, MovedCellRef &mref)
|
|
|
|
bool Cell::getNextMVRF(ESMReader &esm, MovedCellRef &mref)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
esm.getHT(mref.mRefnum);
|
|
|
|
esm.getHT(mref.mRefNum.mIndex);
|
|
|
|
esm.getHNOT(mref.mTarget, "CNDT");
|
|
|
|
esm.getHNOT(mref.mTarget, "CNDT");
|
|
|
|
|
|
|
|
|
|
|
|
// Identify references belonging to a parent file and adapt the ID accordingly.
|
|
|
|
adjustRefNum (mref.mRefNum, esm);
|
|
|
|
int local = (mref.mRefnum & 0xff000000) >> 24;
|
|
|
|
|
|
|
|
size_t global = esm.getIndex() + 1;
|
|
|
|
|
|
|
|
mref.mRefnum &= 0x00ffffff; // delete old plugin ID
|
|
|
|
|
|
|
|
const std::vector<Header::MasterData> &masters = esm.getGameFiles();
|
|
|
|
|
|
|
|
global = masters[local-1].index + 1;
|
|
|
|
|
|
|
|
mref.mRefnum |= global << 24; // insert global plugin ID
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|