aboutsummaryrefslogtreecommitdiff
path: root/engines/saga/objectmap.cpp
diff options
context:
space:
mode:
authorEugene Sandulenko2006-11-09 13:19:23 +0000
committerEugene Sandulenko2006-11-09 13:19:23 +0000
commit9b28b7473ceba16bfa6dea7aec74a58d99e21257 (patch)
treeb75952b7ee2b2e778818c7300771e8ab8eef6384 /engines/saga/objectmap.cpp
parentf334797caa7ab377b2b9be0d6b9115ae263facdc (diff)
downloadscummvm-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/saga/objectmap.cpp')
-rw-r--r--engines/saga/objectmap.cpp11
1 files changed, 9 insertions, 2 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());
}
}