diff options
author | Eugene Sandulenko | 2016-06-13 00:40:45 +0200 |
---|---|---|
committer | Eugene Sandulenko | 2016-08-03 23:40:36 +0200 |
commit | 106e629210f7fceeea765c0aea1062058e48eb78 (patch) | |
tree | 24b8504f93b4224dd4a832910d6990d88d3ddcee /engines/director/lingo | |
parent | 75d759c4d8cc05131270c720d9e86692bd5af199 (diff) | |
download | scummvm-rg350-106e629210f7fceeea765c0aea1062058e48eb78.tar.gz scummvm-rg350-106e629210f7fceeea765c0aea1062058e48eb78.tar.bz2 scummvm-rg350-106e629210f7fceeea765c0aea1062058e48eb78.zip |
DIRECTOR: Lingo: Add support for boolean flags in MCI
Diffstat (limited to 'engines/director/lingo')
-rw-r--r-- | engines/director/lingo/lingo-funcs.cpp | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/engines/director/lingo/lingo-funcs.cpp b/engines/director/lingo/lingo-funcs.cpp index cf48d66685..1a878869d9 100644 --- a/engines/director/lingo/lingo-funcs.cpp +++ b/engines/director/lingo/lingo-funcs.cpp @@ -35,14 +35,15 @@ enum MCITokenType { kMCITokenAlias, kMCITokenBuffer, kMCITokenFrom, - kMCITokenTo + kMCITokenTo, + kMCITokenRepeat }; struct MCIToken { - MCITokenType command; + MCITokenType command; // Command this flag belongs to MCITokenType flag; const char *token; - int pos; + int pos; // Position of parameter to store. 0 is always filename. Negative parameters mean boolean } MCITokens[] = { { kMCITokenNone, kMCITokenOpen, "open", 0 }, { kMCITokenOpen, kMCITokenType, "type", 1 }, @@ -52,6 +53,7 @@ struct MCIToken { { kMCITokenNone, kMCITokenPlay, "play", 0 }, { kMCITokenPlay, kMCITokenFrom, "from", 1 }, { kMCITokenPlay, kMCITokenTo, "to", 2 }, + { kMCITokenPlay, kMCITokenRepeat, "repeat", -3 }, // This is boolean parameter { kMCITokenNone, kMCITokenWait, "wait", 0 }, @@ -93,13 +95,18 @@ int Lingo::func_mci(Common::String *s) { if (command == kMCITokenNone) { // We caught command command = f->flag; // Switching to processing this command parameters - } else if (f->flag == kMCITokenNone) { // Unmatched token, parsing as filename + } else if (f->flag == kMCITokenNone) { // Unmatched token, storing as filename if (!params[0].empty()) warning("Duplicate filename in MCI command: %s -> %s", params[0].c_str(), token.c_str()); params[0] = token; - } else { - state = f->flag; - respos = f->pos; + } else { // This is normal parameter, storing next token to designated position + if (f->pos > 0) { // This is normal parameter + state = f->flag; + respos = f->pos; + } else { // This is boolean + params[-f->pos] = "true"; + state = kMCITokenNone; + } } break; } @@ -116,7 +123,7 @@ int Lingo::func_mci(Common::String *s) { warning("MCI open file: %s, type: %s, alias: %s buffer: %s", params[0].c_str(), params[1].c_str(), params[2].c_str(), params[3].c_str()); break; case kMCITokenPlay: - warning("MCI play file: %s, from: %s, to: %s", params[0].c_str(), params[1].c_str(), params[2].c_str()); + warning("MCI play file: %s, from: %s, to: %s, repeat: %s", params[0].c_str(), params[1].c_str(), params[2].c_str(), params[3].c_str()); break; default: warning("Unhandled MCI command: %s", s->c_str()); |