diff options
Diffstat (limited to 'engines/hopkins')
-rw-r--r-- | engines/hopkins/files.h | 46 | ||||
-rw-r--r-- | engines/hopkins/globals.cpp | 37 | ||||
-rw-r--r-- | engines/hopkins/globals.h | 29 | ||||
-rw-r--r-- | engines/hopkins/hopkins.cpp | 27 | ||||
-rw-r--r-- | engines/hopkins/hopkins.h | 3 |
5 files changed, 129 insertions, 13 deletions
diff --git a/engines/hopkins/files.h b/engines/hopkins/files.h new file mode 100644 index 0000000000..992ea8786f --- /dev/null +++ b/engines/hopkins/files.h @@ -0,0 +1,46 @@ +/* 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. + * + */ + +#ifndef HOPKINS_FILES_H +#define HOPKINS_FILES_H + +#include "common/scummsys.h" +#include "common/hash-str.h" +#include "common/str.h" +#include "common/stream.h" + +namespace Hopkins { + +class FileManager { +public: + static void initSaves(); + static bool SAUVE_FICHIER(const Common::String &file, const void *buf, size_t n); + static bool bsave(const Common::String &file, const void *buf, size_t n); + static void Chage_Inifile(Common::StringMap &iniParams); + static void *CHARGE_FICHIER(const Common::String &file); + static void DMESS1(); + static int bload_it(Common::ReadStream &stream, void *buf, size_t nbytes); +}; + +} // End of namespace Hopkins + +#endif /* HOPKINS_GLOBALS_H */ diff --git a/engines/hopkins/globals.cpp b/engines/hopkins/globals.cpp index 555e8b6919..2a98764c45 100644 --- a/engines/hopkins/globals.cpp +++ b/engines/hopkins/globals.cpp @@ -27,11 +27,46 @@ namespace Hopkins { Globals::Globals() { FR = 0; SVGA = 2; - MANU_SCROLL = 0; + MANU_SCROLL = 1; SPEED_SCROLL = 16; internet = 1; PUBEXIT = 0; FADESPD = 15; + vitesse = 1; + INSTALL_TYPE = 1; + MUSICVOL = 6; + SOUNDVOL = 6; + VOICEVOL = 6; + MUSICOFF = false; + SOUNDOFF = false; + VOICEOFF = false; +} + +void Globals::setConfig() { + HOPIMAGE = "BUFFER"; + HOPANIM = "ANIM"; + HOPLINK = "LINK"; + HOPSAVE = "SAVE"; + HOPSOUND = "SOUND"; + HOPMUSIC = "MUSIC"; + HOPVOICE = "VOICE"; + HOPANM = "ANM"; + HOPSEQ = "SEQ"; + + switch (FR) { + case 0: + FICH_ZONE = "ZONEAN.TXT"; + FICH_TEXTE = "TEXTEAN.TXT"; + break; + case 1: + FICH_ZONE = "ZONE01.TXT"; + FICH_TEXTE = "TEXTE01.TXT"; + break; + case 2: + FICH_ZONE = "ZONEES.TXT"; + FICH_TEXTE = "TEXTEES.TXT"; + break; + } } } // End of namespace Hopkins diff --git a/engines/hopkins/globals.h b/engines/hopkins/globals.h index ec980a975d..9867376415 100644 --- a/engines/hopkins/globals.h +++ b/engines/hopkins/globals.h @@ -24,6 +24,7 @@ #define HOPKINS_GLOBALS_H #include "common/scummsys.h" +#include "common/str.h" namespace Hopkins { @@ -39,8 +40,34 @@ public: int SPEED_SCROLL; int internet; int PUBEXIT; + bool XFULLSCREEN; + int XSETMODE; + int XZOOM; + bool XFORCE16; + bool XFORCE8; + bool CARD_SB; + int vitesse; + int INSTALL_TYPE; + Common::String HOPIMAGE; + Common::String HOPANIM; + Common::String HOPLINK; + Common::String HOPSAVE; + Common::String HOPSOUND; + Common::String HOPMUSIC; + Common::String HOPVOICE; + Common::String HOPANM; + Common::String HOPSEQ; + Common::String FICH_ZONE; + Common::String FICH_TEXTE; + int SOUNDVOL; + int MUSICVOL; + int VOICEVOL; + bool SOUNDOFF; + bool MUSICOFF; + bool VOICEOFF; - Globals(); + Globals(); + void setConfig(); }; } // End of namespace Hopkins diff --git a/engines/hopkins/hopkins.cpp b/engines/hopkins/hopkins.cpp index 16e75784d5..ebf97c308d 100644 --- a/engines/hopkins/hopkins.cpp +++ b/engines/hopkins/hopkins.cpp @@ -51,17 +51,6 @@ Common::Error HopkinsEngine::run() { processIniParams(iniParams); /* - Chage_Inifile(); - LOAD_CONFIG(); - *(_DWORD *)HOPIMAGE = dword_807B6D0; - *(_WORD *)&HOPIMAGE[4] = word_807B6D4; - HOPIMAGE[6] = byte_807B6D6; - *(_DWORD *)HOPANIM = dword_807B6D7; - HOPANIM[4] = byte_807B6DB; - *(_DWORD *)HOPLINK = dword_807B6DC; - HOPLINK[4] = byte_807B6E0; - *(_DWORD *)HOPSAVE = dword_807B6E1; - HOPSAVE[4] = byte_807B6E5; if ( FR == 1 ) { *(_DWORD *)FICH_ZONE = dword_807B6E6; @@ -530,7 +519,23 @@ int HopkinsEngine::getRandomNumber(int maxNumber) { } void HopkinsEngine::processIniParams(Common::StringMap &iniParams) { + GLOBALS.XFULLSCREEN = iniParams["FULLSCREEN"] == "YES"; + GLOBALS.XSETMODE = 1; + if (iniParams.contains("SETMODE")) { + int setMode = atoi(iniParams["SETMODE"].c_str()); + GLOBALS.XSETMODE = CLIP(setMode, 1, 5); + } + + GLOBALS.XZOOM = 0; + if (GLOBALS.XSETMODE == 5 && iniParams.contains("ZOOM")) { + int zoom = atoi(iniParams["ZOOM"].c_str()); + GLOBALS.XZOOM = CLIP(zoom, 25, 100); + } + + GLOBALS.XFORCE16 = iniParams["FORCE16BITS"] == "YES"; + GLOBALS.XFORCE8 = iniParams["FORCE8BITS"] == "YES"; + GLOBALS.CARD_SB = iniParams["SOUND"] == "YES"; } } // End of namespace Hopkins diff --git a/engines/hopkins/hopkins.h b/engines/hopkins/hopkins.h index c4f8415543..57dc3ea7ad 100644 --- a/engines/hopkins/hopkins.h +++ b/engines/hopkins/hopkins.h @@ -61,6 +61,9 @@ private: const HopkinsGameDescription *_gameDescription; Common::RandomSource _randomSource; + /** + * Processes the loaded list of ini file parameters + */ void processIniParams(Common::StringMap &iniParams); protected: // Engine APIs |