diff options
author | Eugene Sandulenko | 2016-09-02 09:35:53 +0200 |
---|---|---|
committer | Eugene Sandulenko | 2016-09-02 09:51:12 +0200 |
commit | bb2168fe9cc195ec51c2566ce537f2d1c83af17d (patch) | |
tree | cc46b3ea218c0f94ede8c92495dd7ccb8962cf56 /engines/director/lingo | |
parent | 18af5ea5da5b37375dec1efa51e42e81115dc99a (diff) | |
download | scummvm-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.cpp | 10 |
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; } |