2013-04-04 10:13:15 +00:00
|
|
|
#ifndef OPENMW_ESM_CELLREF_H
|
|
|
|
#define OPENMW_ESM_CELLREF_H
|
|
|
|
|
2018-06-19 10:17:33 +00:00
|
|
|
#include <limits>
|
2013-04-04 10:13:15 +00:00
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "defs.hpp"
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
class ESMWriter;
|
2014-01-12 18:23:08 +00:00
|
|
|
class ESMReader;
|
2013-04-04 10:13:15 +00:00
|
|
|
|
2018-06-19 10:17:33 +00:00
|
|
|
const int UnbreakableLock = std::numeric_limits<int>::max();
|
2014-05-25 12:13:07 +00:00
|
|
|
|
|
|
|
struct RefNum
|
|
|
|
{
|
2015-04-24 23:39:37 +00:00
|
|
|
unsigned int mIndex;
|
|
|
|
int mContentFile;
|
2015-01-22 12:33:23 +00:00
|
|
|
|
2015-12-06 18:11:25 +00:00
|
|
|
void load (ESMReader& esm, bool wide = false, const std::string& tag = "FRMR");
|
2015-01-22 12:33:23 +00:00
|
|
|
|
2015-01-24 13:22:29 +00:00
|
|
|
void save (ESMWriter &esm, bool wide = false, const std::string& tag = "FRMR") const;
|
2015-01-10 23:20:22 +00:00
|
|
|
|
|
|
|
enum { RefNum_NoContentFile = -1 };
|
|
|
|
inline bool hasContentFile() const { return mContentFile != RefNum_NoContentFile; }
|
|
|
|
inline void unset() { mIndex = 0; mContentFile = RefNum_NoContentFile; }
|
2014-05-25 12:13:07 +00:00
|
|
|
};
|
|
|
|
|
2013-04-04 10:13:15 +00:00
|
|
|
/* Cell reference. This represents ONE object (of many) inside the
|
|
|
|
cell. The cell references are not loaded as part of the normal
|
|
|
|
loading process, but are rather loaded later on demand when we are
|
|
|
|
setting up a specific cell.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class CellRef
|
|
|
|
{
|
|
|
|
public:
|
2014-05-25 12:13:07 +00:00
|
|
|
// Reference number
|
|
|
|
// Note: Currently unused for items in containers
|
|
|
|
RefNum mRefNum;
|
2013-12-17 20:19:05 +00:00
|
|
|
|
2017-04-04 04:42:02 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Keep track of a multiplayer-only number unique to this object
|
|
|
|
*/
|
2018-07-02 19:25:54 +00:00
|
|
|
unsigned int mMpNum;
|
2017-04-04 04:42:02 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2013-04-04 10:13:15 +00:00
|
|
|
std::string mRefID; // ID of object being referenced
|
|
|
|
|
|
|
|
float mScale; // Scale applied to mesh
|
|
|
|
|
2014-07-22 15:05:05 +00:00
|
|
|
// The NPC that owns this object (and will get angry if you steal it)
|
2013-04-04 10:13:15 +00:00
|
|
|
std::string mOwner;
|
|
|
|
|
2014-07-22 15:05:05 +00:00
|
|
|
// Name of a global variable. If the global variable is set to '1', using the object is temporarily allowed
|
|
|
|
// even if it has an Owner field.
|
|
|
|
// Used by bed rent scripts to allow the player to use the bed for the duration of the rent.
|
|
|
|
std::string mGlobalVariable;
|
2013-04-04 10:13:15 +00:00
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// ID of creature trapped in this soul gem
|
2013-04-04 10:13:15 +00:00
|
|
|
std::string mSoul;
|
|
|
|
|
2014-01-07 19:24:01 +00:00
|
|
|
// The faction that owns this object (and will get angry if
|
|
|
|
// you take it and are not a faction member)
|
2013-04-04 10:13:15 +00:00
|
|
|
std::string mFaction;
|
|
|
|
|
2014-07-22 18:03:35 +00:00
|
|
|
// PC faction rank required to use the item. Sometimes is -1, which means "any rank".
|
|
|
|
int mFactionRank;
|
2013-04-04 10:13:15 +00:00
|
|
|
|
|
|
|
// For weapon or armor, this is the remaining item health.
|
|
|
|
// For tools (lockpicks, probes, repair hammer) it is the remaining uses.
|
2015-02-13 12:11:10 +00:00
|
|
|
// For lights it is remaining time.
|
|
|
|
// This could be -1 if the charge was not touched yet (i.e. full).
|
2015-01-23 14:33:39 +00:00
|
|
|
union
|
|
|
|
{
|
2015-02-13 12:11:10 +00:00
|
|
|
int mChargeInt; // Used by everything except lights
|
|
|
|
float mChargeFloat; // Used only by lights
|
2015-01-23 14:33:39 +00:00
|
|
|
};
|
2016-12-10 02:55:26 +00:00
|
|
|
float mChargeIntRemainder; // Stores amount of charge not subtracted from mChargeInt
|
2013-04-04 10:13:15 +00:00
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// Remaining enchantment charge. This could be -1 if the charge was not touched yet (i.e. full).
|
2013-04-04 10:13:15 +00:00
|
|
|
float mEnchantmentCharge;
|
|
|
|
|
|
|
|
// This is 5 for Gold_005 references, 100 for Gold_100 and so on.
|
|
|
|
int mGoldValue;
|
|
|
|
|
|
|
|
// For doors - true if this door teleports to somewhere else, false
|
|
|
|
// if it should open through animation.
|
|
|
|
bool mTeleport;
|
|
|
|
|
|
|
|
// Teleport location for the door, if this is a teleporting door.
|
|
|
|
Position mDoorDest;
|
|
|
|
|
|
|
|
// Destination cell for doors (optional)
|
|
|
|
std::string mDestCell;
|
|
|
|
|
|
|
|
// Lock level for doors and containers
|
|
|
|
int mLockLevel;
|
|
|
|
std::string mKey, mTrap; // Key and trap ID names, if any
|
|
|
|
|
|
|
|
// This corresponds to the "Reference Blocked" checkbox in the construction set,
|
|
|
|
// which prevents editing that reference.
|
|
|
|
// -1 is not blocked, otherwise it is blocked.
|
|
|
|
signed char mReferenceBlocked;
|
|
|
|
|
|
|
|
// Position and rotation of this object within the cell
|
|
|
|
Position mPos;
|
|
|
|
|
2015-01-19 22:29:06 +00:00
|
|
|
/// Calls loadId and loadData
|
2015-07-20 14:23:14 +00:00
|
|
|
void load (ESMReader& esm, bool &isDeleted, bool wideRefNum = false);
|
2014-01-12 18:23:08 +00:00
|
|
|
|
2015-04-29 09:36:56 +00:00
|
|
|
void loadId (ESMReader& esm, bool wideRefNum = false);
|
2015-01-19 22:29:06 +00:00
|
|
|
|
2015-01-18 21:52:11 +00:00
|
|
|
/// Implicitly called by load
|
2015-07-20 14:23:14 +00:00
|
|
|
void loadData (ESMReader& esm, bool &isDeleted);
|
2015-01-18 21:52:11 +00:00
|
|
|
|
2015-07-20 14:23:14 +00:00
|
|
|
void save (ESMWriter &esm, bool wideRefNum = false, bool inInventory = false, bool isDeleted = false) const;
|
2013-06-08 13:49:59 +00:00
|
|
|
|
|
|
|
void blank();
|
2013-04-04 10:13:15 +00:00
|
|
|
};
|
2013-12-17 20:19:05 +00:00
|
|
|
|
2020-05-16 13:37:00 +00:00
|
|
|
inline bool operator== (const RefNum& left, const RefNum& right)
|
|
|
|
{
|
|
|
|
return left.mIndex==right.mIndex && left.mContentFile==right.mContentFile;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool operator< (const RefNum& left, const RefNum& right)
|
|
|
|
{
|
|
|
|
if (left.mIndex<right.mIndex)
|
|
|
|
return true;
|
|
|
|
if (left.mIndex>right.mIndex)
|
|
|
|
return false;
|
|
|
|
return left.mContentFile<right.mContentFile;
|
|
|
|
}
|
|
|
|
|
2013-04-04 10:13:15 +00:00
|
|
|
}
|
|
|
|
|
2014-01-02 00:31:06 +00:00
|
|
|
#endif
|