aboutsummaryrefslogtreecommitdiff
path: root/engines/adl
diff options
context:
space:
mode:
authorWalter van Niftrik2016-04-01 21:54:09 +0200
committerWalter van Niftrik2016-06-06 20:35:49 +0200
commit1b9d712a8b68f75dcd7c22021b50fff1eeaec155 (patch)
tree6ce7ced83d16233fc43139fb6903c44010ad7776 /engines/adl
parentff4b9fcd9c50204cf31703d56ec55164f5646ba4 (diff)
downloadscummvm-rg350-1b9d712a8b68f75dcd7c22021b50fff1eeaec155.tar.gz
scummvm-rg350-1b9d712a8b68f75dcd7c22021b50fff1eeaec155.tar.bz2
scummvm-rg350-1b9d712a8b68f75dcd7c22021b50fff1eeaec155.zip
ADL: Add 'var' debug command
Diffstat (limited to 'engines/adl')
-rw-r--r--engines/adl/console.cpp35
-rw-r--r--engines/adl/console.h1
2 files changed, 31 insertions, 5 deletions
diff --git a/engines/adl/console.cpp b/engines/adl/console.cpp
index 94d0a73e84..c62d21c7ce 100644
--- a/engines/adl/console.cpp
+++ b/engines/adl/console.cpp
@@ -39,6 +39,7 @@ Console::Console(AdlEngine *engine) : GUI::Debugger() {
registerCmd("items", WRAP_METHOD(Console, Cmd_Items));
registerCmd("give_item", WRAP_METHOD(Console, Cmd_GiveItem));
registerCmd("vars", WRAP_METHOD(Console, Cmd_Vars));
+ registerCmd("var", WRAP_METHOD(Console, Cmd_Var));
}
Common::String Console::toAscii(const Common::String &str) {
@@ -162,10 +163,10 @@ bool Console::Cmd_Room(int argc, const char **argv) {
return true;
}
- int roomCount = _engine->_state.rooms.size();
- int room = strtoul(argv[1], NULL, 0);
+ uint roomCount = _engine->_state.rooms.size();
+ uint room = strtoul(argv[1], NULL, 0);
if (room < 1 || room > roomCount) {
- debugPrintf("Room %i out of valid range [1, %d]\n", room, roomCount);
+ debugPrintf("Room %u out of valid range [1, %u]\n", room, roomCount);
return true;
}
@@ -177,7 +178,7 @@ bool Console::Cmd_Room(int argc, const char **argv) {
_engine->_display->updateHiResScreen();
}
- debugPrintf("Current room: %d\n", _engine->_state.room);
+ debugPrintf("Current room: %u\n", _engine->_state.room);
return true;
}
@@ -205,7 +206,7 @@ bool Console::Cmd_GiveItem(int argc, const char **argv) {
Common::List<Item>::iterator item;
char *end;
- int id = strtoul(argv[1], &end, 0);
+ uint id = strtoul(argv[1], &end, 0);
if (*end != 0) {
Common::Array<Item *> matches;
@@ -268,6 +269,30 @@ bool Console::Cmd_Vars(int argc, const char **argv) {
return true;
}
+bool Console::Cmd_Var(int argc, const char **argv) {
+ if (argc < 2 || argc > 3) {
+ debugPrintf("Usage: %s <index> [<value>]\n", argv[0]);
+ return true;
+ }
+
+ uint varCount = _engine->_state.vars.size();
+ uint var = strtoul(argv[1], NULL, 0);
+
+ if (var >= varCount) {
+ debugPrintf("Variable %u out of valid range [0, %u]\n", var, varCount - 1);
+ return true;
+ }
+
+ if (argc == 3) {
+ uint value = strtoul(argv[2], NULL, 0);
+ _engine->_state.vars[var] = value;
+ }
+
+ debugPrintf("%3d: %3d\n", var, _engine->_state.vars[var]);
+
+ return true;
+}
+
void Console::printItem(const Item &item) {
Common::String name, desc, state;
diff --git a/engines/adl/console.h b/engines/adl/console.h
index 13f55fc036..a8c6adc1cc 100644
--- a/engines/adl/console.h
+++ b/engines/adl/console.h
@@ -52,6 +52,7 @@ private:
bool Cmd_Items(int argc, const char **argv);
bool Cmd_GiveItem(int argc, const char **argv);
bool Cmd_Vars(int argc, const char **argv);
+ bool Cmd_Var(int argc, const char **argv);
void printItem(const Item &item);
void printWordMap(const Common::HashMap<Common::String, uint> &wordMap);