scummvm/engines/wintermute/base/base_engine.cpp
2016-05-08 23:25:16 +02:00

130 lines
3.3 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
/*
* This file is based on WME Lite.
* http://dead-code.org/redir.php?target=wmelite
* Copyright (c) 2011 Jan Nedoma
*/
#include "engines/wintermute/base/base_file_manager.h"
#include "engines/wintermute/base/base_game.h"
#include "engines/wintermute/base/base_engine.h"
#include "engines/wintermute/wintermute.h"
#include "engines/wintermute/system/sys_class_registry.h"
#include "common/system.h"
namespace Common {
DECLARE_SINGLETON(Wintermute::BaseEngine);
}
namespace Wintermute {
BaseEngine::BaseEngine() {
_fileManager = nullptr;
_gameRef = nullptr;
_classReg = nullptr;
_rnd = nullptr;
_gameId = "";
_language = Common::UNK_LANG;
}
void BaseEngine::init() {
_fileManager = new BaseFileManager(_language);
// Don't forget to register your random source
_rnd = new Common::RandomSource("Wintermute");
_classReg = new SystemClassRegistry();
_classReg->registerClasses();
}
BaseEngine::~BaseEngine() {
delete _fileManager;
delete _rnd;
delete _classReg;
}
void BaseEngine::createInstance(const Common::String &targetName, const Common::String &gameId, Common::Language lang, WMETargetExecutable targetExecutable) {
instance()._targetName = targetName;
instance()._gameId = gameId;
instance()._language = lang;
instance()._targetExecutable = targetExecutable;
instance().init();
}
void BaseEngine::LOG(bool res, const char *fmt, ...) {
uint32 secs = g_system->getMillis() / 1000;
uint32 hours = secs / 3600;
secs = secs % 3600;
uint32 mins = secs / 60;
secs = secs % 60;
char buff[512];
va_list va;
va_start(va, fmt);
vsprintf(buff, fmt, va);
va_end(va);
if (instance()._gameRef) {
instance()._gameRef->LOG(res, "%s", buff);
} else {
debugCN(kWintermuteDebugLog, "%02d:%02d:%02d: %s\n", hours, mins, secs, buff);
}
}
uint32 BaseEngine::randInt(int from, int to) {
return _rnd->getRandomNumberRng(from, to);
}
BaseSoundMgr *BaseEngine::getSoundMgr() {
if (instance()._gameRef) {
return _gameRef->_soundMgr;
} else {
return nullptr;
}
}
BaseRenderer *BaseEngine::getRenderer() {
if (instance()._gameRef) {
return instance()._gameRef->_renderer;
} else {
return nullptr;
}
}
const Timer *BaseEngine::getTimer() {
if (instance()._gameRef) {
return instance()._gameRef->getTimer();
} else {
return nullptr;
}
}
const Timer *BaseEngine::getLiveTimer() {
if (instance()._gameRef) {
return instance()._gameRef->getLiveTimer();
} else {
return nullptr;
}
}
} // End of namespace Wintermute