diff options
author | Paul Gilbert | 2016-05-21 16:47:42 -0400 |
---|---|---|
committer | Paul Gilbert | 2016-07-15 19:13:50 -0400 |
commit | 8668b37ef583962d9684adb9913289a0b6e71a97 (patch) | |
tree | dde4cea2336206b2c7ec6e6c21324e8757ad03b2 /engines/titanic/true_talk | |
parent | 886b71048470986102ce2edf7baffc637134ac49 (diff) | |
download | scummvm-rg350-8668b37ef583962d9684adb9913289a0b6e71a97.tar.gz scummvm-rg350-8668b37ef583962d9684adb9913289a0b6e71a97.tar.bz2 scummvm-rg350-8668b37ef583962d9684adb9913289a0b6e71a97.zip |
TITANIC: Finished TTparser loadRequests
Diffstat (limited to 'engines/titanic/true_talk')
-rw-r--r-- | engines/titanic/true_talk/tt_parser.cpp | 85 | ||||
-rw-r--r-- | engines/titanic/true_talk/tt_sentence.h | 2 |
2 files changed, 84 insertions, 3 deletions
diff --git a/engines/titanic/true_talk/tt_parser.cpp b/engines/titanic/true_talk/tt_parser.cpp index 9bc129b807..52be9578f9 100644 --- a/engines/titanic/true_talk/tt_parser.cpp +++ b/engines/titanic/true_talk/tt_parser.cpp @@ -628,10 +628,92 @@ int TTparser::loadRequests(TTword *word) { status = fn2(word); break; + case WMODE_7: + switch (word->_id) { + case 700: + addNode(6); + addNode(5); + break; + case 701: + addNode(11); + break; + case 702: + status = 1; + break; + case 703: + addNode(9); + break; + case 704: + addNode(10); + break; + default: + break; + } + + case WMODE_8: + if (word->_id == 304) { + // Nothing + } else if (word->_id == 801) { + addNode(22); + } else { + if (word->proc16()) + _sentence->_field58++; + if (word->proc17()) + _sentence->_field58++; + } + break; + + case WMODE_9: + switch (word->_id) { + case 900: + case 901: + case 902: + case 904: + if (_sentence->_field2C == 9) { + _sentenceSub->_field1C = 1; + _sentenceSub = _sentenceSub->addSibling(); + addNode(1); + } + else { + addNode(23); + addNode(13); + addNode(1); + } + break; + + case 905: + case 907: + case 908: + case 909: + addNode(23); + break; + + case 906: + addNode(23); + status = 1; + break; + + case 910: + addNode(4); + addNode(24); + addNode(23); + addNode(14); + status = 1; + break; + + default: + break; + } + + if (word->_id == 906) { + addNode(14); + status = 1; + } + break; + default: break; } - // TODO return status; } @@ -678,7 +760,6 @@ int TTparser::fn2(TTword *word) { default: return 0; } - int checkReferent(TTpronoun *pronoun); } int TTparser::checkReferent(TTpronoun *pronoun) { diff --git a/engines/titanic/true_talk/tt_sentence.h b/engines/titanic/true_talk/tt_sentence.h index a75742181b..fb060c1a45 100644 --- a/engines/titanic/true_talk/tt_sentence.h +++ b/engines/titanic/true_talk/tt_sentence.h @@ -71,7 +71,6 @@ public: class TTsentence { private: CScriptHandler *_owner; - int _field2C; int _inputCtr; int _field34; int _field38; @@ -90,6 +89,7 @@ public: int _field58; TTroomScript *_roomScript; TTnpcScript *_npcScript; + int _field2C; public: TTsentence(int inputCtr, const TTstring &line, CScriptHandler *owner, TTroomScript *roomScript, TTnpcScript *npcScript); |