diff options
author | Martin Kiewitz | 2010-07-19 15:30:27 +0000 |
---|---|---|
committer | Martin Kiewitz | 2010-07-19 15:30:27 +0000 |
commit | b7b904f9814ca0644a8fea1a3fb9250a4a4fbbd5 (patch) | |
tree | 078cf1f2011659a90f6cc5a7091c3465e2928cba /engines/sci/parser/vocabulary.cpp | |
parent | cda55fe770ed71f5d4b00690ba4ea196ad4b533f (diff) | |
download | scummvm-rg350-b7b904f9814ca0644a8fea1a3fb9250a4a4fbbd5.tar.gz scummvm-rg350-b7b904f9814ca0644a8fea1a3fb9250a4a4fbbd5.tar.bz2 scummvm-rg350-b7b904f9814ca0644a8fea1a3fb9250a4a4fbbd5.zip |
SCI: fix regression of r51027
we have to reset the parser when switching vocabulary
svn-id: r51031
Diffstat (limited to 'engines/sci/parser/vocabulary.cpp')
-rw-r--r-- | engines/sci/parser/vocabulary.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/engines/sci/parser/vocabulary.cpp b/engines/sci/parser/vocabulary.cpp index 82051a3ecd..b4bd4dcb16 100644 --- a/engines/sci/parser/vocabulary.cpp +++ b/engines/sci/parser/vocabulary.cpp @@ -82,6 +82,12 @@ Vocabulary::~Vocabulary() { freeSuffixes(); } +void Vocabulary::reset() { + parserIsValid = false; // Invalidate parser + parser_event = NULL_REG; // Invalidate parser event + parser_base = make_reg(g_sci->getEngineState()->_segMan->getSysStringsSegment(), SYS_STRING_PARSER_BASE); +} + bool Vocabulary::loadParserWords() { char currentWord[VOCAB_MAX_WORDLENGTH] = ""; int currentWordPos = 0; |