diff options
author | Eugene Sandulenko | 2006-11-09 13:19:23 +0000 |
---|---|---|
committer | Eugene Sandulenko | 2006-11-09 13:19:23 +0000 |
commit | 9b28b7473ceba16bfa6dea7aec74a58d99e21257 (patch) | |
tree | b75952b7ee2b2e778818c7300771e8ab8eef6384 /engines | |
parent | f334797caa7ab377b2b9be0d6b9115ae263facdc (diff) | |
download | scummvm-rg350-9b28b7473ceba16bfa6dea7aec74a58d99e21257.tar.gz scummvm-rg350-9b28b7473ceba16bfa6dea7aec74a58d99e21257.tar.bz2 scummvm-rg350-9b28b7473ceba16bfa6dea7aec74a58d99e21257.zip |
Workaround for bug #1259608: "ITE: Riff ignores command in Ferret merchant
center"
svn-id: r24664
Diffstat (limited to 'engines')
-rw-r--r-- | engines/saga/objectmap.cpp | 11 | ||||
-rw-r--r-- | engines/saga/objectmap.h | 2 |
2 files changed, 10 insertions, 3 deletions
diff --git a/engines/saga/objectmap.cpp b/engines/saga/objectmap.cpp index d0a302b0d7..5bfdade011 100644 --- a/engines/saga/objectmap.cpp +++ b/engines/saga/objectmap.cpp @@ -41,7 +41,7 @@ namespace Saga { -HitZone::HitZone(MemoryReadStreamEndian *readStream, int index): _index(index) { +HitZone::HitZone(MemoryReadStreamEndian *readStream, int index, int sceneNumber): _index(index) { int i, j; HitZone::ClickArea *clickArea; Point *point; @@ -74,6 +74,13 @@ HitZone::HitZone(MemoryReadStreamEndian *readStream, int index): _index(index) { point = &clickArea->points[j]; point->x = readStream->readSint16(); point->y = readStream->readSint16(); + + // WORKAROUND: bug #1259608: "ITE: Riff ignores command in Ferret merchant center" + // Apparently ITE Mac version has bug in game data. Both ObjectMap and ActionMap + // for exit area are little taller (y = 123) and thus Riff goes to exit + // when clicked on barrel of nails. + if (sceneNumber == 18 && index == 0 && i == 0 && j == 0 && point->y == 123) + point->y = 129; } } } @@ -198,7 +205,7 @@ void ObjectMap::load(const byte *resourcePointer, size_t resourceLength) { } for (i = 0; i < _hitZoneListCount; i++) { - _hitZoneList[i] = new HitZone(&readS, i); + _hitZoneList[i] = new HitZone(&readS, i, _vm->_scene->currentSceneNumber()); } } diff --git a/engines/saga/objectmap.h b/engines/saga/objectmap.h index 43356d3579..117d5180ae 100644 --- a/engines/saga/objectmap.h +++ b/engines/saga/objectmap.h @@ -40,7 +40,7 @@ private: }; public: - HitZone(MemoryReadStreamEndian *readStream, int index); + HitZone(MemoryReadStreamEndian *readStream, int index, int sceneNumber); ~HitZone(); int getNameIndex() const { |