2007-05-30 21:56:52 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
2004-04-12 21:40:49 +00:00
|
|
|
*
|
2007-05-30 21:56:52 +00:00
|
|
|
* 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.
|
2004-04-12 21:40:49 +00:00
|
|
|
*
|
|
|
|
* 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.
|
2014-02-18 02:34:24 +01:00
|
|
|
*
|
2004-04-12 21:40:49 +00:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2008-01-05 12:45:14 +00:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2004-04-12 21:40:49 +00:00
|
|
|
* GNU General Public License for more details.
|
2014-02-18 02:34:24 +01:00
|
|
|
*
|
2004-04-12 21:40:49 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
2005-10-18 01:30:26 +00:00
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2004-04-12 21:40:49 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2004-05-01 06:35:06 +00:00
|
|
|
// Console module
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-08-02 16:20:35 +00:00
|
|
|
#include "saga/saga.h"
|
2004-12-03 19:15:44 +00:00
|
|
|
#include "saga/actor.h"
|
|
|
|
#include "saga/animation.h"
|
2014-07-20 18:49:57 +03:00
|
|
|
#include "saga/music.h"
|
2004-12-03 19:15:44 +00:00
|
|
|
#include "saga/scene.h"
|
|
|
|
#include "saga/script.h"
|
2014-07-20 18:49:57 +03:00
|
|
|
#include "saga/sndres.h"
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-08-02 16:20:35 +00:00
|
|
|
#include "saga/console.h"
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
namespace Saga {
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2006-09-16 16:58:27 +00:00
|
|
|
Console::Console(SagaEngine *vm) : GUI::Debugger() {
|
2004-12-03 19:15:44 +00:00
|
|
|
_vm = vm;
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("continue", WRAP_METHOD(Console, cmdExit));
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
// Actor commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("actor_walk_to", WRAP_METHOD(Console, cmdActorWalkTo));
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
// Animation commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("anim_info", WRAP_METHOD(Console, cmdAnimInfo));
|
|
|
|
registerCmd("cutaway_info", WRAP_METHOD(Console, cmdCutawayInfo));
|
|
|
|
registerCmd("play_cutaway", WRAP_METHOD(Console, cmdPlayCutaway));
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2014-07-20 18:49:57 +03:00
|
|
|
// Sound commands
|
|
|
|
registerCmd("play_music", WRAP_METHOD(Console, cmdPlayMusic));
|
|
|
|
registerCmd("play_sound", WRAP_METHOD(Console, cmdPlaySound));
|
|
|
|
registerCmd("play_voice", WRAP_METHOD(Console, cmdPlayVoice));
|
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
// Game stuff
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
#if 0
|
2008-01-07 08:44:19 +00:00
|
|
|
#define MAXPATH 512
|
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
// Register "g_language" cfg cvar
|
|
|
|
strncpy(GameModule.game_language, "us", MAXPATH);
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
CVAR_Register_S(GameModule.game_language, "g_language", NULL, CVAR_CFG, GAME_LANGSTR_LIMIT);
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
// Register "g_skipintro" cfg cvar
|
|
|
|
CVAR_Register_I(&GameModule.g_skipintro, "g_skipintro", NULL, CVAR_CFG, 0, 1);
|
|
|
|
#endif
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
// Scene commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("current_scene", WRAP_METHOD(Console, cmdCurrentScene));
|
|
|
|
registerCmd("current_chapter", WRAP_METHOD(Console, cmdCurrentChapter));
|
|
|
|
registerCmd("scene_change", WRAP_METHOD(Console, cmdSceneChange));
|
|
|
|
registerCmd("chapter_change", WRAP_METHOD(Console, cmdChapterChange));
|
2007-06-14 23:28:30 +00:00
|
|
|
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("action_map_info", WRAP_METHOD(Console, cmdActionMapInfo));
|
|
|
|
registerCmd("object_map_info", WRAP_METHOD(Console, cmdObjectMapInfo));
|
2007-06-14 23:28:30 +00:00
|
|
|
|
2009-04-10 22:33:29 +00:00
|
|
|
// Script commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("wake_up_threads", WRAP_METHOD(Console, cmdWakeUpThreads));
|
2009-04-10 22:33:29 +00:00
|
|
|
|
2007-06-14 23:28:30 +00:00
|
|
|
// Panel commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("current_panel_mode", WRAP_METHOD(Console, cmdCurrentPanelMode));
|
|
|
|
registerCmd("set_panel_mode", WRAP_METHOD(Console, cmdSetPanelMode));
|
2007-09-13 15:49:40 +00:00
|
|
|
|
2007-09-17 23:32:25 +00:00
|
|
|
// Font commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("set_font_mapping", WRAP_METHOD(Console, cmdSetFontMapping));
|
2007-09-17 23:32:25 +00:00
|
|
|
|
2007-09-13 15:49:40 +00:00
|
|
|
// Global flags commands
|
2014-05-27 02:04:08 +02:00
|
|
|
registerCmd("global_flags_info", WRAP_METHOD(Console, cmdGlobalFlagsInfo));
|
|
|
|
registerCmd("set_global_flag", WRAP_METHOD(Console, cmdSetGlobalFlag));
|
|
|
|
registerCmd("clear_global_flag", WRAP_METHOD(Console, cmdClearGlobalFlag));
|
2004-04-12 21:40:49 +00:00
|
|
|
}
|
|
|
|
|
2004-12-03 19:15:44 +00:00
|
|
|
Console::~Console() {
|
2004-04-12 21:40:49 +00:00
|
|
|
}
|
|
|
|
|
2005-01-08 20:30:07 +00:00
|
|
|
bool Console::cmdActorWalkTo(int argc, const char **argv) {
|
|
|
|
if (argc != 4)
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Actor id> <lx> <ly>\n", argv[0]);
|
2004-12-03 19:15:44 +00:00
|
|
|
else
|
2005-01-08 20:30:07 +00:00
|
|
|
_vm->_actor->cmdActorWalkTo(argc, argv);
|
2004-12-03 19:15:44 +00:00
|
|
|
return true;
|
2004-04-12 21:40:49 +00:00
|
|
|
}
|
|
|
|
|
2007-06-14 23:42:39 +00:00
|
|
|
bool Console::cmdAnimInfo(int argc, const char **argv) {
|
2004-12-03 19:15:44 +00:00
|
|
|
_vm->_anim->animInfo();
|
|
|
|
return true;
|
|
|
|
}
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2007-06-14 23:42:39 +00:00
|
|
|
bool Console::cmdCutawayInfo(int argc, const char **argv) {
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2007-06-14 23:28:30 +00:00
|
|
|
_vm->_anim->cutawayInfo();
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2007-06-14 23:28:30 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-06-14 23:42:39 +00:00
|
|
|
bool Console::cmdPlayCutaway(int argc, const char **argv) {
|
2009-01-02 16:52:38 +00:00
|
|
|
#ifdef ENABLE_IHNM
|
2007-06-14 23:42:39 +00:00
|
|
|
if (argc != 2)
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Cutaway number>\n", argv[0]);
|
2007-06-14 23:42:39 +00:00
|
|
|
else
|
|
|
|
_vm->_anim->playCutaway(atoi(argv[1]), false);
|
2009-01-02 16:52:38 +00:00
|
|
|
#endif
|
2007-06-14 23:42:39 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-07-20 18:49:57 +03:00
|
|
|
bool Console::cmdPlayMusic(int argc, const char **argv) {
|
|
|
|
if (argc != 2) {
|
|
|
|
debugPrintf("Usage: %s <Music number>\n", argv[0]);
|
|
|
|
} else {
|
|
|
|
if (_vm->getGameId() == GID_ITE)
|
|
|
|
_vm->_music->play(atoi(argv[1]) + 9);
|
|
|
|
else
|
|
|
|
_vm->_music->play(atoi(argv[1]));
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Console::cmdPlaySound(int argc, const char **argv) {
|
|
|
|
if (argc != 2)
|
|
|
|
debugPrintf("Usage: %s <Sound number>\n", argv[0]);
|
|
|
|
else
|
|
|
|
_vm->_sndRes->playSound(atoi(argv[1]), 255, false);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Console::cmdPlayVoice(int argc, const char **argv) {
|
|
|
|
if (argc < 2) {
|
|
|
|
debugPrintf("Usage: %s <Voice number> <Voice bank>\n", argv[0]);
|
|
|
|
} else {
|
|
|
|
int voiceBank = 0;
|
|
|
|
|
|
|
|
if (argc == 3) {
|
|
|
|
voiceBank = _vm->_sndRes->getVoiceBank();
|
|
|
|
_vm->_sndRes->setVoiceBank(atoi(argv[2]));
|
|
|
|
}
|
|
|
|
|
|
|
|
_vm->_sndRes->playVoice(atoi(argv[1]));
|
|
|
|
|
|
|
|
if (argc == 3)
|
|
|
|
_vm->_sndRes->setVoiceBank(voiceBank);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-06-14 23:28:30 +00:00
|
|
|
bool Console::cmdCurrentScene(int argc, const char **argv) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Current Scene is: %i, scene resource id: %i\n",
|
2007-06-14 23:28:30 +00:00
|
|
|
_vm->_scene->currentSceneNumber(), _vm->_scene->currentSceneResourceId());
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Console::cmdCurrentChapter(int argc, const char **argv) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Current Chapter is: %i\n", _vm->_scene->currentChapterNumber());
|
2007-06-14 23:28:30 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2004-12-24 20:44:39 +00:00
|
|
|
bool Console::cmdSceneChange(int argc, const char **argv) {
|
2004-12-03 19:15:44 +00:00
|
|
|
if (argc != 2)
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Scene number>\n", argv[0]);
|
2004-12-03 19:15:44 +00:00
|
|
|
else
|
2004-12-24 20:44:39 +00:00
|
|
|
_vm->_scene->cmdSceneChange(argc, argv);
|
2004-12-03 19:15:44 +00:00
|
|
|
return true;
|
|
|
|
}
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2007-06-14 23:28:30 +00:00
|
|
|
bool Console::cmdChapterChange(int argc, const char **argv) {
|
|
|
|
if (argc != 3)
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Chapter number> <Scene number>\n", argv[0]);
|
2007-06-14 23:28:30 +00:00
|
|
|
else {
|
|
|
|
_vm->_scene->setChapterNumber(atoi(argv[2]));
|
|
|
|
_vm->_scene->cmdSceneChange(argc, argv);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2004-12-24 20:44:39 +00:00
|
|
|
bool Console::cmdActionMapInfo(int argc, const char **argv) {
|
|
|
|
_vm->_scene->cmdActionMapInfo();
|
2004-12-03 19:15:44 +00:00
|
|
|
return true;
|
2004-04-12 21:40:49 +00:00
|
|
|
}
|
|
|
|
|
2004-12-24 20:44:39 +00:00
|
|
|
bool Console::cmdObjectMapInfo(int argc, const char **argv) {
|
|
|
|
_vm->_scene->cmdObjectMapInfo();
|
2004-12-03 19:15:44 +00:00
|
|
|
return true;
|
|
|
|
}
|
2004-04-12 21:40:49 +00:00
|
|
|
|
2009-04-10 22:33:29 +00:00
|
|
|
bool Console::cmdWakeUpThreads(int argc, const char **argv) {
|
|
|
|
if (argc != 2) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <wait type>\n", argv[0]);
|
|
|
|
debugPrintf("e.g.: 1 for kWaitTypeDelay, 2 for kWaitTypeSpeech, 10 for kWaitTypeWaitFrames");
|
|
|
|
debugPrintf("Refer to saga/script.h for additional types");
|
2009-04-10 22:33:29 +00:00
|
|
|
} else {
|
|
|
|
_vm->_script->wakeUpThreads(atoi(argv[1]));
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-06-14 23:28:30 +00:00
|
|
|
bool Console::cmdCurrentPanelMode(int argc, const char **argv) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Current Panel Mode is: %i\n", _vm->_interface->getMode());
|
2007-06-14 23:28:30 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Console::cmdSetPanelMode(int argc, const char **argv) {
|
|
|
|
if (argc != 2)
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Panel mode number>\n", argv[0]);
|
2007-06-14 23:28:30 +00:00
|
|
|
else
|
|
|
|
_vm->_interface->setMode(atoi(argv[1]));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-09-17 23:32:25 +00:00
|
|
|
bool Console::cmdSetFontMapping(int argc, const char **argv) {
|
|
|
|
if (argc != 2) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Sets font mapping\nUsage: %s <Font mapping flag>\n", argv[0]);
|
|
|
|
debugPrintf("Mapping flags:\n0 - default game behavior\n1 - force font mapping\n2 - ignore font mapping\n");
|
2007-09-17 23:32:25 +00:00
|
|
|
} else {
|
|
|
|
_vm->_font->setFontMapping(atoi(argv[1]));
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-09-13 15:49:40 +00:00
|
|
|
bool Console::cmdGlobalFlagsInfo(int argc, const char **argv) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Global flags status for IHNM:\n");
|
2007-09-13 15:49:40 +00:00
|
|
|
|
|
|
|
// Global flags in IHNM:
|
2007-09-19 02:10:44 +00:00
|
|
|
// 00: Tested when Gorrister's chapter ends. 0: Gorrister failed, 1: Gorrister won
|
|
|
|
// 01: Tested when Gorrister's chapter ends, when Gorrister fails (flag 0 is 0). 0: Gorrister died, 1: Gorrister failed
|
|
|
|
// 02: Unknown, set when Gorrister's chapter ends (perhaps it signifies that Gorrister's chapter is done)
|
2007-09-13 15:49:40 +00:00
|
|
|
// 03: Unknown
|
|
|
|
// 04: Unknown
|
|
|
|
// 05: Unknown
|
|
|
|
// 06: Unknown
|
|
|
|
// 07: Unknown
|
|
|
|
// 08: Unknown
|
|
|
|
// 09: Unknown
|
|
|
|
// 10: Unknown
|
|
|
|
// 11: Unknown
|
|
|
|
// 12: Unknown
|
|
|
|
// 13: Unknown
|
|
|
|
// 14: Unknown
|
|
|
|
// 15: Unknown
|
|
|
|
// 16: Used in the final chapter. If it's 0 when a character dies, the "bad" ending for that character is shown
|
|
|
|
// 17: Unknown
|
|
|
|
// 18: Unknown
|
2007-09-19 02:10:44 +00:00
|
|
|
// 19: Unknown, used after any chapter ends
|
2007-09-13 15:49:40 +00:00
|
|
|
// 20: Unknown
|
|
|
|
// 21: Unknown
|
|
|
|
// 22: Unknown
|
|
|
|
// 23: Unknown
|
|
|
|
// 24: Unknown
|
|
|
|
// 25: Unknown
|
|
|
|
// 26: Unknown
|
|
|
|
// 27: Unknown
|
|
|
|
// 28: Unknown
|
|
|
|
// 29: Unknown
|
|
|
|
// 30: Unknown
|
|
|
|
// 31: Unknown
|
|
|
|
|
|
|
|
int i = 0, k = 0, flagStatus = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < 32; i += 8) {
|
|
|
|
for (k = i; k < i + 8; k ++) {
|
|
|
|
flagStatus = _vm->_globalFlags & (1 << k) ? 1 : 0;
|
2014-05-27 02:04:07 +02:00
|
|
|
_vm->_console->debugPrintf("%02d: %u |", k, flagStatus);
|
2007-09-13 15:49:40 +00:00
|
|
|
}
|
2014-05-27 02:04:07 +02:00
|
|
|
_vm->_console->debugPrintf("\n");
|
2007-09-13 15:49:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Console::cmdSetGlobalFlag(int argc, const char **argv) {
|
|
|
|
if (argc != 2) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Global flag number>\nValid flag numbers are 0 - 31\n", argv[0]);
|
2007-09-13 15:49:40 +00:00
|
|
|
} else {
|
|
|
|
int flagNumber = atoi(argv[1]);
|
|
|
|
if (flagNumber >= 0 && flagNumber <= 31) {
|
|
|
|
_vm->_globalFlags |= (1 << flagNumber);
|
|
|
|
} else {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Valid flag numbers are 0 - 31\n");
|
2007-09-13 15:49:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Console::cmdClearGlobalFlag(int argc, const char **argv) {
|
|
|
|
if (argc != 2) {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Usage: %s <Global flag number>\nValid flag numbers are 0 - 31\n", argv[0]);
|
2007-09-13 15:49:40 +00:00
|
|
|
} else {
|
|
|
|
int flagNumber = atoi(argv[1]);
|
|
|
|
if (flagNumber >= 0 && flagNumber <= 31) {
|
|
|
|
_vm->_globalFlags &= ~(1 << flagNumber);
|
|
|
|
} else {
|
2014-05-27 02:04:07 +02:00
|
|
|
debugPrintf("Valid flag numbers are 0 - 31\n");
|
2007-09-13 15:49:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2004-04-12 21:40:49 +00:00
|
|
|
} // End of namespace Saga
|