aboutsummaryrefslogtreecommitdiff
path: root/engines/director/lingo
diff options
context:
space:
mode:
authorEugene Sandulenko2016-06-13 00:40:45 +0200
committerEugene Sandulenko2016-08-03 23:40:36 +0200
commit106e629210f7fceeea765c0aea1062058e48eb78 (patch)
tree24b8504f93b4224dd4a832910d6990d88d3ddcee /engines/director/lingo
parent75d759c4d8cc05131270c720d9e86692bd5af199 (diff)
downloadscummvm-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.cpp23
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());