Store configuration in /etc/openmw/ and ~/.openmw/ on linux

Requires new openengine version.
This commit is contained in:
Jan-Peter Nilsson 2011-01-04 01:34:55 +01:00
parent 940554b5fc
commit 429775d485
8 changed files with 111 additions and 25 deletions

View file

@ -41,6 +41,7 @@
#include <MyGUI_WidgetManager.h> #include <MyGUI_WidgetManager.h>
#include "mwgui/class.hpp" #include "mwgui/class.hpp"
#include "path.hpp"
//using namespace ESM; //using namespace ESM;
@ -245,6 +246,12 @@ void OMW::Engine::setDataDir (const boost::filesystem::path& dataDir)
mDataDir = boost::filesystem::system_complete (dataDir); mDataDir = boost::filesystem::system_complete (dataDir);
} }
// Set resource dir
void OMW::Engine::setResourceDir (const boost::filesystem::path& parResDir)
{
mResDir = boost::filesystem::system_complete(parResDir);
}
// Set start cell name (only interiors for now) // Set start cell name (only interiors for now)
void OMW::Engine::setCell (const std::string& cellName) void OMW::Engine::setCell (const std::string& cellName)
@ -300,16 +307,20 @@ void OMW::Engine::go()
std::cout << "Data directory: " << mDataDir << "\n"; std::cout << "Data directory: " << mDataDir << "\n";
const char* plugCfg = "plugins.cfg"; std::string cfgDir = OMW::Path::getPath(OMW::Path::USER_CFG_PATH, "openmw", "");
std::string plugCfg = "plugins.cfg";
std::string ogreCfg = "ogre.cfg";
ogreCfg.insert(0, cfgDir);
plugCfg.insert(0, cfgDir);
mOgre.configure(!isFile("ogre.cfg"), plugCfg, false); mOgre.configure(!isFile(ogreCfg.c_str()), cfgDir, plugCfg, false);
addResourcesDirectory (mDataDir / "Meshes"); addResourcesDirectory (mDataDir / "Meshes");
addResourcesDirectory (mDataDir / "Textures"); addResourcesDirectory (mDataDir / "Textures");
// This has to be added BEFORE MyGUI is initialized, as it needs // This has to be added BEFORE MyGUI is initialized, as it needs
// to find core.xml here. // to find core.xml here.
addResourcesDirectory("resources/mygui/"); addResourcesDirectory(mResDir / "mygui");
// Create the window // Create the window
mOgre.createWindow("OpenMW"); mOgre.createWindow("OpenMW");
@ -317,11 +328,10 @@ void OMW::Engine::go()
loadBSA(); loadBSA();
// Create the world // Create the world
mEnvironment.mWorld = new MWWorld::World (mOgre, mDataDir, mMaster, mNewGame, mEnvironment); mEnvironment.mWorld = new MWWorld::World (mOgre, mDataDir, mMaster, mResDir, mNewGame, mEnvironment);
// Set up the GUI system // Set up the GUI system
mGuiManager = new OEngine::GUI::MyGUIManager(mOgre.getWindow(), mGuiManager = new OEngine::GUI::MyGUIManager(mOgre.getWindow(), mOgre.getScene(), false, cfgDir);
mOgre.getScene());
MyGUI::FactoryManager::getInstance().registerFactory<MWGui::Widgets::MWSkill>("Widget"); MyGUI::FactoryManager::getInstance().registerFactory<MWGui::Widgets::MWSkill>("Widget");
MyGUI::FactoryManager::getInstance().registerFactory<MWGui::Widgets::MWAttribute>("Widget"); MyGUI::FactoryManager::getInstance().registerFactory<MWGui::Widgets::MWAttribute>("Widget");
MyGUI::FactoryManager::getInstance().registerFactory<MWGui::Widgets::MWSpell>("Widget"); MyGUI::FactoryManager::getInstance().registerFactory<MWGui::Widgets::MWSpell>("Widget");

View file

@ -57,6 +57,7 @@ namespace OMW
//int nFiles; //int nFiles;
boost::filesystem::path mDataDir; boost::filesystem::path mDataDir;
boost::filesystem::path mResDir;
OEngine::Render::OgreRenderer mOgre; OEngine::Render::OgreRenderer mOgre;
std::string mCellName; std::string mCellName;
std::string mMaster; std::string mMaster;
@ -107,6 +108,9 @@ namespace OMW
/// Set data dir /// Set data dir
void setDataDir (const boost::filesystem::path& dataDir); void setDataDir (const boost::filesystem::path& dataDir);
/// Set resource dir
void setResourceDir (const boost::filesystem::path& parResDir);
/// Set start cell name (only interiors for now) /// Set start cell name (only interiors for now)
void setCell (const std::string& cellName); void setCell (const std::string& cellName);

View file

@ -7,9 +7,10 @@
#include <components/misc/fileops.hpp> #include <components/misc/fileops.hpp>
#include "engine.hpp" #include "engine.hpp"
#include "path.hpp"
#if defined(_WIN32) && !defined(_CONSOLE) #if defined(_WIN32) && !defined(_CONSOLE)
#include <boost/iostreams/concepts.hpp> #include <boost/iostreams/concepts.hpp>
#include <boost/iostreams/stream_buffer.hpp> #include <boost/iostreams/stream_buffer.hpp>
# if !defined(_DEBUG) # if !defined(_DEBUG)
@ -42,6 +43,8 @@ bool parseOptions (int argc, char**argv, OMW::Engine& engine)
("help", "print help message") ("help", "print help message")
("data", bpo::value<std::string>()->default_value ("data"), ("data", bpo::value<std::string>()->default_value ("data"),
"set data directory") "set data directory")
("resources", bpo::value<std::string>()->default_value ("resources"),
"set resources directory")
("start", bpo::value<std::string>()->default_value ("Beshara"), ("start", bpo::value<std::string>()->default_value ("Beshara"),
"set initial cell") "set initial cell")
("master", bpo::value<std::string>()->default_value ("Morrowind"), ("master", bpo::value<std::string>()->default_value ("Morrowind"),
@ -55,20 +58,23 @@ bool parseOptions (int argc, char**argv, OMW::Engine& engine)
bpo::variables_map variables; bpo::variables_map variables;
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE std::string cfgFile = OMW::Path::getPath(OMW::Path::GLOBAL_CFG_PATH, "openmw", "openmw.cfg");
std::string configFilePath(macBundlePath() + "/Contents/MacOS/openmw.cfg"); std::cout << "Using global config file: " << cfgFile << std::endl;
std::ifstream configFile (configFilePath.c_str()); std::ifstream globalConfigFile(cfgFile.c_str());
#else
std::ifstream configFile ("openmw.cfg"); cfgFile = OMW::Path::getPath(OMW::Path::USER_CFG_PATH, "openmw", "openmw.cfg");
#endif std::cout << "Using user config file: " << cfgFile << std::endl;
std::ifstream userConfigFile(cfgFile.c_str());
bpo::parsed_options valid_opts = bpo::command_line_parser(argc, argv).options(desc).allow_unregistered().run(); bpo::parsed_options valid_opts = bpo::command_line_parser(argc, argv).options(desc).allow_unregistered().run();
bpo::store(valid_opts, variables); bpo::store(valid_opts, variables);
bpo::notify(variables); bpo::notify(variables);
if (configFile.is_open()) if (userConfigFile.is_open())
bpo::store ( bpo::parse_config_file (configFile, desc), variables); bpo::store ( bpo::parse_config_file (userConfigFile, desc), variables);
if (globalConfigFile.is_open())
bpo::store ( bpo::parse_config_file (globalConfigFile, desc), variables);
if (variables.count ("help")) if (variables.count ("help"))
{ {
@ -77,6 +83,7 @@ bool parseOptions (int argc, char**argv, OMW::Engine& engine)
} }
engine.setDataDir (variables["data"].as<std::string>()); engine.setDataDir (variables["data"].as<std::string>());
engine.setResourceDir (variables["resources"].as<std::string>());
engine.setCell (variables["start"].as<std::string>()); engine.setCell (variables["start"].as<std::string>());
engine.addMaster (variables["master"].as<std::string>()); engine.addMaster (variables["master"].as<std::string>());

View file

@ -19,7 +19,8 @@ namespace MWRender
public: public:
CaelumManager (Ogre::RenderWindow* pRenderWindow, CaelumManager (Ogre::RenderWindow* pRenderWindow,
Ogre::Camera* pCamera); Ogre::Camera* pCamera,
const boost::filesystem::path& resDir);
virtual ~CaelumManager (); virtual ~CaelumManager ();
virtual void enable() {} virtual void enable() {}
@ -44,7 +45,8 @@ namespace MWRender
}; };
CaelumManager::CaelumManager (Ogre::RenderWindow* pRenderWindow, CaelumManager::CaelumManager (Ogre::RenderWindow* pRenderWindow,
Ogre::Camera* pCamera) Ogre::Camera* pCamera,
const boost::filesystem::path& resDir)
: mpCaelumSystem (NULL) : mpCaelumSystem (NULL)
{ {
using namespace Ogre; using namespace Ogre;
@ -55,7 +57,7 @@ namespace MWRender
// Load the Caelum resources // Load the Caelum resources
// //
ResourceGroupManager::getSingleton().addResourceLocation("resources/caelum", "FileSystem", "Caelum"); ResourceGroupManager::getSingleton().addResourceLocation((resDir / "caelum").string(), "FileSystem", "Caelum");
ResourceGroupManager::getSingleton().initialiseAllResourceGroups(); ResourceGroupManager::getSingleton().initialiseAllResourceGroups();
// Load the Caelum resources // Load the Caelum resources
@ -89,13 +91,14 @@ namespace MWRender
/// \return NULL on failure. /// \return NULL on failure.
/// ///
SkyManager* SkyManager::create (Ogre::RenderWindow* pRenderWindow, SkyManager* SkyManager::create (Ogre::RenderWindow* pRenderWindow,
Ogre::Camera* pCamera) Ogre::Camera* pCamera,
const boost::filesystem::path& resDir)
{ {
SkyManager* pSkyManager = NULL; SkyManager* pSkyManager = NULL;
try try
{ {
pSkyManager = new CaelumManager(pRenderWindow, pCamera); pSkyManager = new CaelumManager(pRenderWindow, pCamera, resDir);
} }
catch (Ogre::Exception& e) catch (Ogre::Exception& e)
{ {

View file

@ -1,6 +1,8 @@
#ifndef _GAME_RENDER_SKY_H #ifndef _GAME_RENDER_SKY_H
#define _GAME_RENDER_SKY_H #define _GAME_RENDER_SKY_H
#include <boost/filesystem.hpp>
namespace Ogre namespace Ogre
{ {
class RenderWindow; class RenderWindow;
@ -16,7 +18,8 @@ namespace MWRender
{ {
public: public:
static SkyManager* create (Ogre::RenderWindow* pRenderWindow, static SkyManager* create (Ogre::RenderWindow* pRenderWindow,
Ogre::Camera* pCamera); Ogre::Camera* pCamera,
const boost::filesystem::path& resDir);
virtual ~SkyManager() {} virtual ~SkyManager() {}
virtual void enable() = 0; virtual void enable() = 0;

View file

@ -316,7 +316,7 @@ namespace MWWorld
} }
World::World (OEngine::Render::OgreRenderer& renderer, const boost::filesystem::path& dataDir, World::World (OEngine::Render::OgreRenderer& renderer, const boost::filesystem::path& dataDir,
const std::string& master, bool newGame, Environment& environment) const std::string& master, const boost::filesystem::path& resDir, bool newGame, Environment& environment)
: mSkyManager (0), mScene (renderer), mPlayer (0), mCurrentCell (0), mGlobalVariables (0), : mSkyManager (0), mScene (renderer), mPlayer (0), mCurrentCell (0), mGlobalVariables (0),
mSky (false), mCellChanged (false), mEnvironment (environment) mSky (false), mCellChanged (false), mEnvironment (environment)
{ {
@ -341,7 +341,7 @@ namespace MWWorld
} }
mSkyManager = mSkyManager =
MWRender::SkyManager::create(renderer.getWindow(), mScene.getCamera()); MWRender::SkyManager::create(renderer.getWindow(), mScene.getCamera(), resDir);
} }
World::~World() World::~World()

View file

@ -89,8 +89,8 @@ namespace MWWorld
public: public:
World (OEngine::Render::OgreRenderer& renderer, const boost::filesystem::path& master, World (OEngine::Render::OgreRenderer& renderer, const boost::filesystem::path& dataDir,
const std::string& dataDir, bool newGame, Environment& environment); const std::string& master, const boost::filesystem::path& resDir, bool newGame, Environment& environment);
~World(); ~World();

59
apps/openmw/path.hpp Normal file
View file

@ -0,0 +1,59 @@
#ifndef PATH__HPP
#define PATH__HPP
#include <OgrePlatform.h>
#include <string>
#if OGRE_PLATFORM_LINUX
#include <sys/stat.h>
#include <sys/types.h>
#include <stdlib.h> //getenv
#endif
namespace OMW
{
class Path
{
public:
enum PathTypeEnum
{
USER_CFG_PATH,
GLOBAL_CFG_PATH
};
//TODO use application data dir on windows?
static std::string getPath(PathTypeEnum parType, const std::string parApp, const std::string parFile)
{
std::string theBasePath;
if(parType == GLOBAL_CFG_PATH)
{
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
theBasePath = macBundlePath() + "/Contents/MacOS/"; //FIXME do we have global/local with OSX?
#elif OGRE_PLATFORM_LINUX
theBasePath = "/etc/"+parApp+"/";
#else
theBasePath = "";
#endif
}
else
{
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
theBasePath = macBundlePath() + "/Contents/MacOS/"; //FIXME do we have global/local with OSX?
#elif OGRE_PLATFORM_LINUX
const char* homedir;
if ((homedir = getenv("HOME")) == NULL)
return NULL;
theBasePath = std::string(homedir)+"/."+parApp+"/";
mkdir(theBasePath.c_str(), 0777);
#else
theBasePath = "";
#endif
}
theBasePath.append(parFile);
return theBasePath;
}
};
}
#endif