mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-21 23:53:56 +00:00
Refactor list of variables in the WorldManager
This commit is contained in:
parent
998f4f73f4
commit
c0e62e9529
2 changed files with 28 additions and 27 deletions
|
@ -164,10 +164,11 @@ namespace MWWorld
|
||||||
const std::string& startCell, const std::string& startupScript,
|
const std::string& startCell, const std::string& startupScript,
|
||||||
const std::string& resourcePath, const std::string& userDataPath)
|
const std::string& resourcePath, const std::string& userDataPath)
|
||||||
: mResourceSystem(resourceSystem), mLocalScripts (mStore),
|
: mResourceSystem(resourceSystem), mLocalScripts (mStore),
|
||||||
mSky (true), mCells (mStore, mEsm),
|
mCells (mStore, mEsm), mSky (true),
|
||||||
mGodMode(false), mScriptsEnabled(true), mContentFiles (contentFiles), mUserDataPath(userDataPath),
|
mGodMode(false), mScriptsEnabled(true), mContentFiles (contentFiles),
|
||||||
|
mUserDataPath(userDataPath), mShouldUpdateNavigator(false),
|
||||||
mActivationDistanceOverride (activationDistanceOverride),
|
mActivationDistanceOverride (activationDistanceOverride),
|
||||||
mStartCell (startCell), mDistanceToFacedObject(-1), mTeleportEnabled(true),
|
mStartCell(startCell), mDistanceToFacedObject(-1.f), mTeleportEnabled(true),
|
||||||
mLevitationEnabled(true), mGoToJail(false), mDaysInPrison(0),
|
mLevitationEnabled(true), mGoToJail(false), mDaysInPrison(0),
|
||||||
mPlayerTraveling(false), mPlayerInJail(false), mSpellPreloadTimer(0.f)
|
mPlayerTraveling(false), mPlayerInJail(false), mSpellPreloadTimer(0.f)
|
||||||
{
|
{
|
||||||
|
|
|
@ -77,13 +77,13 @@ namespace MWWorld
|
||||||
|
|
||||||
class World final: public MWBase::World
|
class World final: public MWBase::World
|
||||||
{
|
{
|
||||||
|
private:
|
||||||
Resource::ResourceSystem* mResourceSystem;
|
Resource::ResourceSystem* mResourceSystem;
|
||||||
|
|
||||||
std::vector<ESM::ESMReader> mEsm;
|
std::vector<ESM::ESMReader> mEsm;
|
||||||
MWWorld::ESMStore mStore;
|
MWWorld::ESMStore mStore;
|
||||||
LocalScripts mLocalScripts;
|
LocalScripts mLocalScripts;
|
||||||
MWWorld::Globals mGlobalVariables;
|
MWWorld::Globals mGlobalVariables;
|
||||||
bool mSky;
|
|
||||||
|
|
||||||
ESM::Variant* mGameHour;
|
ESM::Variant* mGameHour;
|
||||||
ESM::Variant* mDaysPassed;
|
ESM::Variant* mDaysPassed;
|
||||||
|
@ -104,6 +104,7 @@ namespace MWWorld
|
||||||
std::unique_ptr<MWWorld::WeatherManager> mWeatherManager;
|
std::unique_ptr<MWWorld::WeatherManager> mWeatherManager;
|
||||||
std::shared_ptr<ProjectileManager> mProjectileManager;
|
std::shared_ptr<ProjectileManager> mProjectileManager;
|
||||||
|
|
||||||
|
bool mSky;
|
||||||
bool mGodMode;
|
bool mGodMode;
|
||||||
bool mScriptsEnabled;
|
bool mScriptsEnabled;
|
||||||
std::vector<std::string> mContentFiles;
|
std::vector<std::string> mContentFiles;
|
||||||
|
@ -111,18 +112,31 @@ namespace MWWorld
|
||||||
std::string mUserDataPath;
|
std::string mUserDataPath;
|
||||||
|
|
||||||
osg::Vec3f mDefaultHalfExtents;
|
osg::Vec3f mDefaultHalfExtents;
|
||||||
bool mShouldUpdateNavigator = false;
|
bool mShouldUpdateNavigator;
|
||||||
|
|
||||||
// not implemented
|
|
||||||
World (const World&);
|
|
||||||
World& operator= (const World&);
|
|
||||||
|
|
||||||
int mActivationDistanceOverride;
|
int mActivationDistanceOverride;
|
||||||
|
|
||||||
|
std::string mStartCell;
|
||||||
|
|
||||||
|
float mSwimHeightScale;
|
||||||
|
|
||||||
|
float mDistanceToFacedObject;
|
||||||
|
|
||||||
|
bool mTeleportEnabled;
|
||||||
|
bool mLevitationEnabled;
|
||||||
|
bool mGoToJail;
|
||||||
|
int mDaysInPrison;
|
||||||
|
bool mPlayerTraveling;
|
||||||
|
bool mPlayerInJail;
|
||||||
|
|
||||||
|
float mSpellPreloadTimer;
|
||||||
|
|
||||||
std::map<MWWorld::Ptr, MWWorld::DoorState> mDoorStates;
|
std::map<MWWorld::Ptr, MWWorld::DoorState> mDoorStates;
|
||||||
///< only holds doors that are currently moving. 1 = opening, 2 = closing
|
///< only holds doors that are currently moving. 1 = opening, 2 = closing
|
||||||
|
|
||||||
std::string mStartCell;
|
// not implemented
|
||||||
|
World (const World&);
|
||||||
|
World& operator= (const World&);
|
||||||
|
|
||||||
void updateWeather(float duration, bool paused = false);
|
void updateWeather(float duration, bool paused = false);
|
||||||
int getDaysPerMonth (int month) const;
|
int getDaysPerMonth (int month) const;
|
||||||
|
@ -141,10 +155,6 @@ namespace MWWorld
|
||||||
|
|
||||||
MWWorld::Ptr getFacedObject(float maxDistance, bool ignorePlayer=true);
|
MWWorld::Ptr getFacedObject(float maxDistance, bool ignorePlayer=true);
|
||||||
|
|
||||||
public: // FIXME
|
|
||||||
void addContainerScripts(const Ptr& reference, CellStore* cell) override;
|
|
||||||
void removeContainerScripts(const Ptr& reference) override;
|
|
||||||
private:
|
|
||||||
void PCDropped (const Ptr& item);
|
void PCDropped (const Ptr& item);
|
||||||
|
|
||||||
bool rotateDoor(const Ptr door, DoorState state, float duration);
|
bool rotateDoor(const Ptr door, DoorState state, float duration);
|
||||||
|
@ -172,19 +182,6 @@ namespace MWWorld
|
||||||
void loadContentFiles(const Files::Collections& fileCollections,
|
void loadContentFiles(const Files::Collections& fileCollections,
|
||||||
const std::vector<std::string>& content, ContentLoader& contentLoader);
|
const std::vector<std::string>& content, ContentLoader& contentLoader);
|
||||||
|
|
||||||
float mSwimHeightScale;
|
|
||||||
|
|
||||||
float mDistanceToFacedObject;
|
|
||||||
|
|
||||||
bool mTeleportEnabled;
|
|
||||||
bool mLevitationEnabled;
|
|
||||||
bool mGoToJail;
|
|
||||||
int mDaysInPrison;
|
|
||||||
bool mPlayerTraveling;
|
|
||||||
bool mPlayerInJail;
|
|
||||||
|
|
||||||
float mSpellPreloadTimer;
|
|
||||||
|
|
||||||
float feetToGameUnits(float feet);
|
float feetToGameUnits(float feet);
|
||||||
float getActivationDistancePlusTelekinesis();
|
float getActivationDistancePlusTelekinesis();
|
||||||
|
|
||||||
|
@ -192,6 +189,9 @@ namespace MWWorld
|
||||||
MWWorld::ConstPtr getClosestMarkerFromExteriorPosition( const osg::Vec3f& worldPos, const std::string &id );
|
MWWorld::ConstPtr getClosestMarkerFromExteriorPosition( const osg::Vec3f& worldPos, const std::string &id );
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
// FIXME
|
||||||
|
void addContainerScripts(const Ptr& reference, CellStore* cell) override;
|
||||||
|
void removeContainerScripts(const Ptr& reference) override;
|
||||||
|
|
||||||
World (
|
World (
|
||||||
osgViewer::Viewer* viewer,
|
osgViewer::Viewer* viewer,
|
||||||
|
|
Loading…
Reference in a new issue