From 6dd09b8935495d211c51a45652fc59b4da1b0442 Mon Sep 17 00:00:00 2001 From: Willem Jan Palenstijn Date: Wed, 14 Dec 2011 17:19:14 +0100 Subject: DREAMWEB: Convert checkForExit --- engines/dreamweb/dreambase.h | 2 + engines/dreamweb/dreamgen.cpp | 371 ++++++++++------------------------- engines/dreamweb/dreamgen.h | 442 +++++++++++++++++++++--------------------- engines/dreamweb/sprite.cpp | 61 +++++- engines/dreamweb/stubs.cpp | 3 +- engines/dreamweb/stubs.h | 4 +- 6 files changed, 388 insertions(+), 495 deletions(-) (limited to 'engines') diff --git a/engines/dreamweb/dreambase.h b/engines/dreamweb/dreambase.h index 20cafcb203..7c86696568 100644 --- a/engines/dreamweb/dreambase.h +++ b/engines/dreamweb/dreambase.h @@ -263,6 +263,7 @@ public: void clearReels(); void getRidOfReels(); void liftNoise(uint8 index); + void checkForExit(Sprite *sprite); // from stubs.cpp bool isCD(); @@ -388,6 +389,7 @@ public: void dumpTimedText(); void getTime(); void doChange(uint8 index, uint8 value, uint8 type); + bool isRyanHolding(const char *id); // from use.cpp void placeFreeObject(uint8 index); diff --git a/engines/dreamweb/dreamgen.cpp b/engines/dreamweb/dreamgen.cpp index ff91eb678f..ea4d8e5b05 100644 --- a/engines/dreamweb/dreamgen.cpp +++ b/engines/dreamweb/dreamgen.cpp @@ -26,165 +26,6 @@ namespace DreamGen { -void DreamGenContext::checkForExit() { - STACK_CHECK; - cl = data.byte(kRyanx); - _add(cl, 12); - ch = data.byte(kRyany); - _add(ch, 12); - checkOne(); - data.byte(kLastflag) = cl; - data.byte(kLastflagex) = ch; - data.byte(kFlagx) = dl; - data.byte(kFlagy) = dh; - al = data.byte(kLastflag); - _test(al, 64); - if (flags.z()) - goto notnewdirect; - al = data.byte(kLastflagex); - data.byte(kAutolocation) = al; - return; -notnewdirect: - _test(al, 32); - if (flags.z()) - goto notleave; - push(es); - push(bx); - _cmp(data.byte(kReallocation), 2); - if (!flags.z()) - goto notlouis; - bl = 0; - push(bx); - al = 'W'; - ah = 'E'; - cl = 'T'; - ch = 'A'; - isRyanHolding(); - bx = pop(); - if (flags.z()) - goto noshoe1; - _inc(bl); -noshoe1: - push(bx); - al = 'W'; - ah = 'E'; - cl = 'T'; - ch = 'B'; - isRyanHolding(); - bx = pop(); - if (flags.z()) - goto noshoe2; - _inc(bl); -noshoe2: - _cmp(bl, 2); - if (flags.z()) - goto notlouis; - al = 42; - _cmp(bl, 0); - if (flags.z()) - goto notravmessage; - _inc(al); -notravmessage: - cx = 80; - dx = 10; - bl = 68; - bh = 64; - setupTimedUse(); - al = data.byte(kFacing); - _add(al, 4); - _and(al, 7); - data.byte(kTurntoface) = al; - bx = pop(); - es = pop(); - return; -notlouis: - bx = pop(); - es = pop(); - data.byte(kNeedtotravel) = 1; - return; -notleave: - _test(al, 4); - if (flags.z()) - goto notaleft; - adjustLeft(); - return; -notaleft: - _test(al, 2); - if (flags.z()) - goto notaright; - adjustRight(); - return; -notaright: - _test(al, 8); - if (flags.z()) - goto notadown; - adjustDown(); - return; -notadown: - _test(al, 16); - if (flags.z()) - return /* (notanup) */; - adjustUp(); -} - -void DreamGenContext::adjustDown() { - STACK_CHECK; - push(es); - push(bx); - _add(data.byte(kMapy), 10); - al = data.byte(kLastflagex); - cl = 16; - _mul(cl); - es.byte(bx+11) = al; - data.byte(kNowinnewroom) = 1; - bx = pop(); - es = pop(); -} - -void DreamGenContext::adjustUp() { - STACK_CHECK; - push(es); - push(bx); - _sub(data.byte(kMapy), 10); - al = data.byte(kLastflagex); - cl = 16; - _mul(cl); - es.byte(bx+11) = al; - data.byte(kNowinnewroom) = 1; - bx = pop(); - es = pop(); -} - -void DreamGenContext::adjustLeft() { - STACK_CHECK; - push(es); - push(bx); - data.byte(kLastflag) = 0; - _sub(data.byte(kMapx), 11); - al = data.byte(kLastflagex); - cl = 16; - _mul(cl); - es.byte(bx+10) = al; - data.byte(kNowinnewroom) = 1; - bx = pop(); - es = pop(); -} - -void DreamGenContext::adjustRight() { - STACK_CHECK; - push(es); - push(bx); - _add(data.byte(kMapx), 11); - al = data.byte(kLastflagex); - cl = 16; - _mul(cl); - _sub(al, 2); - es.byte(bx+10) = al; - data.byte(kNowinnewroom) = 1; - bx = pop(); - es = pop(); -} - void DreamGenContext::reminders() { STACK_CHECK; _cmp(data.byte(kReallocation), 24); @@ -2140,14 +1981,14 @@ void DreamGenContext::getDestInfo() { push(ax); dx = data; es = dx; - si = 1123; + si = 1120; _add(si, ax); cl = es.byte(si); ax = pop(); push(cx); dx = data; es = dx; - si = 1139; + si = 1136; _add(si, ax); ax = pop(); } @@ -2199,7 +2040,7 @@ clearedlocations: bx = ax; dx = data; es = dx; - _add(bx, 1123); + _add(bx, 1120); es.byte(bx) = 0; } @@ -2238,7 +2079,7 @@ dirroot: si = offset_rootdir; _inc(si); es = cs; - di = 1048; + di = 1045; _inc(di); cx = 12; _movsb(cx, true); @@ -2340,7 +2181,7 @@ notyetassigned: push(bx); _add(bx, 2); ds = cs; - si = 1157; + si = 1154; checkpass: _lodsw(); ah = es.byte(bx); @@ -2411,7 +2252,7 @@ void DreamGenContext::read() { return; okcom: es = cs; - di = 1048; + di = 1045; ax = data.word(kTextfile1); data.word(kMonsource) = ax; ds = ax; @@ -2541,7 +2382,7 @@ keyok2: ds = cs; si = offset_operand1+1; es = cs; - di = 1048+1; + di = 1045+1; cx = 12; _movsb(cx, true); monitorLogo(); @@ -2668,7 +2509,7 @@ void DreamGenContext::parser() { al = '='; _stosb(); ds = cs; - si = 1157; + si = 1154; notspace1: _lodsw(); _cmp(al, 32); @@ -2755,7 +2596,7 @@ gotkeyp: void DreamGenContext::clearBuffers() { STACK_CHECK; es = data.word(kBuffers); - cx = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+901-444+68-0)/2; + cx = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+898-441+68-0)/2; ax = 0; di = 0; _stosw(cx, true); @@ -2767,11 +2608,11 @@ void DreamGenContext::clearBuffers() { es = data.word(kBuffers); di = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)); ds = cs; - si = 444; - cx = (901-444); + si = 441; + cx = (898-441); _movsb(cx, true); es = data.word(kBuffers); - di = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+901-444); + di = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+898-441); ds = cs; si = 0; cx = (68-0); @@ -2789,11 +2630,11 @@ void DreamGenContext::clearChanges() { ds = data.word(kBuffers); si = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)); es = cs; - di = 444; - cx = (901-444); + di = 441; + cx = (898-441); _movsb(cx, true); ds = data.word(kBuffers); - si = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+901-444); + si = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+898-441); es = cs; di = 0; cx = (68-0); @@ -2807,7 +2648,7 @@ void DreamGenContext::clearChanges() { di = 0; _stosw(cx, true); es = cs; - di = 1123; + di = 1120; al = 1; _stosb(2); al = 0; @@ -2930,14 +2771,14 @@ void DreamGenContext::__start() { //0x0090: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x00a0: .... .... .... .... - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x00b0: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x00c0: .... .... .... .... + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x20, 0x00, + //0x00d0: .... .... .... . . 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - //0x00d0: .... .... .... .... - 0x20, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - //0x00e0: .. .... .... .... + //0x00e0: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x00f0: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, @@ -2954,105 +2795,105 @@ void DreamGenContext::__start() { //0x0150: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x0160: .... .... .... .... - 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, + 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, //0x0170: .... .... .... .... 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, //0x0180: .... .... .... .... - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x17, 0x00, + 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x17, 0x00, 0x00, 0x00, 0x00, //0x0190: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x01a0: .... .... .... .... - 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0x00, 0x01, 0x2c, 0x00, 0x14, - //0x01b0: .... .... .... .,.. - 0x00, 0x02, 0x00, 0x01, 0x01, 0x37, 0x00, 0x00, 0x00, 0x32, 0x14, 0x00, 0x18, 0x16, 0x00, 0x4a, - //0x01c0: .... .7.. .2.. ...J - 0x00, 0x01, 0x00, 0x00, 0x18, 0x21, 0x0a, 0x4b, 0x00, 0x01, 0x00, 0x01, 0x01, 0x2c, 0x00, 0x1b, - //0x01d0: .... .!.K .... .,.. - 0x00, 0x02, 0x00, 0x02, 0x01, 0x2c, 0x00, 0x60, 0x00, 0x03, 0x00, 0x04, 0x01, 0x2c, 0x00, 0x76, - //0x01e0: .... .,.` .... .,.v - 0x00, 0x02, 0x00, 0x05, 0x01, 0x2c, 0x0a, 0x00, 0x00, 0x02, 0x00, 0x00, 0x05, 0x16, 0x14, 0x35, - //0x01f0: .... .,.. .... ...5 - 0x00, 0x03, 0x00, 0x00, 0x05, 0x16, 0x14, 0x28, 0x00, 0x01, 0x00, 0x02, 0x05, 0x16, 0x14, 0x32, - //0x0200: .... ...( .... ...2 - 0x00, 0x01, 0x00, 0x03, 0x02, 0x0b, 0x0a, 0xc0, 0x00, 0x01, 0x00, 0x00, 0x02, 0x0b, 0x0a, 0xb6, + 0x00, 0x00, 0xff, 0x00, 0x00, 0x00, 0x00, 0xff, 0x00, 0x01, 0x2c, 0x00, 0x14, 0x00, 0x02, 0x00, + //0x01b0: .... .... ..,. .... + 0x01, 0x01, 0x37, 0x00, 0x00, 0x00, 0x32, 0x14, 0x00, 0x18, 0x16, 0x00, 0x4a, 0x00, 0x01, 0x00, + //0x01c0: ..7. ..2. .... J... + 0x00, 0x18, 0x21, 0x0a, 0x4b, 0x00, 0x01, 0x00, 0x01, 0x01, 0x2c, 0x00, 0x1b, 0x00, 0x02, 0x00, + //0x01d0: ..!. K... ..,. .... + 0x02, 0x01, 0x2c, 0x00, 0x60, 0x00, 0x03, 0x00, 0x04, 0x01, 0x2c, 0x00, 0x76, 0x00, 0x02, 0x00, + //0x01e0: ..,. `... ..,. v... + 0x05, 0x01, 0x2c, 0x0a, 0x00, 0x00, 0x02, 0x00, 0x00, 0x05, 0x16, 0x14, 0x35, 0x00, 0x03, 0x00, + //0x01f0: ..,. .... .... 5... + 0x00, 0x05, 0x16, 0x14, 0x28, 0x00, 0x01, 0x00, 0x02, 0x05, 0x16, 0x14, 0x32, 0x00, 0x01, 0x00, + //0x0200: .... (... .... 2... + 0x03, 0x02, 0x0b, 0x0a, 0xc0, 0x00, 0x01, 0x00, 0x00, 0x02, 0x0b, 0x0a, 0xb6, 0x00, 0x02, 0x00, //0x0210: .... .... .... .... - 0x00, 0x02, 0x00, 0x01, 0x08, 0x0b, 0x0a, 0x00, 0x00, 0x02, 0x00, 0x01, 0x17, 0x00, 0x32, 0x00, - //0x0220: .... .... .... ..2. - 0x00, 0x03, 0x00, 0x00, 0x1c, 0x0b, 0x14, 0xfa, 0x00, 0x04, 0x00, 0x00, 0x17, 0x00, 0x32, 0x2b, - //0x0230: .... .... .... ..2+ - 0x00, 0x02, 0x00, 0x08, 0x17, 0x0b, 0x28, 0x82, 0x00, 0x02, 0x00, 0x01, 0x17, 0x16, 0x28, 0x7a, - //0x0240: .... ..(. .... ..(z - 0x00, 0x02, 0x00, 0x02, 0x17, 0x16, 0x28, 0x69, 0x00, 0x02, 0x00, 0x03, 0x17, 0x16, 0x28, 0x51, - //0x0250: .... ..(i .... ..(Q - 0x00, 0x02, 0x00, 0x04, 0x17, 0x0b, 0x28, 0x87, 0x00, 0x02, 0x00, 0x05, 0x17, 0x16, 0x28, 0x91, - //0x0260: .... ..(. .... ..(. - 0x00, 0x02, 0x00, 0x06, 0x04, 0x16, 0x1e, 0x00, 0x00, 0x02, 0x00, 0x00, 0x2d, 0x16, 0x1e, 0xc8, - //0x0270: .... .... .... -... - 0x00, 0x00, 0x00, 0x14, 0x2d, 0x16, 0x1e, 0x27, 0x00, 0x02, 0x00, 0x00, 0x2d, 0x16, 0x1e, 0x19, - //0x0280: .... -..' .... -... - 0x00, 0x02, 0x00, 0x00, 0x08, 0x16, 0x28, 0x20, 0x00, 0x02, 0x00, 0x00, 0x07, 0x0b, 0x14, 0x40, - //0x0290: .... ..( .... ...@ - 0x00, 0x02, 0x00, 0x00, 0x16, 0x16, 0x14, 0x52, 0x00, 0x02, 0x00, 0x00, 0x1b, 0x0b, 0x1e, 0x00, - //0x02a0: .... ...R .... .... - 0x00, 0x02, 0x00, 0x00, 0x14, 0x00, 0x1e, 0x00, 0x00, 0x02, 0x00, 0x00, 0x0e, 0x21, 0x28, 0x15, - //0x02b0: .... .... .... .!(. - 0x00, 0x01, 0x00, 0x00, 0x1d, 0x0b, 0x0a, 0x00, 0x00, 0x01, 0x00, 0x00, 0x02, 0x16, 0x00, 0x02, + 0x01, 0x08, 0x0b, 0x0a, 0x00, 0x00, 0x02, 0x00, 0x01, 0x17, 0x00, 0x32, 0x00, 0x00, 0x03, 0x00, + //0x0220: .... .... ...2 .... + 0x00, 0x1c, 0x0b, 0x14, 0xfa, 0x00, 0x04, 0x00, 0x00, 0x17, 0x00, 0x32, 0x2b, 0x00, 0x02, 0x00, + //0x0230: .... .... ...2 +... + 0x08, 0x17, 0x0b, 0x28, 0x82, 0x00, 0x02, 0x00, 0x01, 0x17, 0x16, 0x28, 0x7a, 0x00, 0x02, 0x00, + //0x0240: ...( .... ...( z... + 0x02, 0x17, 0x16, 0x28, 0x69, 0x00, 0x02, 0x00, 0x03, 0x17, 0x16, 0x28, 0x51, 0x00, 0x02, 0x00, + //0x0250: ...( i... ...( Q... + 0x04, 0x17, 0x0b, 0x28, 0x87, 0x00, 0x02, 0x00, 0x05, 0x17, 0x16, 0x28, 0x91, 0x00, 0x02, 0x00, + //0x0260: ...( .... ...( .... + 0x06, 0x04, 0x16, 0x1e, 0x00, 0x00, 0x02, 0x00, 0x00, 0x2d, 0x16, 0x1e, 0xc8, 0x00, 0x00, 0x00, + //0x0270: .... .... .-.. .... + 0x14, 0x2d, 0x16, 0x1e, 0x27, 0x00, 0x02, 0x00, 0x00, 0x2d, 0x16, 0x1e, 0x19, 0x00, 0x02, 0x00, + //0x0280: .-.. '... .-.. .... + 0x00, 0x08, 0x16, 0x28, 0x20, 0x00, 0x02, 0x00, 0x00, 0x07, 0x0b, 0x14, 0x40, 0x00, 0x02, 0x00, + //0x0290: ...( ... .... @... + 0x00, 0x16, 0x16, 0x14, 0x52, 0x00, 0x02, 0x00, 0x00, 0x1b, 0x0b, 0x1e, 0x00, 0x00, 0x02, 0x00, + //0x02a0: .... R... .... .... + 0x00, 0x14, 0x00, 0x1e, 0x00, 0x00, 0x02, 0x00, 0x00, 0x0e, 0x21, 0x28, 0x15, 0x00, 0x01, 0x00, + //0x02b0: .... .... ..!( .... + 0x00, 0x1d, 0x0b, 0x0a, 0x00, 0x00, 0x01, 0x00, 0x00, 0x02, 0x16, 0x00, 0x02, 0x00, 0x02, 0x00, //0x02c0: .... .... .... .... - 0x00, 0x02, 0x00, 0x00, 0x19, 0x00, 0x32, 0x04, 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x1e, 0x79, - //0x02d0: .... ..2. .... 2..y - 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x1e, 0x00, 0x00, 0x14, 0x00, 0x00, 0x34, 0x16, 0x1e, 0xc0, - //0x02e0: .... 2... .... 4... - 0x00, 0x02, 0x00, 0x00, 0x34, 0x16, 0x1e, 0xe9, 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x28, 0x68, - //0x02f0: .... 4... .... 2.(h - 0x00, 0x37, 0x00, 0x00, 0x35, 0x21, 0x00, 0x63, 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x28, 0x00, - //0x0300: .7.. 5!.c .... 2.(. - 0x00, 0x03, 0x00, 0x00, 0x32, 0x16, 0x1e, 0xa2, 0x00, 0x02, 0x00, 0x00, 0x34, 0x16, 0x1e, 0x39, - //0x0310: .... 2... .... 4..9 - 0x00, 0x02, 0x00, 0x00, 0x34, 0x16, 0x1e, 0x00, 0x00, 0x02, 0x00, 0x00, 0x36, 0x00, 0x00, 0x48, - //0x0320: .... 4... .... 6..H - 0x00, 0x03, 0x00, 0x00, 0x37, 0x2c, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x13, 0x00, 0x00, 0x00, - //0x0330: .... 7,.. .... .... - 0x00, 0x1c, 0x00, 0x00, 0x0e, 0x16, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00, 0x0e, 0x16, 0x00, 0x2c, - //0x0340: .... .... .... ..., - 0x01, 0x01, 0x00, 0x00, 0x0a, 0x16, 0x1e, 0xae, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x16, 0x14, 0x00, + 0x00, 0x19, 0x00, 0x32, 0x04, 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x1e, 0x79, 0x00, 0x02, 0x00, + //0x02d0: ...2 .... .2.. y... + 0x00, 0x32, 0x16, 0x1e, 0x00, 0x00, 0x14, 0x00, 0x00, 0x34, 0x16, 0x1e, 0xc0, 0x00, 0x02, 0x00, + //0x02e0: .2.. .... .4.. .... + 0x00, 0x34, 0x16, 0x1e, 0xe9, 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x28, 0x68, 0x00, 0x37, 0x00, + //0x02f0: .4.. .... .2.( h.7. + 0x00, 0x35, 0x21, 0x00, 0x63, 0x00, 0x02, 0x00, 0x00, 0x32, 0x16, 0x28, 0x00, 0x00, 0x03, 0x00, + //0x0300: .5!. c... .2.( .... + 0x00, 0x32, 0x16, 0x1e, 0xa2, 0x00, 0x02, 0x00, 0x00, 0x34, 0x16, 0x1e, 0x39, 0x00, 0x02, 0x00, + //0x0310: .2.. .... .4.. 9... + 0x00, 0x34, 0x16, 0x1e, 0x00, 0x00, 0x02, 0x00, 0x00, 0x36, 0x00, 0x00, 0x48, 0x00, 0x03, 0x00, + //0x0320: .4.. .... .6.. H... + 0x00, 0x37, 0x2c, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x13, 0x00, 0x00, 0x00, 0x00, 0x1c, 0x00, + //0x0330: .7,. .... .... .... + 0x00, 0x0e, 0x16, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00, 0x0e, 0x16, 0x00, 0x2c, 0x01, 0x01, 0x00, + //0x0340: .... .... .... ,... + 0x00, 0x0a, 0x16, 0x1e, 0xae, 0x00, 0x00, 0x00, 0x00, 0x0c, 0x16, 0x14, 0x00, 0x00, 0x01, 0x00, //0x0350: .... .... .... .... - 0x00, 0x01, 0x00, 0x00, 0x0b, 0x0b, 0x14, 0x00, 0x00, 0x32, 0x14, 0x00, 0x0b, 0x0b, 0x1e, 0x00, - //0x0360: .... .... .2.. .... - 0x00, 0x32, 0x14, 0x00, 0x0b, 0x16, 0x14, 0x00, 0x00, 0x32, 0x14, 0x00, 0x0e, 0x21, 0x28, 0x00, - //0x0370: .2.. .... .2.. .!(. - 0x00, 0x32, 0x14, 0x00, 0xff, 0x44, 0x52, 0x45, 0x41, 0x4d, 0x57, 0x45, 0x42, 0x2e, 0x56, 0x39, - //0x0380: .2.. .DRE AMWE B.V9 - 0x39, 0x00, 0x01, 0x00, 0x50, 0x55, 0x42, 0x4c, 0x49, 0x43, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - //0x0390: 9... PUBL IC - 0x50, 0x55, 0x42, 0x4c, 0x49, 0x43, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x00, 0x00, 0x42, 0x4c, - //0x03a0: PUBL IC . ..BL - 0x41, 0x43, 0x4b, 0x44, 0x52, 0x41, 0x47, 0x4f, 0x4e, 0x20, 0x52, 0x59, 0x41, 0x4e, 0x20, 0x20, - //0x03b0: ACKD RAGO N RY AN - 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x00, 0x00, 0x48, 0x45, 0x4e, 0x44, 0x52, 0x49, 0x58, 0x20, - //0x03c0: ... HEND RIX - 0x20, 0x20, 0x20, 0x20, 0x4c, 0x4f, 0x55, 0x49, 0x53, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, - //0x03d0: LOUI S . - 0x00, 0x00, 0x53, 0x45, 0x50, 0x54, 0x49, 0x4d, 0x55, 0x53, 0x20, 0x20, 0x20, 0x20, 0x42, 0x45, - //0x03e0: ..SE PTIM US BE - 0x43, 0x4b, 0x45, 0x54, 0x54, 0x20, 0x20, 0x20, 0x20, 0x00, 0xff, 0xff, 0x20, 0x20, 0x20, 0x20, - //0x03f0: CKET T ... - 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x22, 0x52, 0x4f, 0x4f, 0x54, 0x20, - //0x0400: ."R OOT - 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x22, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, - //0x0410: . " - 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x0d, 0x0a, 0x0d, 0x0a, 0x24, 0x10, 0x12, 0x12, 0x11, 0x10, - //0x0420: ... ..$. .... - 0x10, 0x10, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x02, 0x02, 0x02, 0x02, + 0x00, 0x0b, 0x0b, 0x14, 0x00, 0x00, 0x32, 0x14, 0x00, 0x0b, 0x0b, 0x1e, 0x00, 0x00, 0x32, 0x14, + //0x0360: .... ..2. .... ..2. + 0x00, 0x0b, 0x16, 0x14, 0x00, 0x00, 0x32, 0x14, 0x00, 0x0e, 0x21, 0x28, 0x00, 0x00, 0x32, 0x14, + //0x0370: .... ..2. ..!( ..2. + 0x00, 0xff, 0x44, 0x52, 0x45, 0x41, 0x4d, 0x57, 0x45, 0x42, 0x2e, 0x56, 0x39, 0x39, 0x00, 0x01, + //0x0380: ..DR EAMW EB.V 99.. + 0x00, 0x50, 0x55, 0x42, 0x4c, 0x49, 0x43, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x50, 0x55, 0x42, + //0x0390: .PUB LIC PUB + 0x4c, 0x49, 0x43, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x00, 0x00, 0x42, 0x4c, 0x41, 0x43, 0x4b, + //0x03a0: LIC ...B LACK + 0x44, 0x52, 0x41, 0x47, 0x4f, 0x4e, 0x20, 0x52, 0x59, 0x41, 0x4e, 0x20, 0x20, 0x20, 0x20, 0x20, + //0x03b0: DRAG ON R YAN + 0x20, 0x20, 0x00, 0x00, 0x00, 0x48, 0x45, 0x4e, 0x44, 0x52, 0x49, 0x58, 0x20, 0x20, 0x20, 0x20, + //0x03c0: .. .HEN DRIX + 0x20, 0x4c, 0x4f, 0x55, 0x49, 0x53, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x00, 0x00, 0x53, + //0x03d0: LOU IS ...S + 0x45, 0x50, 0x54, 0x49, 0x4d, 0x55, 0x53, 0x20, 0x20, 0x20, 0x20, 0x42, 0x45, 0x43, 0x4b, 0x45, + //0x03e0: EPTI MUS B ECKE + 0x54, 0x54, 0x20, 0x20, 0x20, 0x20, 0x00, 0xff, 0xff, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + //0x03f0: TT .. . + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00, 0x22, 0x52, 0x4f, 0x4f, 0x54, 0x20, 0x20, 0x20, 0x20, + //0x0400: ." ROOT + 0x20, 0x20, 0x20, 0x20, 0x00, 0x22, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + //0x0410: ." + 0x20, 0x20, 0x00, 0x0d, 0x0a, 0x0d, 0x0a, 0x24, 0x10, 0x12, 0x12, 0x11, 0x10, 0x10, 0x10, 0x01, + //0x0420: .. ...$ .... .... + 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, //0x0430: .... .... .... .... - 0x02, 0x02, 0x02, 0x44, 0x3a, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - //0x0440: ...D :... .... .... + 0x44, 0x3a, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + //0x0440: D:.. .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x0450: .... .... .... .... - 0x00, 0x00, 0x00, 0x01, 0x01, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x01, 0x01, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x0460: .... .... .... .... - 0x00, 0x00, 0x00, 0x05, 0x00, 0x03, 0x02, 0x04, 0x01, 0x0a, 0x09, 0x08, 0x06, 0x0b, 0x04, 0x07, + 0x05, 0x00, 0x03, 0x02, 0x04, 0x01, 0x0a, 0x09, 0x08, 0x06, 0x0b, 0x04, 0x07, 0x07, 0x00, 0x00, //0x0470: .... .... .... .... - 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x0480: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x0490: .... .... .... .... @@ -3068,7 +2909,7 @@ void DreamGenContext::__start() { //0x04e0: .... .... .... .... 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, //0x04f0: .... .... .... .... - 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, }; + 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, }; ds.assign(src, src + sizeof(src)); dreamweb(); } diff --git a/engines/dreamweb/dreamgen.h b/engines/dreamweb/dreamgen.h index 139253cdb8..f6100557c1 100644 --- a/engines/dreamweb/dreamgen.h +++ b/engines/dreamweb/dreamgen.h @@ -32,9 +32,9 @@ namespace DreamGen { -static const uint16 offset_operand1 = 0x03fc; -static const uint16 offset_keys = 0x0392; -static const uint16 offset_rootdir = 0x040a; +static const uint16 offset_rootdir = 0x0407; +static const uint16 offset_operand1 = 0x03f9; +static const uint16 offset_keys = 0x038f; static const uint16 kStartvars = 0; static const uint16 kProgresspoints = 1; static const uint16 kWatchon = 2; @@ -157,220 +157,217 @@ static const uint16 kNewscreen = 149; static const uint16 kRyanx = 150; static const uint16 kRyany = 151; static const uint16 kLastflag = 152; -static const uint16 kLastflagex = 153; -static const uint16 kFlagx = 154; -static const uint16 kFlagy = 155; -static const uint16 kCurrentex = 156; -static const uint16 kCurrentfree = 157; -static const uint16 kFramesad = 158; -static const uint16 kDataad = 160; -static const uint16 kFrsegment = 162; -static const uint16 kObjectx = 164; -static const uint16 kObjecty = 166; -static const uint16 kOffsetx = 168; -static const uint16 kOffsety = 170; -static const uint16 kSavesize = 172; -static const uint16 kSavesource = 174; -static const uint16 kSavex = 176; -static const uint16 kSavey = 177; -static const uint16 kCurrentob = 178; -static const uint16 kPrioritydep = 179; -static const uint16 kDestpos = 180; -static const uint16 kReallocation = 181; -static const uint16 kRoomnum = 182; -static const uint16 kNowinnewroom = 183; -static const uint16 kResetmanxy = 184; -static const uint16 kNewlocation = 185; -static const uint16 kAutolocation = 186; -static const uint16 kMustload = 187; -static const uint16 kAnswered = 188; -static const uint16 kSaidno = 189; -static const uint16 kDoorcheck1 = 190; -static const uint16 kDoorcheck2 = 191; -static const uint16 kDoorcheck3 = 192; -static const uint16 kDoorcheck4 = 193; -static const uint16 kMousex = 194; -static const uint16 kMousey = 196; -static const uint16 kMousebutton = 198; -static const uint16 kMousebutton1 = 200; -static const uint16 kMousebutton2 = 202; -static const uint16 kMousebutton3 = 204; -static const uint16 kMousebutton4 = 206; -static const uint16 kOldbutton = 208; -static const uint16 kOldx = 210; -static const uint16 kOldy = 212; -static const uint16 kLastbutton = 214; -static const uint16 kOldpointerx = 216; -static const uint16 kOldpointery = 218; -static const uint16 kDelherex = 220; -static const uint16 kDelherey = 222; -static const uint16 kPointerxs = 224; -static const uint16 kPointerys = 225; -static const uint16 kDelxs = 226; -static const uint16 kDelys = 227; -static const uint16 kPointerframe = 228; -static const uint16 kPointerpower = 229; -static const uint16 kAuxpointerframe = 230; -static const uint16 kPointermode = 231; -static const uint16 kPointerspeed = 232; -static const uint16 kPointercount = 233; -static const uint16 kInmaparea = 234; -static const uint16 kSlotdata = 235; -static const uint16 kThisslot = 236; -static const uint16 kSlotflags = 237; -static const uint16 kTalkmode = 238; -static const uint16 kTalkpos = 239; -static const uint16 kCharacter = 240; -static const uint16 kPersondata = 241; -static const uint16 kTalknum = 243; -static const uint16 kNumberinroom = 244; -static const uint16 kCurrentcel = 245; -static const uint16 kOldselection = 246; -static const uint16 kStopwalking = 247; -static const uint16 kMouseon = 248; -static const uint16 kPlayed = 249; -static const uint16 kTimer1 = 251; -static const uint16 kTimer2 = 252; -static const uint16 kTimer3 = 253; -static const uint16 kWholetimer = 254; -static const uint16 kTimer1to = 256; -static const uint16 kTimer2to = 257; -static const uint16 kTimer3to = 258; -static const uint16 kWatchdump = 259; -static const uint16 kLogonum = 260; -static const uint16 kOldlogonum = 261; -static const uint16 kNewlogonum = 262; -static const uint16 kNetseg = 263; -static const uint16 kNetpoint = 265; -static const uint16 kKeynum = 267; -static const uint16 kCursorstate = 268; -static const uint16 kPressed = 269; -static const uint16 kPresspointer = 270; -static const uint16 kGraphicpress = 272; -static const uint16 kPresscount = 273; -static const uint16 kLightcount = 274; -static const uint16 kFolderpage = 275; -static const uint16 kDiarypage = 276; -static const uint16 kMenucount = 277; -static const uint16 kSymboltopx = 278; -static const uint16 kSymboltopnum = 279; -static const uint16 kSymboltopdir = 280; -static const uint16 kSymbolbotx = 281; -static const uint16 kSymbolbotnum = 282; -static const uint16 kSymbolbotdir = 283; -static const uint16 kSymboltolight = 284; -static const uint16 kSymbol1 = 285; -static const uint16 kSymbol2 = 286; -static const uint16 kSymbol3 = 287; -static const uint16 kSymbolnum = 288; -static const uint16 kDumpx = 289; -static const uint16 kDumpy = 291; -static const uint16 kWalkandexam = 293; -static const uint16 kWalkexamtype = 294; -static const uint16 kWalkexamnum = 295; -static const uint16 kCurslocx = 296; -static const uint16 kCurslocy = 298; -static const uint16 kCurpos = 300; -static const uint16 kMonadx = 302; -static const uint16 kMonady = 304; -static const uint16 kMonsource = 306; -static const uint16 kNumtodo = 308; -static const uint16 kTimecount = 310; -static const uint16 kCounttotimed = 312; -static const uint16 kTimedseg = 314; -static const uint16 kTimedoffset = 316; -static const uint16 kTimedy = 318; -static const uint16 kTimedx = 319; -static const uint16 kNeedtodumptimed = 320; -static const uint16 kLoadingorsave = 321; -static const uint16 kCurrentslot = 322; -static const uint16 kCursorpos = 323; -static const uint16 kColourpos = 324; -static const uint16 kFadedirection = 325; -static const uint16 kNumtofade = 326; -static const uint16 kFadecount = 327; -static const uint16 kAddtogreen = 328; -static const uint16 kAddtored = 329; -static const uint16 kAddtoblue = 330; -static const uint16 kLastsoundreel = 331; -static const uint16 kSpeechloaded = 333; -static const uint16 kSpeechlength = 334; -static const uint16 kVolume = 336; -static const uint16 kVolumeto = 337; -static const uint16 kVolumedirection = 338; -static const uint16 kVolumecount = 339; -static const uint16 kWongame = 340; -static const uint16 kLasthardkey = 341; -static const uint16 kBufferin = 342; -static const uint16 kBufferout = 344; -static const uint16 kExtras = 346; -static const uint16 kWorkspace = 348; -static const uint16 kMapstore = 350; -static const uint16 kCharset1 = 352; -static const uint16 kBuffers = 354; -static const uint16 kMainsprites = 356; -static const uint16 kBackdrop = 358; -static const uint16 kMapdata = 360; -static const uint16 kSounddata = 362; -static const uint16 kSounddata2 = 364; -static const uint16 kRecordspace = 366; -static const uint16 kFreedat = 368; -static const uint16 kSetdat = 370; -static const uint16 kReel1 = 372; -static const uint16 kReel2 = 374; -static const uint16 kReel3 = 376; -static const uint16 kRoomdesc = 378; -static const uint16 kFreedesc = 380; -static const uint16 kSetdesc = 382; -static const uint16 kBlockdesc = 384; -static const uint16 kSetframes = 386; -static const uint16 kFreeframes = 388; -static const uint16 kPeople = 390; -static const uint16 kReels = 392; -static const uint16 kCommandtext = 394; -static const uint16 kPuzzletext = 396; -static const uint16 kTraveltext = 398; -static const uint16 kTempgraphics = 400; -static const uint16 kTempgraphics2 = 402; -static const uint16 kTempgraphics3 = 404; -static const uint16 kTempsprites = 406; -static const uint16 kTextfile1 = 408; -static const uint16 kTextfile2 = 410; -static const uint16 kTextfile3 = 412; -static const uint16 kBlinkframe = 414; -static const uint16 kBlinkcount = 415; -static const uint16 kReasseschanges = 416; -static const uint16 kPointerspath = 417; -static const uint16 kManspath = 418; -static const uint16 kPointerfirstpath = 419; -static const uint16 kFinaldest = 420; -static const uint16 kDestination = 421; -static const uint16 kLinestartx = 422; -static const uint16 kLinestarty = 424; -static const uint16 kLineendx = 426; -static const uint16 kLineendy = 428; -static const uint16 kLinepointer = 430; -static const uint16 kLinedirection = 431; -static const uint16 kLinelength = 432; -static const uint16 kCh0blockstocopy = 433; -static const uint16 kCh0playing = 435; -static const uint16 kCh0repeat = 436; -static const uint16 kCh1playing = 437; -static const uint16 kCh1blockstocopy = 438; -static const uint16 kSoundbufferwrite = 440; -static const uint16 kCurrentsample = 442; -static const uint16 kRoomssample = 443; -static const uint16 kReelroutines = 444; -static const uint16 kBasicsample = 901; -static const uint16 kCurrentfile = 1048; -static const uint16 kRoomscango = 1123; -static const uint16 kRoompics = 1139; -static const uint16 kOplist = 1154; -static const uint16 kInputline = 1157; -static const uint16 kPresslist = 1285; -static const uint16 kQuitrequested = 1291; -static const uint16 kSubtitles = 1292; -static const uint16 kForeignrelease = 1293; +static const uint16 kCurrentex = 153; +static const uint16 kCurrentfree = 154; +static const uint16 kFramesad = 155; +static const uint16 kDataad = 157; +static const uint16 kFrsegment = 159; +static const uint16 kObjectx = 161; +static const uint16 kObjecty = 163; +static const uint16 kOffsetx = 165; +static const uint16 kOffsety = 167; +static const uint16 kSavesize = 169; +static const uint16 kSavesource = 171; +static const uint16 kSavex = 173; +static const uint16 kSavey = 174; +static const uint16 kCurrentob = 175; +static const uint16 kPrioritydep = 176; +static const uint16 kDestpos = 177; +static const uint16 kReallocation = 178; +static const uint16 kRoomnum = 179; +static const uint16 kNowinnewroom = 180; +static const uint16 kResetmanxy = 181; +static const uint16 kNewlocation = 182; +static const uint16 kAutolocation = 183; +static const uint16 kMustload = 184; +static const uint16 kAnswered = 185; +static const uint16 kSaidno = 186; +static const uint16 kDoorcheck1 = 187; +static const uint16 kDoorcheck2 = 188; +static const uint16 kDoorcheck3 = 189; +static const uint16 kDoorcheck4 = 190; +static const uint16 kMousex = 191; +static const uint16 kMousey = 193; +static const uint16 kMousebutton = 195; +static const uint16 kMousebutton1 = 197; +static const uint16 kMousebutton2 = 199; +static const uint16 kMousebutton3 = 201; +static const uint16 kMousebutton4 = 203; +static const uint16 kOldbutton = 205; +static const uint16 kOldx = 207; +static const uint16 kOldy = 209; +static const uint16 kLastbutton = 211; +static const uint16 kOldpointerx = 213; +static const uint16 kOldpointery = 215; +static const uint16 kDelherex = 217; +static const uint16 kDelherey = 219; +static const uint16 kPointerxs = 221; +static const uint16 kPointerys = 222; +static const uint16 kDelxs = 223; +static const uint16 kDelys = 224; +static const uint16 kPointerframe = 225; +static const uint16 kPointerpower = 226; +static const uint16 kAuxpointerframe = 227; +static const uint16 kPointermode = 228; +static const uint16 kPointerspeed = 229; +static const uint16 kPointercount = 230; +static const uint16 kInmaparea = 231; +static const uint16 kSlotdata = 232; +static const uint16 kThisslot = 233; +static const uint16 kSlotflags = 234; +static const uint16 kTalkmode = 235; +static const uint16 kTalkpos = 236; +static const uint16 kCharacter = 237; +static const uint16 kPersondata = 238; +static const uint16 kTalknum = 240; +static const uint16 kNumberinroom = 241; +static const uint16 kCurrentcel = 242; +static const uint16 kOldselection = 243; +static const uint16 kStopwalking = 244; +static const uint16 kMouseon = 245; +static const uint16 kPlayed = 246; +static const uint16 kTimer1 = 248; +static const uint16 kTimer2 = 249; +static const uint16 kTimer3 = 250; +static const uint16 kWholetimer = 251; +static const uint16 kTimer1to = 253; +static const uint16 kTimer2to = 254; +static const uint16 kTimer3to = 255; +static const uint16 kWatchdump = 256; +static const uint16 kLogonum = 257; +static const uint16 kOldlogonum = 258; +static const uint16 kNewlogonum = 259; +static const uint16 kNetseg = 260; +static const uint16 kNetpoint = 262; +static const uint16 kKeynum = 264; +static const uint16 kCursorstate = 265; +static const uint16 kPressed = 266; +static const uint16 kPresspointer = 267; +static const uint16 kGraphicpress = 269; +static const uint16 kPresscount = 270; +static const uint16 kLightcount = 271; +static const uint16 kFolderpage = 272; +static const uint16 kDiarypage = 273; +static const uint16 kMenucount = 274; +static const uint16 kSymboltopx = 275; +static const uint16 kSymboltopnum = 276; +static const uint16 kSymboltopdir = 277; +static const uint16 kSymbolbotx = 278; +static const uint16 kSymbolbotnum = 279; +static const uint16 kSymbolbotdir = 280; +static const uint16 kSymboltolight = 281; +static const uint16 kSymbol1 = 282; +static const uint16 kSymbol2 = 283; +static const uint16 kSymbol3 = 284; +static const uint16 kSymbolnum = 285; +static const uint16 kDumpx = 286; +static const uint16 kDumpy = 288; +static const uint16 kWalkandexam = 290; +static const uint16 kWalkexamtype = 291; +static const uint16 kWalkexamnum = 292; +static const uint16 kCurslocx = 293; +static const uint16 kCurslocy = 295; +static const uint16 kCurpos = 297; +static const uint16 kMonadx = 299; +static const uint16 kMonady = 301; +static const uint16 kMonsource = 303; +static const uint16 kNumtodo = 305; +static const uint16 kTimecount = 307; +static const uint16 kCounttotimed = 309; +static const uint16 kTimedseg = 311; +static const uint16 kTimedoffset = 313; +static const uint16 kTimedy = 315; +static const uint16 kTimedx = 316; +static const uint16 kNeedtodumptimed = 317; +static const uint16 kLoadingorsave = 318; +static const uint16 kCurrentslot = 319; +static const uint16 kCursorpos = 320; +static const uint16 kColourpos = 321; +static const uint16 kFadedirection = 322; +static const uint16 kNumtofade = 323; +static const uint16 kFadecount = 324; +static const uint16 kAddtogreen = 325; +static const uint16 kAddtored = 326; +static const uint16 kAddtoblue = 327; +static const uint16 kLastsoundreel = 328; +static const uint16 kSpeechloaded = 330; +static const uint16 kSpeechlength = 331; +static const uint16 kVolume = 333; +static const uint16 kVolumeto = 334; +static const uint16 kVolumedirection = 335; +static const uint16 kVolumecount = 336; +static const uint16 kWongame = 337; +static const uint16 kLasthardkey = 338; +static const uint16 kBufferin = 339; +static const uint16 kBufferout = 341; +static const uint16 kExtras = 343; +static const uint16 kWorkspace = 345; +static const uint16 kMapstore = 347; +static const uint16 kCharset1 = 349; +static const uint16 kBuffers = 351; +static const uint16 kMainsprites = 353; +static const uint16 kBackdrop = 355; +static const uint16 kMapdata = 357; +static const uint16 kSounddata = 359; +static const uint16 kSounddata2 = 361; +static const uint16 kRecordspace = 363; +static const uint16 kFreedat = 365; +static const uint16 kSetdat = 367; +static const uint16 kReel1 = 369; +static const uint16 kReel2 = 371; +static const uint16 kReel3 = 373; +static const uint16 kRoomdesc = 375; +static const uint16 kFreedesc = 377; +static const uint16 kSetdesc = 379; +static const uint16 kBlockdesc = 381; +static const uint16 kSetframes = 383; +static const uint16 kFreeframes = 385; +static const uint16 kPeople = 387; +static const uint16 kReels = 389; +static const uint16 kCommandtext = 391; +static const uint16 kPuzzletext = 393; +static const uint16 kTraveltext = 395; +static const uint16 kTempgraphics = 397; +static const uint16 kTempgraphics2 = 399; +static const uint16 kTempgraphics3 = 401; +static const uint16 kTempsprites = 403; +static const uint16 kTextfile1 = 405; +static const uint16 kTextfile2 = 407; +static const uint16 kTextfile3 = 409; +static const uint16 kBlinkframe = 411; +static const uint16 kBlinkcount = 412; +static const uint16 kReasseschanges = 413; +static const uint16 kPointerspath = 414; +static const uint16 kManspath = 415; +static const uint16 kPointerfirstpath = 416; +static const uint16 kFinaldest = 417; +static const uint16 kDestination = 418; +static const uint16 kLinestartx = 419; +static const uint16 kLinestarty = 421; +static const uint16 kLineendx = 423; +static const uint16 kLineendy = 425; +static const uint16 kLinepointer = 427; +static const uint16 kLinedirection = 428; +static const uint16 kLinelength = 429; +static const uint16 kCh0blockstocopy = 430; +static const uint16 kCh0playing = 432; +static const uint16 kCh0repeat = 433; +static const uint16 kCh1playing = 434; +static const uint16 kCh1blockstocopy = 435; +static const uint16 kSoundbufferwrite = 437; +static const uint16 kCurrentsample = 439; +static const uint16 kRoomssample = 440; +static const uint16 kReelroutines = 441; +static const uint16 kBasicsample = 898; +static const uint16 kCurrentfile = 1045; +static const uint16 kRoomscango = 1120; +static const uint16 kRoompics = 1136; +static const uint16 kOplist = 1151; +static const uint16 kInputline = 1154; +static const uint16 kPresslist = 1282; +static const uint16 kQuitrequested = 1288; +static const uint16 kSubtitles = 1289; +static const uint16 kForeignrelease = 1290; static const uint16 kBlocktextdat = (0); static const uint16 kPersonframes = (0); static const uint16 kDebuglevel1 = (0); @@ -409,8 +406,8 @@ static const uint16 kListofchanges = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768 static const uint16 kUndertimedtext = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)); static const uint16 kRainlist = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)); static const uint16 kInitialreelrouts = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)); -static const uint16 kInitialvars = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+901-444); -static const uint16 kLengthofbuffer = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+901-444+68-0); +static const uint16 kInitialvars = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+898-441); +static const uint16 kLengthofbuffer = (0+(228*13)+32+60+(32*32)+(11*10*3)+768+768+768+(32*32)+(128*5)+(80*5)+(100*5)+(12*5)+(46*40)+(5*80)+(250*4)+(256*30)+(6*64)+898-441+68-0); static const uint16 kReellist = (0+(36*144)); static const uint16 kIntext = (0+(38*2)); static const uint16 kLengthofmap = (0+(66*60)); @@ -461,7 +458,7 @@ static const uint16 kKeypady = (72); static const uint16 kZoomx = (8); static const uint16 kInventx = (80); static const uint16 kMenux = (80+40); -static const uint16 kLenofreelrouts = (901-444); +static const uint16 kLenofreelrouts = (898-441); static const uint16 kHeaderlen = (96); @@ -480,17 +477,14 @@ public: void fillOpen(); void doSomeTalk(); void resetLocation(); - void adjustUp(); void outOfOpen(); void dirCom(); void findFirstPath(); void startTalk(); void getAnyAd(); void reminders(); - void checkForExit(); void lookInInterface(); void inToInv(); - void adjustLeft(); void deleteExText(); void getFreeAd(); void removeObFromInv(); @@ -533,12 +527,10 @@ public: void getExAd(); void initialMonCols(); void swapWithInv(); - void adjustRight(); void transferToEx(); void parser(); void emergencyPurge(); void transferConToEx(); - void adjustDown(); }; } // End of namespace DreamGen diff --git a/engines/dreamweb/sprite.cpp b/engines/dreamweb/sprite.cpp index cfa204ec23..1e980de015 100644 --- a/engines/dreamweb/sprite.cpp +++ b/engines/dreamweb/sprite.cpp @@ -148,7 +148,7 @@ void DreamGenContext::mainMan(Sprite *sprite) { if ((data.byte(kTurndirection) != 0) && (data.byte(kLinepointer) == 254)) { data.byte(kReasseschanges) = 1; if (data.byte(kFacing) == data.byte(kLeavedirection)) - checkForExit(); + checkForExit(sprite); } data.byte(kTurndirection) = 0; if (data.byte(kLinepointer) == 254) { @@ -168,7 +168,7 @@ void DreamGenContext::mainMan(Sprite *sprite) { if (data.byte(kTurntoface) == data.byte(kFacing)) { data.byte(kReasseschanges) = 1; if (data.byte(kFacing) == data.byte(kLeavedirection)) - checkForExit(); + checkForExit(sprite); } } } @@ -1215,4 +1215,61 @@ void DreamBase::liftNoise(uint8 index) { playChannel1(index); } +void DreamBase::checkForExit(Sprite *sprite) { + uint8 flag, flagEx, type, flagX, flagY; + checkOne(data.byte(kRyanx) + 12, data.byte(kRyany) + 12, &flag, &flagEx, &type, &flagX, &flagY); + data.byte(kLastflag) = flag; + + if (flag & 64) { + data.byte(kAutolocation) = flagEx; + return; + } + + if (!(flag & 32)) { + if (flag & 4) { + // adjust left + data.byte(kLastflag) = 0; + data.byte(kMapx) -= 11; + sprite->x = 16 * flagEx; + data.byte(kNowinnewroom) = 1; + } else if (flag & 2) { + // adjust right + data.byte(kMapx) += 11; + sprite->x = 16 * flagEx - 2; + data.byte(kNowinnewroom) = 1; + } else if (flag & 8) { + // adjust down + data.byte(kMapy) += 10; + sprite->y = 16 * flagEx; + data.byte(kNowinnewroom) = 1; + } else if (flag & 16) { + // adjust up + data.byte(kMapy) -= 10; + sprite->y = 16 * flagEx; + data.byte(kNowinnewroom) = 1; + } + + return; + } + + if (data.byte(kReallocation) == 2) { + // Can't leave Louis' until you found shoes + + int shoeCount = 0; + if (isRyanHolding("WETA")) shoeCount++; + if (isRyanHolding("WETB")) shoeCount++; + + if (shoeCount < 2) { + uint8 text = shoeCount ? 43 : 42; + setupTimedUse(text, 80, 10, 68, 64); + + data.byte(kTurntoface) = (data.byte(kFacing) + 4) & 7; + return; + } + + } + + data.byte(kNeedtotravel) = 1; +} + } // End of namespace DreamGen diff --git a/engines/dreamweb/stubs.cpp b/engines/dreamweb/stubs.cpp index a1d08b35d1..21d1038f3c 100644 --- a/engines/dreamweb/stubs.cpp +++ b/engines/dreamweb/stubs.cpp @@ -1454,7 +1454,6 @@ void DreamBase::getFlagUnderP(uint8 *flag, uint8 *flagEx) { uint8 type, flagX, flagY; checkOne(data.word(kMousex) - data.word(kMapadx), data.word(kMousey) - data.word(kMapady), flag, flagEx, &type, &flagX, &flagY); data.byte(kLastflag) = *flag; - data.byte(kLastflagex) = *flagEx; } void DreamGenContext::walkAndExamine() { @@ -1784,7 +1783,7 @@ void DreamGenContext::isRyanHolding() { flags._z = !isRyanHolding(id); } -bool DreamGenContext::isRyanHolding(const char *id) { +bool DreamBase::isRyanHolding(const char *id) { for (uint16 index = 0; index < kNumexobjects; index++) { DynObject *object = getExAd(index); if (object->mapad[0] == 4 && objectMatches(object, id)) diff --git a/engines/dreamweb/stubs.h b/engines/dreamweb/stubs.h index d9823fb2c0..2305b93d53 100644 --- a/engines/dreamweb/stubs.h +++ b/engines/dreamweb/stubs.h @@ -384,7 +384,9 @@ void findExObject(); uint16 findExObject(const char *id); void isRyanHolding(); - bool isRyanHolding(const char *id); + bool isRyanHolding(const char *id) { + return DreamBase::isRyanHolding(id); + } void describeOb(); void getOpenedSize(); byte getOpenedSizeCPP(); -- cgit v1.2.3