mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
b8fcd6d3ba
Instead of explicit work queue stop before any possibly used engine manager is destructed. Based on an assumption that any engine manager can be destructed independently from the work queue destruction. This model is already used in CellPreloader that conflicts with explicit work queue stop. After the work queue is requested to be stopped, any client waiting for a not started work item to be done will wait forever because the work item is dropped from the queue. Therefore either clients should not wait for own work items to be completed in destructor or the work queue should not drop items before clients are destructed. Other approaches are possible but are not considered due to increasing complexity. CellPreloader already tries to wait for all created work items to be done so keep it that way and extend the model to AsyncScreenCaptureOperation and Scene. Additionally abort all scheduled work items when owner is destructed. This prevents a long exit when multiple screenshots are scheduled right before exiting the game.
203 lines
6.0 KiB
C++
203 lines
6.0 KiB
C++
#ifndef ENGINE_H
|
|
#define ENGINE_H
|
|
|
|
#include <components/compiler/extensions.hpp>
|
|
#include <components/files/collections.hpp>
|
|
#include <components/translation/translation.hpp>
|
|
#include <components/settings/settings.hpp>
|
|
|
|
#include <osgViewer/Viewer>
|
|
#include <osgViewer/ViewerEventHandlers>
|
|
|
|
#include "mwbase/environment.hpp"
|
|
|
|
#include "mwworld/ptr.hpp"
|
|
|
|
namespace Resource
|
|
{
|
|
class ResourceSystem;
|
|
}
|
|
|
|
namespace SceneUtil
|
|
{
|
|
class WorkQueue;
|
|
class AsyncScreenCaptureOperation;
|
|
}
|
|
|
|
namespace VFS
|
|
{
|
|
class Manager;
|
|
}
|
|
|
|
namespace Compiler
|
|
{
|
|
class Context;
|
|
}
|
|
|
|
namespace MWLua
|
|
{
|
|
class LuaManager;
|
|
}
|
|
|
|
namespace Files
|
|
{
|
|
struct ConfigurationManager;
|
|
}
|
|
|
|
namespace osgViewer
|
|
{
|
|
class ScreenCaptureHandler;
|
|
}
|
|
|
|
struct SDL_Window;
|
|
|
|
namespace OMW
|
|
{
|
|
/// \brief Main engine class, that brings together all the components of OpenMW
|
|
class Engine
|
|
{
|
|
SDL_Window* mWindow;
|
|
std::unique_ptr<VFS::Manager> mVFS;
|
|
std::unique_ptr<Resource::ResourceSystem> mResourceSystem;
|
|
osg::ref_ptr<SceneUtil::WorkQueue> mWorkQueue;
|
|
MWBase::Environment mEnvironment;
|
|
ToUTF8::FromType mEncoding;
|
|
ToUTF8::Utf8Encoder* mEncoder;
|
|
Files::PathContainer mDataDirs;
|
|
std::vector<std::string> mArchives;
|
|
boost::filesystem::path mResDir;
|
|
osg::ref_ptr<osgViewer::Viewer> mViewer;
|
|
osg::ref_ptr<osgViewer::ScreenCaptureHandler> mScreenCaptureHandler;
|
|
osg::ref_ptr<SceneUtil::AsyncScreenCaptureOperation> mScreenCaptureOperation;
|
|
std::string mCellName;
|
|
std::vector<std::string> mContentFiles;
|
|
std::vector<std::string> mGroundcoverFiles;
|
|
std::vector<std::string> mLuaScriptListFiles;
|
|
bool mSkipMenu;
|
|
bool mUseSound;
|
|
bool mCompileAll;
|
|
bool mCompileAllDialogue;
|
|
int mWarningsMode;
|
|
std::string mFocusName;
|
|
bool mScriptConsoleMode;
|
|
std::string mStartupScript;
|
|
int mActivationDistanceOverride;
|
|
std::string mSaveGameFile;
|
|
// Grab mouse?
|
|
bool mGrab;
|
|
|
|
bool mExportFonts;
|
|
unsigned int mRandomSeed;
|
|
|
|
Compiler::Extensions mExtensions;
|
|
Compiler::Context *mScriptContext;
|
|
|
|
MWLua::LuaManager* mLuaManager;
|
|
|
|
Files::Collections mFileCollections;
|
|
bool mFSStrict;
|
|
Translation::Storage mTranslationDataStorage;
|
|
std::vector<std::string> mScriptBlacklist;
|
|
bool mScriptBlacklistUse;
|
|
bool mNewGame;
|
|
|
|
// not implemented
|
|
Engine (const Engine&);
|
|
Engine& operator= (const Engine&);
|
|
|
|
void executeLocalScripts();
|
|
|
|
bool frame (float dt);
|
|
|
|
/// Load settings from various files, returns the path to the user settings file
|
|
std::string loadSettings (Settings::Manager & settings);
|
|
|
|
/// Prepare engine for game play
|
|
void prepareEngine (Settings::Manager & settings);
|
|
|
|
void createWindow(Settings::Manager& settings);
|
|
void setWindowIcon();
|
|
|
|
public:
|
|
Engine(Files::ConfigurationManager& configurationManager);
|
|
virtual ~Engine();
|
|
|
|
/// Enable strict filesystem mode (do not fold case)
|
|
///
|
|
/// \attention The strict mode must be specified before any path-related settings
|
|
/// are given to the engine.
|
|
void enableFSStrict(bool fsStrict);
|
|
|
|
/// Set data dirs
|
|
void setDataDirs(const Files::PathContainer& dataDirs);
|
|
|
|
/// Add BSA archive
|
|
void addArchive(const std::string& archive);
|
|
|
|
/// Set resource dir
|
|
void setResourceDir(const boost::filesystem::path& parResDir);
|
|
|
|
/// Set start cell name
|
|
void setCell(const std::string& cellName);
|
|
|
|
/**
|
|
* @brief addContentFile - Adds content file (ie. esm/esp, or omwgame/omwaddon) to the content files container.
|
|
* @param file - filename (extension is required)
|
|
*/
|
|
void addContentFile(const std::string& file);
|
|
void addGroundcoverFile(const std::string& file);
|
|
void addLuaScriptListFile(const std::string& file);
|
|
|
|
/// Disable or enable all sounds
|
|
void setSoundUsage(bool soundUsage);
|
|
|
|
/// Skip main menu and go directly into the game
|
|
///
|
|
/// \param newGame Start a new game instead off dumping the player into the game
|
|
/// (ignored if !skipMenu).
|
|
void setSkipMenu (bool skipMenu, bool newGame);
|
|
|
|
void setGrabMouse(bool grab) { mGrab = grab; }
|
|
|
|
/// Initialise and enter main loop.
|
|
void go();
|
|
|
|
/// Compile all scripts (excludign dialogue scripts) at startup?
|
|
void setCompileAll (bool all);
|
|
|
|
/// Compile all dialogue scripts at startup?
|
|
void setCompileAllDialogue (bool all);
|
|
|
|
/// Font encoding
|
|
void setEncoding(const ToUTF8::FromType& encoding);
|
|
|
|
/// Enable console-only script functionality
|
|
void setScriptConsoleMode (bool enabled);
|
|
|
|
/// Set path for a script that is run on startup in the console.
|
|
void setStartupScript (const std::string& path);
|
|
|
|
/// Override the game setting specified activation distance.
|
|
void setActivationDistanceOverride (int distance);
|
|
|
|
void setWarningsMode (int mode);
|
|
|
|
void setScriptBlacklist (const std::vector<std::string>& list);
|
|
|
|
void setScriptBlacklistUse (bool use);
|
|
|
|
void enableFontExport(bool exportFonts);
|
|
|
|
/// Set the save game file to load after initialising the engine.
|
|
void setSaveGameFile(const std::string& savegame);
|
|
|
|
void setRandomSeed(unsigned int seed);
|
|
|
|
private:
|
|
Files::ConfigurationManager& mCfgMgr;
|
|
class LuaWorker;
|
|
};
|
|
}
|
|
|
|
#endif /* ENGINE_H */
|