aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/sci/console.cpp59
-rw-r--r--engines/sci/console.h1
-rw-r--r--engines/sci/engine/scriptdebug.cpp64
-rw-r--r--engines/sci/engine/scriptdebug.h2
-rw-r--r--engines/sci/sci.cpp3
5 files changed, 68 insertions, 61 deletions
diff --git a/engines/sci/console.cpp b/engines/sci/console.cpp
index 6c9be970cb..6efe6849bb 100644
--- a/engines/sci/console.cpp
+++ b/engines/sci/console.cpp
@@ -4745,65 +4745,6 @@ void Console::printBitmap(reg_t reg) {
#endif
-int Console::printObject(reg_t pos) {
- EngineState *s = _engine->_gamestate; // for the several defines in this function
- const Object *obj = s->_segMan->getObject(pos);
- const Object *var_container = obj;
- uint i;
-
- if (!obj) {
- debugPrintf("[%04x:%04x]: Not an object.\n", PRINT_REG(pos));
- return 1;
- }
-
- // Object header
- debugPrintf("[%04x:%04x] %s : %3d vars, %3d methods\n", PRINT_REG(pos), s->_segMan->getObjectName(pos),
- obj->getVarCount(), obj->getMethodCount());
-
- if (!obj->isClass())
- var_container = s->_segMan->getObject(obj->getSuperClassSelector());
- debugPrintf(" -- member variables:\n");
-
- if (getSciVersion() == SCI_VERSION_3) {
- debugPrintf(" (----) [---] -size- = 0000:%04x (%d)\n", obj->getVarCount(), obj->getVarCount());
- debugPrintf(" (----) [---] -classScript- = %04x:%04x (%d)\n", PRINT_REG(obj->getClassScriptSelector()), obj->getClassScriptSelector().getOffset());
- debugPrintf(" (----) [---] -species- = %04x:%04x (%s)\n", PRINT_REG(obj->getSpeciesSelector()), s->_segMan->getObjectName(obj->getSpeciesSelector()));
- debugPrintf(" (----) [---] -super- = %04x:%04x (%s)\n", PRINT_REG(obj->getSuperClassSelector()), s->_segMan->getObjectName(obj->getSuperClassSelector()));
- debugPrintf(" (----) [---] -info- = %04x:%04x (%d)\n", PRINT_REG(obj->getInfoSelector()), obj->getInfoSelector().getOffset());
- }
-
- for (i = 0; (uint)i < obj->getVarCount(); i++) {
- debugPrintf(" ");
- if (var_container && i < var_container->getVarCount()) {
- uint16 varSelector = var_container->getVarSelector(i);
- // Times two commented out for now for easy parsing of vocab.994
- debugPrintf("(%04x) [%03x] %s = ", i /* *2 */, varSelector, _engine->getKernel()->getSelectorName(varSelector).c_str());
- } else
- debugPrintf("p#%x = ", i);
-
- reg_t val = obj->getVariable(i);
- debugPrintf("%04x:%04x", PRINT_REG(val));
-
- if (!val.getSegment())
- debugPrintf(" (%d)", val.getOffset());
-
- const Object *ref = s->_segMan->getObject(val);
- if (ref)
- debugPrintf(" (%s)", s->_segMan->getObjectName(val));
-
- debugPrintf("\n");
- }
- debugPrintf(" -- methods:\n");
- for (i = 0; i < obj->getMethodCount(); i++) {
- reg_t fptr = obj->getFunction(i);
- debugPrintf(" [%03x] %s = %04x:%04x\n", obj->getFuncSelector(i), _engine->getKernel()->getSelectorName(obj->getFuncSelector(i)).c_str(), PRINT_REG(fptr));
- }
- if (s->_segMan->_heap[pos.getSegment()]->getType() == SEG_TYPE_SCRIPT)
- debugPrintf("\nOwner script: %d\n", s->_segMan->getScript(pos.getSegment())->getScriptNumber());
-
- return 0;
-}
-
static void printChar(byte c) {
if (c < 32 || c >= 127)
c = '.';
diff --git a/engines/sci/console.h b/engines/sci/console.h
index d0faf8a030..75243e52b3 100644
--- a/engines/sci/console.h
+++ b/engines/sci/console.h
@@ -45,7 +45,6 @@ public:
void printArray(reg_t reg);
void printBitmap(reg_t reg);
#endif
- int printObject(reg_t reg);
private:
virtual void preEnter();
diff --git a/engines/sci/engine/scriptdebug.cpp b/engines/sci/engine/scriptdebug.cpp
index c5a617a17a..ce1d2dd1f3 100644
--- a/engines/sci/engine/scriptdebug.cpp
+++ b/engines/sci/engine/scriptdebug.cpp
@@ -1005,6 +1005,70 @@ void logBacktrace() {
}
}
+bool printObject(reg_t pos) {
+ Console *con = g_sci->getSciDebugger();
+ EngineState *s = g_sci->getEngineState();
+ const Object *obj = s->_segMan->getObject(pos);
+ const Object *var_container = obj;
+ uint i;
+
+ if (!obj) {
+ con->debugPrintf("[%04x:%04x]: Not an object.\n", PRINT_REG(pos));
+ return false;
+ }
+
+ // Object header
+ con->debugPrintf("[%04x:%04x] %s : %3d vars, %3d methods\n", PRINT_REG(pos), s->_segMan->getObjectName(pos),
+ obj->getVarCount(), obj->getMethodCount());
+
+ if (!obj->isClass())
+ var_container = s->_segMan->getObject(obj->getSuperClassSelector());
+ con->debugPrintf(" -- member variables:\n");
+
+ if (getSciVersion() == SCI_VERSION_3) {
+ con->debugPrintf(" (----) [---] -size- = 0000:%04x (%d)\n", obj->getVarCount(), obj->getVarCount());
+ con->debugPrintf(" (----) [---] -classScript- = %04x:%04x (%d)\n", PRINT_REG(obj->getClassScriptSelector()), obj->getClassScriptSelector().getOffset());
+ con->debugPrintf(" (----) [---] -species- = %04x:%04x (%s)\n", PRINT_REG(obj->getSpeciesSelector()), s->_segMan->getObjectName(obj->getSpeciesSelector()));
+ con->debugPrintf(" (----) [---] -super- = %04x:%04x (%s)\n", PRINT_REG(obj->getSuperClassSelector()), s->_segMan->getObjectName(obj->getSuperClassSelector()));
+ con->debugPrintf(" (----) [---] -info- = %04x:%04x (%d)\n", PRINT_REG(obj->getInfoSelector()), obj->getInfoSelector().getOffset());
+ }
+
+ for (i = 0; (uint)i < obj->getVarCount(); i++) {
+ con->debugPrintf(" ");
+ if (var_container && i < var_container->getVarCount()) {
+ uint16 varSelector = var_container->getVarSelector(i);
+ // Times two commented out for now for easy parsing of vocab.994
+ con->debugPrintf("(%04x) [%03x] %s = ", i /* *2 */, varSelector, g_sci->getKernel()->getSelectorName(varSelector).c_str());
+ } else
+ con->debugPrintf("p#%x = ", i);
+
+ reg_t val = obj->getVariable(i);
+ con->debugPrintf("%04x:%04x", PRINT_REG(val));
+
+ if (!val.getSegment())
+ con->debugPrintf(" (%d)", val.getOffset());
+
+ const Object *ref = s->_segMan->getObject(val);
+ if (ref)
+ con->debugPrintf(" (%s)", s->_segMan->getObjectName(val));
+
+ con->debugPrintf("\n");
+ }
+ con->debugPrintf(" -- methods:\n");
+ for (i = 0; i < obj->getMethodCount(); i++) {
+ reg_t fptr = obj->getFunction(i);
+ con->debugPrintf(" [%03x] %s = %04x:%04x\n", obj->getFuncSelector(i), g_sci->getKernel()->getSelectorName(obj->getFuncSelector(i)).c_str(), PRINT_REG(fptr));
+ }
+
+ Script *scr = s->_segMan->getScriptIfLoaded(pos.getSegment());
+ if (scr)
+ con->debugPrintf("\nOwner script: %d\n", scr->getScriptNumber());
+
+ return true;
+}
+
+
+
diff --git a/engines/sci/engine/scriptdebug.h b/engines/sci/engine/scriptdebug.h
index 1d8a2ef6bb..f8930998e2 100644
--- a/engines/sci/engine/scriptdebug.h
+++ b/engines/sci/engine/scriptdebug.h
@@ -37,6 +37,8 @@ void logKernelCall(const KernelFunction *kernelCall, const KernelSubFunction *ke
void logBacktrace();
+bool printObject(reg_t obj);
+
}
#endif
diff --git a/engines/sci/sci.cpp b/engines/sci/sci.cpp
index 2226cdd63c..c7b9bc7995 100644
--- a/engines/sci/sci.cpp
+++ b/engines/sci/sci.cpp
@@ -42,6 +42,7 @@
#include "sci/engine/script.h" // for script_adjust_opcode_formats
#include "sci/engine/script_patches.h"
#include "sci/engine/selector.h" // for SELECTOR
+#include "sci/engine/scriptdebug.h"
#include "sci/sound/audio.h"
#include "sci/sound/music.h"
@@ -637,7 +638,7 @@ void SciEngine::initStackBaseWithSelector(Selector selector) {
// Register the first element on the execution stack
if (!send_selector(_gamestate, _gameObjectAddress, _gameObjectAddress, _gamestate->stack_base, 2, _gamestate->stack_base)) {
- _console->printObject(_gameObjectAddress);
+ printObject(_gameObjectAddress);
error("initStackBaseWithSelector: error while registering the first selector in the call stack");
}