aboutsummaryrefslogtreecommitdiff
path: root/engines/titanic/true_talk
diff options
context:
space:
mode:
authorPaul Gilbert2016-05-21 16:47:42 -0400
committerPaul Gilbert2016-07-15 19:13:50 -0400
commit8668b37ef583962d9684adb9913289a0b6e71a97 (patch)
treedde4cea2336206b2c7ec6e6c21324e8757ad03b2 /engines/titanic/true_talk
parent886b71048470986102ce2edf7baffc637134ac49 (diff)
downloadscummvm-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.cpp85
-rw-r--r--engines/titanic/true_talk/tt_sentence.h2
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);