From 7c3d65912da2cae2568095e714c0877faf05a8b3 Mon Sep 17 00:00:00 2001 From: Matthew Hoops Date: Thu, 3 Feb 2011 05:10:24 +0000 Subject: SCI: Fix GK1 Mac messages svn-id: r55750 --- engines/sci/engine/message.cpp | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) (limited to 'engines/sci/engine/message.cpp') 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); -- cgit v1.2.3