forked from mirror/openmw-tes3mp
Merge branch 'next' of https://github.com/zinnschlag/openmw into tooltips
Conflicts: apps/openmw/engine.cpp apps/openmw/mwclass/apparatus.cpp apps/openmw/mwclass/book.cpp apps/openmw/mwclass/container.cpp apps/openmw/mwclass/ingredient.cpp apps/openmw/mwclass/misc.cpp apps/openmw/mwclass/npc.cpp apps/openmw/mwclass/potion.cpp apps/openmw/mwclass/repair.cpp apps/openmw/mwgui/window_manager.cppactorid
commit
1b5bfc52a1
@ -0,0 +1,123 @@
|
|||||||
|
|
||||||
|
#include "environment.hpp"
|
||||||
|
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
MWBase::Environment *MWBase::Environment::sThis = 0;
|
||||||
|
|
||||||
|
MWBase::Environment::Environment()
|
||||||
|
: mWorld (0), mSoundManager (0), mScriptManager (0), mWindowManager (0),
|
||||||
|
mMechanicsManager (0), mDialogueManager (0), mJournal (0), mInputManager (0), mFrameDuration (0)
|
||||||
|
{
|
||||||
|
assert (!sThis);
|
||||||
|
sThis = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWBase::Environment::~Environment()
|
||||||
|
{
|
||||||
|
sThis = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setWorld (MWWorld::World *world)
|
||||||
|
{
|
||||||
|
mWorld = world;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setSoundManager (MWSound::SoundManager *soundManager)
|
||||||
|
{
|
||||||
|
mSoundManager = soundManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setScriptManager (MWScript::ScriptManager *scriptManager)
|
||||||
|
{
|
||||||
|
mScriptManager = scriptManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setWindowManager (MWGui::WindowManager *windowManager)
|
||||||
|
{
|
||||||
|
mWindowManager = windowManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setMechanicsManager (MWMechanics::MechanicsManager *mechanicsManager)
|
||||||
|
{
|
||||||
|
mMechanicsManager = mechanicsManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setDialogueManager (MWDialogue::DialogueManager *dialogueManager)
|
||||||
|
{
|
||||||
|
mDialogueManager = dialogueManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setJournal (MWDialogue::Journal *journal)
|
||||||
|
{
|
||||||
|
mJournal = journal;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setInputManager (MWInput::MWInputManager *inputManager)
|
||||||
|
{
|
||||||
|
mInputManager = inputManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MWBase::Environment::setFrameDuration (float duration)
|
||||||
|
{
|
||||||
|
mFrameDuration = duration;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWWorld::World *MWBase::Environment::getWorld() const
|
||||||
|
{
|
||||||
|
assert (mWorld);
|
||||||
|
return mWorld;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWSound::SoundManager *MWBase::Environment::getSoundManager() const
|
||||||
|
{
|
||||||
|
assert (mSoundManager);
|
||||||
|
return mSoundManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWScript::ScriptManager *MWBase::Environment::getScriptManager() const
|
||||||
|
{
|
||||||
|
assert (mScriptManager);
|
||||||
|
return mScriptManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWGui::WindowManager *MWBase::Environment::getWindowManager() const
|
||||||
|
{
|
||||||
|
assert (mWindowManager);
|
||||||
|
return mWindowManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWMechanics::MechanicsManager *MWBase::Environment::getMechanicsManager() const
|
||||||
|
{
|
||||||
|
assert (mMechanicsManager);
|
||||||
|
return mMechanicsManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWDialogue::DialogueManager *MWBase::Environment::getDialogueManager() const
|
||||||
|
{
|
||||||
|
assert (mDialogueManager);
|
||||||
|
return mDialogueManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWDialogue::Journal *MWBase::Environment::getJournal() const
|
||||||
|
{
|
||||||
|
assert (mJournal);
|
||||||
|
return mJournal;
|
||||||
|
}
|
||||||
|
|
||||||
|
MWInput::MWInputManager *MWBase::Environment::getInputManager() const
|
||||||
|
{
|
||||||
|
assert (mInputManager);
|
||||||
|
return mInputManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
float MWBase::Environment::getFrameDuration() const
|
||||||
|
{
|
||||||
|
return mFrameDuration;
|
||||||
|
}
|
||||||
|
|
||||||
|
const MWBase::Environment& MWBase::Environment::get()
|
||||||
|
{
|
||||||
|
assert (sThis);
|
||||||
|
return *sThis;
|
||||||
|
}
|
@ -0,0 +1,116 @@
|
|||||||
|
#ifndef GAME_BASE_INVIRONMENT_H
|
||||||
|
#define GAME_BASE_INVIRONMENT_H
|
||||||
|
|
||||||
|
namespace MWSound
|
||||||
|
{
|
||||||
|
class SoundManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWScript
|
||||||
|
{
|
||||||
|
class ScriptManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWGui
|
||||||
|
{
|
||||||
|
class WindowManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWMechanics
|
||||||
|
{
|
||||||
|
class MechanicsManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWDialogue
|
||||||
|
{
|
||||||
|
class DialogueManager;
|
||||||
|
class Journal;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWInput
|
||||||
|
{
|
||||||
|
struct MWInputManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWWorld
|
||||||
|
{
|
||||||
|
class World;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWBase
|
||||||
|
{
|
||||||
|
/// \brief Central hub for mw-subsystems
|
||||||
|
///
|
||||||
|
/// This class allows each mw-subsystem to access any others subsystem's top-level manager class.
|
||||||
|
///
|
||||||
|
/// \attention Environment does not take ownership of the manager class instances it is handed over in
|
||||||
|
/// the set* functions.
|
||||||
|
class Environment
|
||||||
|
{
|
||||||
|
static Environment *sThis;
|
||||||
|
|
||||||
|
MWWorld::World *mWorld;
|
||||||
|
MWSound::SoundManager *mSoundManager;
|
||||||
|
MWScript::ScriptManager *mScriptManager;
|
||||||
|
MWGui::WindowManager *mWindowManager;
|
||||||
|
MWMechanics::MechanicsManager *mMechanicsManager;
|
||||||
|
MWDialogue::DialogueManager *mDialogueManager;
|
||||||
|
MWDialogue::Journal *mJournal;
|
||||||
|
MWInput::MWInputManager *mInputManager;
|
||||||
|
float mFrameDuration;
|
||||||
|
|
||||||
|
Environment (const Environment&);
|
||||||
|
///< not implemented
|
||||||
|
|
||||||
|
Environment& operator= (const Environment&);
|
||||||
|
///< not implemented
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
Environment();
|
||||||
|
|
||||||
|
~Environment();
|
||||||
|
|
||||||
|
void setWorld (MWWorld::World *world);
|
||||||
|
|
||||||
|
void setSoundManager (MWSound::SoundManager *soundManager);
|
||||||
|
|
||||||
|
void setScriptManager (MWScript::ScriptManager *scriptManager);
|
||||||
|
|
||||||
|
void setWindowManager (MWGui::WindowManager *windowManager);
|
||||||
|
|
||||||
|
void setMechanicsManager (MWMechanics::MechanicsManager *mechanicsManager);
|
||||||
|
|
||||||
|
void setDialogueManager (MWDialogue::DialogueManager *dialogueManager);
|
||||||
|
|
||||||
|
void setJournal (MWDialogue::Journal *journal);
|
||||||
|
|
||||||
|
void setInputManager (MWInput::MWInputManager *inputManager);
|
||||||
|
|
||||||
|
void setFrameDuration (float duration);
|
||||||
|
///< Set length of current frame in seconds.
|
||||||
|
|
||||||
|
MWWorld::World *getWorld() const;
|
||||||
|
|
||||||
|
MWSound::SoundManager *getSoundManager() const;
|
||||||
|
|
||||||
|
MWScript::ScriptManager *getScriptManager() const;
|
||||||
|
|
||||||
|
MWGui::WindowManager *getWindowManager() const;
|
||||||
|
|
||||||
|
MWMechanics::MechanicsManager *getMechanicsManager() const;
|
||||||
|
|
||||||
|
MWDialogue::DialogueManager *getDialogueManager() const;
|
||||||
|
|
||||||
|
MWDialogue::Journal *getJournal() const;
|
||||||
|
|
||||||
|
MWInput::MWInputManager *getInputManager() const;
|
||||||
|
|
||||||
|
float getFrameDuration() const;
|
||||||
|
|
||||||
|
static const Environment& get();
|
||||||
|
///< Return instance of this class.
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue