aboutsummaryrefslogtreecommitdiff
path: root/engines/director/lingo
diff options
context:
space:
mode:
authorEugene Sandulenko2016-09-02 09:35:53 +0200
committerEugene Sandulenko2016-09-02 09:51:12 +0200
commitbb2168fe9cc195ec51c2566ce537f2d1c83af17d (patch)
treecc46b3ea218c0f94ede8c92495dd7ccb8962cf56 /engines/director/lingo
parent18af5ea5da5b37375dec1efa51e42e81115dc99a (diff)
downloadscummvm-rg350-bb2168fe9cc195ec51c2566ce537f2d1c83af17d.tar.gz
scummvm-rg350-bb2168fe9cc195ec51c2566ce537f2d1c83af17d.tar.bz2
scummvm-rg350-bb2168fe9cc195ec51c2566ce537f2d1c83af17d.zip
DIRECTOR: Lingo: Fixed c_whencode and added debug output
Diffstat (limited to 'engines/director/lingo')
-rw-r--r--engines/director/lingo/lingo-code.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/engines/director/lingo/lingo-code.cpp b/engines/director/lingo/lingo-code.cpp
index 91ab21fd6f..405489ba44 100644
--- a/engines/director/lingo/lingo-code.cpp
+++ b/engines/director/lingo/lingo-code.cpp
@@ -758,12 +758,20 @@ void Lingo::c_whencode() {
int end = READ_UINT32(&(*g_lingo->_currentScript)[start]);
Common::String eventname((char *)&(*g_lingo->_currentScript)[start + 1]);
- start += g_lingo->calcStringAlignment(eventname.c_str());
+ start += g_lingo->calcStringAlignment(eventname.c_str()) + 1;
debugC(3, kDebugLingoExec, "c_whencode([%5d][%5d], %s)", start, end, eventname.c_str());
g_lingo->define(eventname, start, 0, NULL, end);
+ if (debugChannelSet(3, kDebugLingoExec)) {
+ int pc = start;
+ while (pc <= end) {
+ Common::String instr = g_lingo->decodeInstruction(pc, &pc);
+ debugC(3, kDebugLingoExec, "[%5d] %s", pc, instr.c_str());
+ }
+ }
+
g_lingo->_pc = end;
}