From a65a0c47688c54bd2d07758420596e1821821c1b Mon Sep 17 00:00:00 2001 From: Paul Gilbert Date: Tue, 26 Sep 2017 21:08:06 -0400 Subject: TITANIC: DE: Fix switch in DeskbotScript::doSentenceEntry --- engines/titanic/true_talk/deskbot_script.cpp | 82 ++++++++++++++++++---------- 1 file changed, 52 insertions(+), 30 deletions(-) (limited to 'engines/titanic/true_talk/deskbot_script.cpp') diff --git a/engines/titanic/true_talk/deskbot_script.cpp b/engines/titanic/true_talk/deskbot_script.cpp index 128868c84e..f45b1b1358 100644 --- a/engines/titanic/true_talk/deskbot_script.cpp +++ b/engines/titanic/true_talk/deskbot_script.cpp @@ -386,48 +386,70 @@ uint DeskbotScript::getDialsBitset() const { } int DeskbotScript::doSentenceEntry(int val1, const int *srcIdP, const TTroomScript *roomScript, const TTsentence *sentence) { - uint id; + uint id = *srcIdP; - if (g_language == Common::DE_DEU && val1 != 4501) - return TTnpcScript::doSentenceEntry(val1, srcIdP, roomScript, sentence); + if (g_language == Common::DE_DEU) { + if (val1 != 4501) + return TTnpcScript::doSentenceEntry(val1, srcIdP, roomScript, sentence); - switch (val1) { - case 1: - id = *srcIdP; - if (id == 240431 || id == 240432) { - switch (getValue(1)) { - case 1: - id = 240336; - break; - case 2: - id = addAssignedRoomDialogue(); - break; - case 3: + switch (getValue(1)) { + case 1: + id = 240336; + break; + case 2: + addAssignedRoom(); + break; + case 3: + if (id == 240431 || id == 240432) { if (getValue(3) == 1) { if (id == 240431) id = 240432; - } - else { + } else { if (id == 240432) id = 240431; } - default: - break; } - - addResponse(getDialogueId(id)); - applyResponse(); - return 2; + break; + default: + break; } - break; + } else { + switch (val1) { + case 1: + if (id == 240431 || id == 240432) { + switch (getValue(1)) { + case 1: + id = 240336; + break; + case 2: + id = addAssignedRoomDialogue(); + break; + case 3: + if (getValue(3) == 1) { + if (id == 240431) + id = 240432; + } else { + if (id == 240432) + id = 240431; + } + default: + break; + } - case 2: - if (getValue(1) == 1) - return true; - break; + addResponse(getDialogueId(id)); + applyResponse(); + return 2; + } + break; - default: - break; + case 2: + if (getValue(1) == 1) + return true; + break; + + default: + break; + } } return 0; -- cgit v1.2.3