2017-05-26 03:24:38 +00:00
|
|
|
/* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2017-08-22 12:12:54 +00:00
|
|
|
#include "common/config-manager.h"
|
2017-05-26 19:25:11 +00:00
|
|
|
#include "common/debug.h"
|
2017-06-05 17:10:47 +00:00
|
|
|
|
|
|
|
#include "sludge/allfiles.h"
|
|
|
|
#include "sludge/backdrop.h"
|
2017-07-19 22:41:13 +00:00
|
|
|
#include "sludge/builtin.h"
|
2017-06-05 17:10:47 +00:00
|
|
|
#include "sludge/cursors.h"
|
2017-08-22 12:12:54 +00:00
|
|
|
#include "sludge/event.h"
|
2017-07-19 22:41:13 +00:00
|
|
|
#include "sludge/fonttext.h"
|
|
|
|
#include "sludge/freeze.h"
|
|
|
|
#include "sludge/floor.h"
|
|
|
|
#include "sludge/fileset.h"
|
2018-05-27 21:23:15 +00:00
|
|
|
#include "sludge/function.h"
|
2017-07-19 22:41:13 +00:00
|
|
|
#include "sludge/graphics.h"
|
|
|
|
#include "sludge/imgloader.h"
|
|
|
|
#include "sludge/language.h"
|
|
|
|
#include "sludge/moreio.h"
|
|
|
|
#include "sludge/newfatal.h"
|
2017-06-05 17:10:47 +00:00
|
|
|
#include "sludge/objtypes.h"
|
2017-07-19 22:41:13 +00:00
|
|
|
#include "sludge/people.h"
|
2017-06-05 17:10:47 +00:00
|
|
|
#include "sludge/region.h"
|
2018-04-29 07:42:26 +00:00
|
|
|
#include "sludge/savedata.h"
|
2017-07-19 22:41:13 +00:00
|
|
|
#include "sludge/sludge.h"
|
|
|
|
#include "sludge/sludger.h"
|
2018-05-27 21:23:15 +00:00
|
|
|
#include "sludge/sound.h"
|
2017-12-19 20:24:31 +00:00
|
|
|
#include "sludge/speech.h"
|
2018-05-27 21:23:15 +00:00
|
|
|
#include "sludge/sprites.h"
|
|
|
|
#include "sludge/sprbanks.h"
|
|
|
|
#include "sludge/statusba.h"
|
2017-06-05 17:10:47 +00:00
|
|
|
#include "sludge/variable.h"
|
2017-07-13 16:08:30 +00:00
|
|
|
#include "sludge/version.h"
|
2017-07-19 22:41:13 +00:00
|
|
|
#include "sludge/zbuffer.h"
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-05-26 19:25:11 +00:00
|
|
|
namespace Sludge {
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2018-05-27 21:23:15 +00:00
|
|
|
extern int numBIFNames;
|
|
|
|
extern Common::String *allBIFNames;
|
|
|
|
extern int numUserFunc;
|
|
|
|
extern Common::String *allUserFunc;
|
|
|
|
|
2017-05-26 03:24:38 +00:00
|
|
|
int selectedLanguage = 0;
|
|
|
|
|
|
|
|
int gameVersion;
|
|
|
|
FILETIME fileTime;
|
|
|
|
|
2017-08-22 12:12:54 +00:00
|
|
|
int numGlobals = 0;
|
|
|
|
|
|
|
|
extern Variable *launchResult;
|
2018-05-27 21:23:15 +00:00
|
|
|
extern Variable *globalVars;
|
|
|
|
extern VariableStack *noStack;
|
2017-08-22 12:12:54 +00:00
|
|
|
|
|
|
|
extern bool allowAnyFilename;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
Common::File *openAndVerify(const Common::String &filename, char extra1, char extra2,
|
2017-05-29 06:02:59 +00:00
|
|
|
const char *er, int &fileVersion) {
|
2017-05-27 18:16:54 +00:00
|
|
|
Common::File *fp = new Common::File();
|
|
|
|
if (!fp->open(filename)) {
|
2017-05-26 03:24:38 +00:00
|
|
|
fatal("Can't open file", filename);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
bool headerBad = false;
|
2017-05-30 07:59:56 +00:00
|
|
|
if (fp->readByte() != 'S')
|
2017-05-29 06:02:59 +00:00
|
|
|
headerBad = true;
|
2017-05-30 07:59:56 +00:00
|
|
|
if (fp->readByte() != 'L')
|
2017-05-29 06:02:59 +00:00
|
|
|
headerBad = true;
|
2017-05-30 07:59:56 +00:00
|
|
|
if (fp->readByte() != 'U')
|
2017-05-29 06:02:59 +00:00
|
|
|
headerBad = true;
|
2017-05-30 07:59:56 +00:00
|
|
|
if (fp->readByte() != 'D')
|
2017-05-29 06:02:59 +00:00
|
|
|
headerBad = true;
|
2017-05-30 07:59:56 +00:00
|
|
|
if (fp->readByte() != extra1)
|
2017-05-29 06:02:59 +00:00
|
|
|
headerBad = true;
|
2017-05-30 07:59:56 +00:00
|
|
|
if (fp->readByte() != extra2)
|
2017-05-29 06:02:59 +00:00
|
|
|
headerBad = true;
|
2017-05-26 03:24:38 +00:00
|
|
|
if (headerBad) {
|
|
|
|
fatal(er, filename);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
char c;
|
2017-05-30 07:59:56 +00:00
|
|
|
c = fp->readByte();
|
2017-08-02 14:35:09 +00:00
|
|
|
while ((c = fp->readByte()))
|
|
|
|
;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-05-30 07:59:56 +00:00
|
|
|
int majVersion = fp->readByte();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "majVersion %i", majVersion);
|
2017-05-30 07:59:56 +00:00
|
|
|
int minVersion = fp->readByte();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "minVersion %i", minVersion);
|
2017-05-26 03:24:38 +00:00
|
|
|
fileVersion = majVersion * 256 + minVersion;
|
|
|
|
|
2017-07-15 12:18:17 +00:00
|
|
|
Common::String txtVer = "";
|
2017-05-26 03:24:38 +00:00
|
|
|
|
|
|
|
if (fileVersion > WHOLE_VERSION) {
|
2017-07-15 12:18:17 +00:00
|
|
|
txtVer = Common::String::format(ERROR_VERSION_TOO_LOW_2, majVersion, minVersion);
|
2017-05-26 03:24:38 +00:00
|
|
|
fatal(ERROR_VERSION_TOO_LOW_1, txtVer);
|
|
|
|
return NULL;
|
|
|
|
} else if (fileVersion < MINIM_VERSION) {
|
2017-07-15 12:18:17 +00:00
|
|
|
txtVer = Common::String::format(ERROR_VERSION_TOO_HIGH_2, majVersion, minVersion);
|
2017-05-26 03:24:38 +00:00
|
|
|
fatal(ERROR_VERSION_TOO_HIGH_1, txtVer);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
return fp;
|
|
|
|
}
|
|
|
|
|
2017-08-22 12:12:54 +00:00
|
|
|
void initSludge() {
|
2018-05-27 20:11:16 +00:00
|
|
|
g_sludge->_timer.reset();
|
2017-08-22 12:12:54 +00:00
|
|
|
g_sludge->_languageMan->init();
|
|
|
|
g_sludge->_gfxMan->init();
|
|
|
|
g_sludge->_resMan->init();
|
2018-04-15 19:10:02 +00:00
|
|
|
g_sludge->_peopleMan->init();
|
2018-05-01 16:41:34 +00:00
|
|
|
g_sludge->_floorMan->init();
|
2017-08-22 12:12:54 +00:00
|
|
|
g_sludge->_objMan->init();
|
2017-12-19 20:24:31 +00:00
|
|
|
g_sludge->_speechMan->init();
|
2017-08-22 12:12:54 +00:00
|
|
|
initStatusBar();
|
|
|
|
g_sludge->_evtMan->init();
|
|
|
|
g_sludge->_txtMan->init();
|
|
|
|
g_sludge->_cursorMan->init();
|
|
|
|
|
|
|
|
g_sludge->_soundMan->init();
|
|
|
|
if (!ConfMan.hasKey("mute") || !ConfMan.getBool("mute")) {
|
|
|
|
g_sludge->_soundMan->initSoundStuff();
|
|
|
|
}
|
|
|
|
|
2018-04-29 07:42:26 +00:00
|
|
|
CustomSaveHelper::_saveEncoding = false;
|
|
|
|
|
2017-08-22 12:12:54 +00:00
|
|
|
// global variables
|
|
|
|
numGlobals = 0;
|
|
|
|
launchResult = nullptr;
|
|
|
|
|
|
|
|
allowAnyFilename = true;
|
|
|
|
noStack = nullptr;
|
|
|
|
numBIFNames = numUserFunc = 0;
|
|
|
|
allUserFunc = allBIFNames = nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
void killSludge() {
|
|
|
|
killAllFunctions();
|
2018-04-15 19:10:02 +00:00
|
|
|
g_sludge->_peopleMan->kill();
|
2018-04-14 22:33:01 +00:00
|
|
|
g_sludge->_regionMan->kill();
|
2018-05-01 16:41:34 +00:00
|
|
|
g_sludge->_floorMan->kill();
|
2017-12-19 20:24:31 +00:00
|
|
|
g_sludge->_speechMan->kill();
|
2017-08-22 12:12:54 +00:00
|
|
|
g_sludge->_languageMan->kill();
|
|
|
|
g_sludge->_gfxMan->kill();
|
|
|
|
g_sludge->_resMan->kill();
|
|
|
|
g_sludge->_objMan->kill();
|
|
|
|
g_sludge->_soundMan->killSoundStuff();
|
|
|
|
g_sludge->_evtMan->kill();
|
|
|
|
g_sludge->_txtMan->kill();
|
|
|
|
g_sludge->_cursorMan->kill();
|
|
|
|
|
|
|
|
// global variables
|
|
|
|
numBIFNames = numUserFunc = 0;
|
|
|
|
delete []allUserFunc;
|
|
|
|
delete []allBIFNames;
|
|
|
|
}
|
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
bool initSludge(const Common::String &filename) {
|
2017-08-22 12:12:54 +00:00
|
|
|
initSludge();
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
Common::File *fp = openAndVerify(filename, 'G', 'E', ERROR_BAD_HEADER, gameVersion);
|
2017-05-29 06:02:59 +00:00
|
|
|
if (!fp)
|
|
|
|
return false;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-05-30 07:59:56 +00:00
|
|
|
char c = fp->readByte();
|
2017-05-26 03:24:38 +00:00
|
|
|
if (c) {
|
2017-05-30 07:59:56 +00:00
|
|
|
numBIFNames = fp->readUint16BE();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "numBIFNames %i", numBIFNames);
|
2017-07-11 12:57:31 +00:00
|
|
|
allBIFNames = new Common::String[numBIFNames];
|
2017-05-29 06:02:59 +00:00
|
|
|
if (!checkNew(allBIFNames))
|
|
|
|
return false;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-05-29 06:02:59 +00:00
|
|
|
for (int fn = 0; fn < numBIFNames; fn++) {
|
2017-07-11 12:57:31 +00:00
|
|
|
allBIFNames[fn].clear();
|
2017-05-26 03:24:38 +00:00
|
|
|
allBIFNames[fn] = readString(fp);
|
|
|
|
}
|
2017-05-30 07:59:56 +00:00
|
|
|
numUserFunc = fp->readUint16BE();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "numUserFunc %i", numUserFunc);
|
2017-07-11 12:57:31 +00:00
|
|
|
allUserFunc = new Common::String[numUserFunc];
|
2017-05-29 06:02:59 +00:00
|
|
|
if (!checkNew(allUserFunc))
|
|
|
|
return false;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-05-29 06:02:59 +00:00
|
|
|
for (int fn = 0; fn < numUserFunc; fn++) {
|
2017-07-11 12:57:31 +00:00
|
|
|
allUserFunc[fn].clear();
|
2017-05-26 03:24:38 +00:00
|
|
|
allUserFunc[fn] = readString(fp);
|
|
|
|
}
|
2018-05-28 19:55:06 +00:00
|
|
|
|
2017-05-26 03:24:38 +00:00
|
|
|
if (gameVersion >= VERSION(1, 3)) {
|
2018-05-28 19:55:06 +00:00
|
|
|
g_sludge->_resMan->readResourceNames(fp);
|
2017-05-26 03:24:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-19 22:41:13 +00:00
|
|
|
int winWidth = fp->readUint16BE();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "winWidth : %i", winWidth);
|
2017-07-19 22:41:13 +00:00
|
|
|
int winHeight = fp->readUint16BE();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "winHeight : %i", winHeight);
|
2017-07-19 22:41:13 +00:00
|
|
|
g_sludge->_gfxMan->setWindowSize(winWidth, winHeight);
|
|
|
|
|
2017-07-18 14:17:39 +00:00
|
|
|
int specialSettings = fp->readByte();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "specialSettings : %i", specialSettings);
|
2018-05-27 20:11:16 +00:00
|
|
|
g_sludge->_timer.setDesiredFPS(1000 / fp->readByte());
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
readString(fp); // Unused - was used for registration purposes.
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-10 19:44:14 +00:00
|
|
|
uint bytes_read = fp->read(&fileTime, sizeof(FILETIME));
|
2017-05-27 18:16:54 +00:00
|
|
|
if (bytes_read != sizeof(FILETIME) && fp->err()) {
|
2017-08-02 14:35:09 +00:00
|
|
|
debug(0, "Reading error in initSludge.");
|
2017-05-26 03:24:38 +00:00
|
|
|
}
|
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
Common::String dataFol = (gameVersion >= VERSION(1, 3)) ? readString(fp) : "";
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "dataFol : %s", dataFol.c_str());
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-08-22 12:12:54 +00:00
|
|
|
g_sludge->_languageMan->createTable(fp);
|
2017-05-26 03:24:38 +00:00
|
|
|
|
|
|
|
if (gameVersion >= VERSION(1, 6)) {
|
2017-05-30 07:59:56 +00:00
|
|
|
fp->readByte();
|
2017-05-26 03:24:38 +00:00
|
|
|
// aaLoad
|
2017-05-30 07:59:56 +00:00
|
|
|
fp->readByte();
|
2017-07-10 22:02:46 +00:00
|
|
|
fp->readFloatLE();
|
|
|
|
fp->readFloatLE();
|
2017-05-26 03:24:38 +00:00
|
|
|
}
|
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
Common::String checker = readString(fp);
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "checker : %s", checker.c_str());
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
if (checker != "okSoFar")
|
2017-05-29 06:02:59 +00:00
|
|
|
return fatal(ERROR_BAD_HEADER, filename);
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-10 19:44:14 +00:00
|
|
|
byte customIconLogo = fp->readByte();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "Game icon type: %i", customIconLogo);
|
2017-05-26 03:24:38 +00:00
|
|
|
|
|
|
|
if (customIconLogo & 1) {
|
|
|
|
// There is an icon - read it!
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "There is an icon - read it!");
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-16 10:18:30 +00:00
|
|
|
// read game icon
|
|
|
|
Graphics::Surface gameIcon;
|
|
|
|
if (!ImgLoader::loadImage(fp, &gameIcon, false))
|
|
|
|
return false;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (customIconLogo & 2) {
|
|
|
|
// There is an logo - read it!
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "There is an logo - read it!");
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-16 10:18:30 +00:00
|
|
|
// read game logo
|
|
|
|
Graphics::Surface gameLogo;
|
|
|
|
if (!ImgLoader::loadImage(fp, &gameLogo))
|
|
|
|
return false;
|
2017-05-26 03:24:38 +00:00
|
|
|
}
|
|
|
|
|
2017-05-30 07:59:56 +00:00
|
|
|
numGlobals = fp->readUint16BE();
|
2017-08-02 14:35:09 +00:00
|
|
|
debugC(2, kSludgeDebugDataLoad, "numGlobals : %i", numGlobals);
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-20 08:39:24 +00:00
|
|
|
globalVars = new Variable[numGlobals];
|
2017-05-29 06:02:59 +00:00
|
|
|
if (!checkNew(globalVars))
|
|
|
|
return false;
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-12 21:20:46 +00:00
|
|
|
// Get language selected by user
|
2017-07-18 17:03:45 +00:00
|
|
|
g_sludge->_resMan->setData(fp);
|
2017-07-18 15:25:00 +00:00
|
|
|
g_sludge->_languageMan->setLanguageID(g_sludge->getLanguageID());
|
2017-05-26 03:24:38 +00:00
|
|
|
|
2017-07-11 12:57:31 +00:00
|
|
|
if (!dataFol.empty()) {
|
|
|
|
Common::String dataFolder = encodeFilename(dataFol);
|
2017-05-26 03:24:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
positionStatus(10, winHeight - 15);
|
2017-05-27 18:16:54 +00:00
|
|
|
|
2017-05-26 03:24:38 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-06-21 14:24:55 +00:00
|
|
|
void displayBase() {
|
2017-08-01 07:29:34 +00:00
|
|
|
g_sludge->_gfxMan->clear(); // Clear screen
|
|
|
|
g_sludge->_gfxMan->drawBackDrop();// Draw Backdrop
|
2017-07-19 22:41:13 +00:00
|
|
|
g_sludge->_gfxMan->drawZBuffer(g_sludge->_gfxMan->getCamX(), g_sludge->_gfxMan->getCamY(), false);
|
2018-04-15 19:10:02 +00:00
|
|
|
g_sludge->_peopleMan->drawPeople();// Then add any moving characters...
|
2017-07-19 22:41:13 +00:00
|
|
|
g_sludge->_gfxMan->displaySpriteLayers();
|
2017-06-21 14:24:55 +00:00
|
|
|
}
|
|
|
|
|
2017-05-26 03:24:38 +00:00
|
|
|
void sludgeDisplay() {
|
2017-06-21 14:24:55 +00:00
|
|
|
displayBase();
|
2017-12-19 20:24:31 +00:00
|
|
|
g_sludge->_speechMan->display();
|
2017-05-26 03:24:38 +00:00
|
|
|
drawStatusBar();
|
2017-07-21 06:16:17 +00:00
|
|
|
g_sludge->_cursorMan->displayCursor();
|
2017-07-19 22:41:13 +00:00
|
|
|
g_sludge->_gfxMan->display();
|
2017-05-26 03:24:38 +00:00
|
|
|
}
|
|
|
|
|
2017-05-26 19:25:11 +00:00
|
|
|
} // End of namespace Sludge
|