diff options
author | sluicebox | 2020-01-02 13:24:16 -0800 |
---|---|---|
committer | sluicebox | 2020-01-02 13:25:00 -0800 |
commit | 03392537a0b0c79323816f8d5644173f80f782a7 (patch) | |
tree | ad09c31e71ddfeac86cb75eaddd9fea5cf44210f /engines/sci/engine | |
parent | d289fa5f981930d151c4d7d57fc5bed1dac63750 (diff) | |
download | scummvm-rg350-03392537a0b0c79323816f8d5644173f80f782a7.tar.gz scummvm-rg350-03392537a0b0c79323816f8d5644173f80f782a7.tar.bz2 scummvm-rg350-03392537a0b0c79323816f8d5644173f80f782a7.zip |
SCI32: Fix GK2 Neuschwanstein castle hint
Diffstat (limited to 'engines/sci/engine')
-rw-r--r-- | engines/sci/engine/script_patches.cpp | 45 |
1 files changed, 44 insertions, 1 deletions
diff --git a/engines/sci/engine/script_patches.cpp b/engines/sci/engine/script_patches.cpp index 4d71e9704a..bd5e5d4ebe 100644 --- a/engines/sci/engine/script_patches.cpp +++ b/engines/sci/engine/script_patches.cpp @@ -3563,7 +3563,7 @@ static const uint16 gk2XaverBlackWolfkPatch[] = { // We fix this as Sierra did by replacing the inventory tests with flag tests. // // Applies to: English PC 1.0, Mac -// Responsible methods: waterBakset:handleEvent, waterBasket:doVerb +// Responsible methods: waterBasket:handleEvent, waterBasket:doVerb static const uint16 gk2HolyWaterLockupSignature[] = { SIG_MAGICDWORD, 0x38, SIG_SELECTOR16(has), // pushi has @@ -3582,6 +3582,46 @@ static const uint16 gk2HolyWaterLockupPatch[] = { PATCH_END }; +// In early versions of GK2, Neuschwanstein castle can flash when clicking the +// Hint button even after completing everything. The Hint script tests too many +// flags including one whose value is random since it toggles back and forth +// between two tape messages. We remove these flag tests as Sierra did. +// +// Applies to: English PC 1.0, Mac +// Responsible method: local procedure #0 in script 800 +static const uint16 gk2NeuschwansteinHintSignature1[] = { + SIG_MAGICDWORD, + 0x78, // push1 + 0x38, SIG_UINT16(0x024d), // pushi 024d + 0x47, 0x0b, 0x00, // calle proc11_0 [ is flag 589 set? ] + SIG_UINT16(0x0002), + SIG_END +}; + +static const uint16 gk2NeuschwansteinHintSignature2[] = { + SIG_MAGICDWORD, + 0x78, // push1 + 0x38, SIG_UINT16(0x024e), // pushi 024e + 0x47, 0x0b, 0x00, // calle proc11_0 [ is flag 590 set? ] + SIG_UINT16(0x0002), + SIG_END +}; + +static const uint16 gk2NeuschwansteinHintSignature3[] = { + SIG_MAGICDWORD, + 0x78, // push1 + 0x38, SIG_UINT16(0x0250), // pushi 0250 + 0x47, 0x0b, 0x00, // calle proc11_0 [ is flag 592 set? ] + SIG_UINT16(0x0002), + SIG_END +}; + +static const uint16 gk2NeuschwansteinHintPatch[] = { + 0x35, 0x01, // ldi 01 + 0x33, 0x05, // jmp 05 + PATCH_END +}; + // Clicking an inventory item on the Wagner paintings in rooms 8616 and 8617 // causes a missing message error. The paintings only have responses for the // "Do" verb but painting:doVerb passes the incoming verb to gk2Messager:say @@ -3613,6 +3653,9 @@ static const SciScriptPatcherEntry gk2Signatures[] = { { true, 23, "fix inventory scroll direction (no line numbers)", 1, gk2InventoryScrollDirSignature2, gk2InventoryScrollDirPatch2 }, { true, 37, "fix sound manager lockup", 1, gk2SoundManagerLockupSignature1, gk2SoundManagerLockupPatch1 }, { true, 37, "fix sound manager lockup (no line numbers)", 1, gk2SoundManagerLockupSignature2, gk2SoundManagerLockupPatch2 }, + { true, 800, "fix neuschwanstein hint (1/3)", 1, gk2NeuschwansteinHintSignature1, gk2NeuschwansteinHintPatch }, + { true, 800, "fix neuschwanstein hint (2/3)", 1, gk2NeuschwansteinHintSignature2, gk2NeuschwansteinHintPatch }, + { true, 800, "fix neuschwanstein hint (3/3)", 1, gk2NeuschwansteinHintSignature3, gk2NeuschwansteinHintPatch }, { true, 810, "fix frau miller lockup", 1, gk2FrauMillerLockupSignature, gk2FrauMillerLockupPatch }, { true, 1020, "fix holy water lockup", 2, gk2HolyWaterLockupSignature, gk2HolyWaterLockupPatch }, { true, 3210, "fix police station deadend", 1, gk2PoliceStationDeadendSignature, gk2PoliceStationDeadendPatch }, |