2014-05-25 12:13:07 +00:00
|
|
|
#ifndef OPENMW_MWWORLD_CELLREF_H
|
|
|
|
#define OPENMW_MWWORLD_CELLREF_H
|
|
|
|
|
|
|
|
#include <components/esm/cellref.hpp>
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
2014-05-27 11:27:18 +00:00
|
|
|
struct ObjectState;
|
2014-05-25 12:13:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
|
|
|
|
/// \brief Encapsulated variant of ESM::CellRef with change tracking
|
|
|
|
class CellRef
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
CellRef (const ESM::CellRef& ref)
|
|
|
|
: mCellRef(ref)
|
|
|
|
{
|
|
|
|
mChanged = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Note: Currently unused for items in containers
|
2015-02-03 22:05:06 +00:00
|
|
|
const ESM::RefNum& getRefNum() const;
|
2014-05-25 12:13:07 +00:00
|
|
|
|
2014-07-29 13:55:58 +00:00
|
|
|
// Set RefNum to its default state.
|
|
|
|
void unsetRefNum();
|
|
|
|
|
2018-07-27 18:42:08 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Set the unique reference number index of a CellRef, needed to
|
|
|
|
make objects retain their uniqueIndex when they are updated
|
|
|
|
after their records are modified on the fly by the server
|
|
|
|
*/
|
2018-07-27 18:56:45 +00:00
|
|
|
void setRefNum(unsigned int index);
|
2018-07-27 18:42:08 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2017-04-04 04:42:02 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Get the mMpNum (unique multiplayer reference number) of a CellRef
|
|
|
|
*/
|
2018-07-02 19:25:54 +00:00
|
|
|
unsigned int getMpNum() const;
|
2017-04-04 04:42:02 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Set the mMpNum (unique multiplayer reference number) of a CellRef
|
|
|
|
*/
|
2018-07-02 19:25:54 +00:00
|
|
|
void setMpNum(unsigned int index);
|
2017-04-04 04:42:02 +00:00
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2015-01-10 23:20:22 +00:00
|
|
|
/// Does the RefNum have a content file?
|
|
|
|
bool hasContentFile() const;
|
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// Id of object being referenced
|
|
|
|
std::string getRefId() const;
|
|
|
|
|
|
|
|
// For doors - true if this door teleports to somewhere else, false
|
|
|
|
// if it should open through animation.
|
|
|
|
bool getTeleport() const;
|
|
|
|
|
2018-04-29 19:32:22 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Make it possible to change the teleport state from elsewhere
|
|
|
|
*/
|
|
|
|
void setTeleport(bool teleportState);
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// Teleport location for the door, if this is a teleporting door.
|
|
|
|
ESM::Position getDoorDest() const;
|
|
|
|
|
2018-04-29 19:32:22 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Make it possible to change the destination position from elsewhere
|
|
|
|
*/
|
|
|
|
void setDoorDest(const ESM::Position& position);
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// Destination cell for doors (optional)
|
|
|
|
std::string getDestCell() const;
|
|
|
|
|
2018-04-29 19:32:22 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Make it possible to change the destination cell from elsewhere
|
|
|
|
*/
|
|
|
|
void setDestCell(const std::string& cellDescription);
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// Scale applied to mesh
|
|
|
|
float getScale() const;
|
|
|
|
void setScale(float scale);
|
|
|
|
|
2014-06-14 15:56:41 +00:00
|
|
|
// The *original* position and rotation as it was given in the Construction Set.
|
|
|
|
// Current position and rotation of the object is stored in RefData.
|
2014-05-25 12:13:07 +00:00
|
|
|
ESM::Position getPosition() const;
|
|
|
|
void setPosition (const ESM::Position& position);
|
|
|
|
|
|
|
|
// Remaining enchantment charge. This could be -1 if the charge was not touched yet (i.e. full).
|
|
|
|
float getEnchantmentCharge() const;
|
|
|
|
|
|
|
|
void setEnchantmentCharge(float charge);
|
|
|
|
|
|
|
|
// For weapon or armor, this is the remaining item health.
|
|
|
|
// For tools (lockpicks, probes, repair hammer) it is the remaining uses.
|
2015-01-23 14:33:39 +00:00
|
|
|
// If this returns int(-1) it means full health.
|
2014-05-25 12:13:07 +00:00
|
|
|
int getCharge() const;
|
2015-01-23 14:33:39 +00:00
|
|
|
float getChargeFloat() const; // Implemented as union with int charge
|
2014-05-25 12:13:07 +00:00
|
|
|
void setCharge(int charge);
|
2015-01-23 14:33:39 +00:00
|
|
|
void setChargeFloat(float charge);
|
2016-12-10 02:55:26 +00:00
|
|
|
void applyChargeRemainderToBeSubtracted(float chargeRemainder); // Stores remainders and applies if > 1
|
2014-05-25 12:13:07 +00:00
|
|
|
|
|
|
|
// The NPC that owns this object (and will get angry if you steal it)
|
|
|
|
std::string getOwner() const;
|
|
|
|
void setOwner(const std::string& owner);
|
|
|
|
|
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 getGlobalVariable() const;
|
|
|
|
|
2015-02-04 20:18:43 +00:00
|
|
|
void resetGlobalVariable();
|
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// ID of creature trapped in this soul gem
|
|
|
|
std::string getSoul() const;
|
|
|
|
void setSoul(const std::string& soul);
|
|
|
|
|
|
|
|
// The faction that owns this object (and will get angry if
|
|
|
|
// you take it and are not a faction member)
|
|
|
|
std::string getFaction() const;
|
|
|
|
void setFaction (const std::string& faction);
|
|
|
|
|
2014-07-22 18:03:35 +00:00
|
|
|
// PC faction rank required to use the item. Sometimes is -1, which means "any rank".
|
2014-12-20 21:00:45 +00:00
|
|
|
void setFactionRank(int factionRank);
|
2014-07-22 18:03:35 +00:00
|
|
|
int getFactionRank() const;
|
|
|
|
|
2014-05-25 12:13:07 +00:00
|
|
|
// Lock level for doors and containers
|
|
|
|
// Positive for a locked door. 0 for a door that was never locked.
|
|
|
|
// For an unlocked door, it is set to -(previous locklevel)
|
|
|
|
int getLockLevel() const;
|
|
|
|
void setLockLevel(int lockLevel);
|
|
|
|
// Key and trap ID names, if any
|
|
|
|
std::string getKey() const;
|
|
|
|
std::string getTrap() const;
|
|
|
|
void setTrap(const std::string& trap);
|
|
|
|
|
|
|
|
// This is 5 for Gold_005 references, 100 for Gold_100 and so on.
|
|
|
|
int getGoldValue() const;
|
|
|
|
void setGoldValue(int value);
|
|
|
|
|
|
|
|
// Write the content of this CellRef into the given ObjectState
|
|
|
|
void writeState (ESM::ObjectState& state) const;
|
|
|
|
|
|
|
|
// Has this CellRef changed since it was originally loaded?
|
|
|
|
bool hasChanged() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool mChanged;
|
|
|
|
ESM::CellRef mCellRef;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|