aboutsummaryrefslogtreecommitdiff
path: root/engines/sci/engine/message.cpp
diff options
context:
space:
mode:
authorMatthew Hoops2011-02-03 05:10:24 +0000
committerMatthew Hoops2011-02-03 05:10:24 +0000
commit7c3d65912da2cae2568095e714c0877faf05a8b3 (patch)
tree7020d7380c5cda19a4553140efa2877ca3467e11 /engines/sci/engine/message.cpp
parent4088e735a962fd597049ff08e6e3710eb491c884 (diff)
downloadscummvm-rg350-7c3d65912da2cae2568095e714c0877faf05a8b3.tar.gz
scummvm-rg350-7c3d65912da2cae2568095e714c0877faf05a8b3.tar.bz2
scummvm-rg350-7c3d65912da2cae2568095e714c0877faf05a8b3.zip
SCI: Fix GK1 Mac messages
svn-id: r55750
Diffstat (limited to 'engines/sci/engine/message.cpp')
-rw-r--r--engines/sci/engine/message.cpp33
1 files changed, 32 insertions, 1 deletions
diff --git a/engines/sci/engine/message.cpp b/engines/sci/engine/message.cpp
index 046ed4e500..ff2d96e804 100644
--- a/engines/sci/engine/message.cpp
+++ b/engines/sci/engine/message.cpp
@@ -136,6 +136,33 @@ public:
}
};
+#ifdef ENABLE_SCI32
+// SCI32 Mac decided to add an extra byte (currently unknown in meaning) between
+// the talker and the string...
+class MessageReaderV4_MacSCI32 : public MessageReader {
+public:
+ MessageReaderV4_MacSCI32(byte *data, uint size) : MessageReader(data, size, 10, 12) { }
+
+ bool findRecord(const MessageTuple &tuple, MessageRecord &record) {
+ const byte *recordPtr = _data + _headerSize;
+
+ for (uint i = 0; i < _messageCount; i++) {
+ if ((recordPtr[0] == tuple.noun) && (recordPtr[1] == tuple.verb)
+ && (recordPtr[2] == tuple.cond) && (recordPtr[3] == tuple.seq)) {
+ record.tuple = tuple;
+ record.refTuple = MessageTuple(recordPtr[8], recordPtr[9], recordPtr[10]);
+ record.talker = recordPtr[4];
+ record.string = (const char *)_data + READ_BE_UINT16(recordPtr + 6);
+ return true;
+ }
+ recordPtr += _recordSize;
+ }
+
+ return false;
+ }
+};
+#endif
+
bool MessageState::getRecord(CursorStack &stack, bool recurse, MessageRecord &record) {
Resource *res = g_sci->getResMan()->findResource(ResourceId(kResourceTypeMessage, stack.getModule()), 0);
@@ -157,8 +184,12 @@ bool MessageState::getRecord(CursorStack &stack, bool recurse, MessageRecord &re
case 4:
#ifdef ENABLE_SCI32
case 5: // v5 seems to be compatible with v4
+ // SCI32 Mac is different than SCI32 DOS/Win here
+ if (g_sci->getPlatform() == Common::kPlatformMacintosh && getSciVersion() >= SCI_VERSION_2_1)
+ reader = new MessageReaderV4_MacSCI32(res->data, res->size);
+ else
#endif
- reader = new MessageReaderV4(res->data, res->size);
+ reader = new MessageReaderV4(res->data, res->size);
break;
default:
error("Message: unsupported resource version %d", version);