aboutsummaryrefslogtreecommitdiff
path: root/engines/director/lingo
diff options
context:
space:
mode:
authorEugene Sandulenko2016-07-04 10:43:35 +0200
committerEugene Sandulenko2016-08-03 23:40:36 +0200
commiteb724af3ea1eb7eeb3948c6ca9fd299ca0cfec76 (patch)
tree83fadac984fcc8e3ca40e20998a509548b988371 /engines/director/lingo
parent350f81635f0186a9c93d8750d1d043f8c1cfda00 (diff)
downloadscummvm-rg350-eb724af3ea1eb7eeb3948c6ca9fd299ca0cfec76.tar.gz
scummvm-rg350-eb724af3ea1eb7eeb3948c6ca9fd299ca0cfec76.tar.bz2
scummvm-rg350-eb724af3ea1eb7eeb3948c6ca9fd299ca0cfec76.zip
DIRECTOR: Lingo: Parse basic 'else if' clause
Diffstat (limited to 'engines/director/lingo')
-rw-r--r--engines/director/lingo/lingo-gr.cpp756
-rw-r--r--engines/director/lingo/lingo-gr.h116
-rw-r--r--engines/director/lingo/lingo-gr.y20
-rw-r--r--engines/director/lingo/lingo-lex.cpp262
-rw-r--r--engines/director/lingo/lingo-lex.l1
5 files changed, 588 insertions, 567 deletions
diff --git a/engines/director/lingo/lingo-gr.cpp b/engines/director/lingo/lingo-gr.cpp
index 61b989a1e4..5d3bcd6b47 100644
--- a/engines/director/lingo/lingo-gr.cpp
+++ b/engines/director/lingo/lingo-gr.cpp
@@ -78,34 +78,35 @@
HANDLER = 267,
tDOWN = 268,
tELSE = 269,
- tEND = 270,
- tEXIT = 271,
- tFRAME = 272,
- tGLOBAL = 273,
- tGO = 274,
- tIF = 275,
- tINTO = 276,
- tLOOP = 277,
- tMACRO = 278,
- tMCI = 279,
- tMCIWAIT = 280,
- tMOVIE = 281,
- tNEXT = 282,
- tOF = 283,
- tPREVIOUS = 284,
- tPUT = 285,
- tREPEAT = 286,
- tSET = 287,
- tTHEN = 288,
- tTO = 289,
- tWITH = 290,
- tWHILE = 291,
- tGE = 292,
- tLE = 293,
- tGT = 294,
- tLT = 295,
- tEQ = 296,
- tNEQ = 297
+ tELSIF = 270,
+ tEND = 271,
+ tEXIT = 272,
+ tFRAME = 273,
+ tGLOBAL = 274,
+ tGO = 275,
+ tIF = 276,
+ tINTO = 277,
+ tLOOP = 278,
+ tMACRO = 279,
+ tMCI = 280,
+ tMCIWAIT = 281,
+ tMOVIE = 282,
+ tNEXT = 283,
+ tOF = 284,
+ tPREVIOUS = 285,
+ tPUT = 286,
+ tREPEAT = 287,
+ tSET = 288,
+ tTHEN = 289,
+ tTO = 290,
+ tWITH = 291,
+ tWHILE = 292,
+ tGE = 293,
+ tLE = 294,
+ tGT = 295,
+ tLT = 296,
+ tEQ = 297,
+ tNEQ = 298
};
#endif
/* Tokens. */
@@ -121,34 +122,35 @@
#define HANDLER 267
#define tDOWN 268
#define tELSE 269
-#define tEND 270
-#define tEXIT 271
-#define tFRAME 272
-#define tGLOBAL 273
-#define tGO 274
-#define tIF 275
-#define tINTO 276
-#define tLOOP 277
-#define tMACRO 278
-#define tMCI 279
-#define tMCIWAIT 280
-#define tMOVIE 281
-#define tNEXT 282
-#define tOF 283
-#define tPREVIOUS 284
-#define tPUT 285
-#define tREPEAT 286
-#define tSET 287
-#define tTHEN 288
-#define tTO 289
-#define tWITH 290
-#define tWHILE 291
-#define tGE 292
-#define tLE 293
-#define tGT 294
-#define tLT 295
-#define tEQ 296
-#define tNEQ 297
+#define tELSIF 270
+#define tEND 271
+#define tEXIT 272
+#define tFRAME 273
+#define tGLOBAL 274
+#define tGO 275
+#define tIF 276
+#define tINTO 277
+#define tLOOP 278
+#define tMACRO 279
+#define tMCI 280
+#define tMCIWAIT 281
+#define tMOVIE 282
+#define tNEXT 283
+#define tOF 284
+#define tPREVIOUS 285
+#define tPUT 286
+#define tREPEAT 287
+#define tSET 288
+#define tTHEN 289
+#define tTO 290
+#define tWITH 291
+#define tWHILE 292
+#define tGE 293
+#define tLE 294
+#define tGT 295
+#define tLT 296
+#define tEQ 297
+#define tNEQ 298
@@ -200,7 +202,7 @@ typedef union YYSTYPE
int narg; /* number of arguments */
}
/* Line 193 of yacc.c. */
-#line 204 "engines/director/lingo/lingo-gr.cpp"
+#line 206 "engines/director/lingo/lingo-gr.cpp"
YYSTYPE;
# define yystype YYSTYPE /* obsolescent; will be withdrawn */
# define YYSTYPE_IS_DECLARED 1
@@ -213,7 +215,7 @@ typedef union YYSTYPE
/* Line 216 of yacc.c. */
-#line 217 "engines/director/lingo/lingo-gr.cpp"
+#line 219 "engines/director/lingo/lingo-gr.cpp"
#ifdef short
# undef short
@@ -428,20 +430,20 @@ union yyalloc
/* YYFINAL -- State number of the termination state. */
#define YYFINAL 61
/* YYLAST -- Last index in YYTABLE. */
-#define YYLAST 339
+#define YYLAST 327
/* YYNTOKENS -- Number of terminals. */
-#define YYNTOKENS 55
+#define YYNTOKENS 56
/* YYNNTS -- Number of nonterminals. */
-#define YYNNTS 28
+#define YYNNTS 29
/* YYNRULES -- Number of rules. */
-#define YYNRULES 88
+#define YYNRULES 89
/* YYNRULES -- Number of states. */
-#define YYNSTATES 189
+#define YYNSTATES 187
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2
-#define YYMAXUTOK 297
+#define YYMAXUTOK 298
#define YYTRANSLATE(YYX) \
((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
@@ -450,12 +452,12 @@ union yyalloc
static const yytype_uint8 yytranslate[] =
{
0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 49, 2, 2, 2, 2, 2, 2, 2, 2, 2,
+ 50, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 48, 2, 2,
- 50, 51, 46, 44, 54, 45, 2, 47, 2, 2,
+ 2, 2, 2, 2, 2, 2, 2, 49, 2, 2,
+ 51, 52, 47, 45, 55, 46, 2, 48, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 53, 43, 52, 2, 2, 2, 2, 2, 2, 2,
+ 54, 44, 53, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
@@ -478,7 +480,7 @@ static const yytype_uint8 yytranslate[] =
5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
15, 16, 17, 18, 19, 20, 21, 22, 23, 24,
25, 26, 27, 28, 29, 30, 31, 32, 33, 34,
- 35, 36, 37, 38, 39, 40, 41, 42
+ 35, 36, 37, 38, 39, 40, 41, 42, 43
};
#if YYDEBUG
@@ -488,50 +490,50 @@ static const yytype_uint16 yyprhs[] =
{
0, 0, 3, 7, 9, 10, 12, 14, 16, 18,
20, 22, 24, 29, 34, 39, 41, 43, 45, 54,
- 66, 79, 86, 94, 105, 116, 118, 122, 129, 131,
- 135, 139, 142, 146, 148, 149, 150, 151, 154, 157,
- 159, 161, 166, 171, 173, 175, 179, 183, 187, 191,
- 195, 199, 203, 207, 211, 214, 217, 221, 224, 227,
- 230, 232, 234, 237, 239, 243, 246, 249, 252, 255,
- 259, 262, 266, 269, 272, 274, 278, 281, 285, 286,
- 295, 296, 298, 302, 307, 308, 312, 313, 315
+ 66, 79, 86, 94, 105, 116, 119, 121, 126, 128,
+ 132, 136, 139, 143, 145, 147, 148, 149, 150, 153,
+ 156, 158, 160, 165, 170, 172, 174, 178, 182, 186,
+ 190, 194, 198, 202, 206, 210, 213, 216, 220, 223,
+ 226, 229, 231, 233, 236, 238, 242, 245, 248, 251,
+ 254, 258, 261, 265, 268, 271, 273, 277, 280, 284,
+ 285, 294, 295, 297, 301, 306, 307, 311, 312, 314
};
/* YYRHS -- A `-1'-separated list of the rules' RHS. */
static const yytype_int8 yyrhs[] =
{
- 56, 0, -1, 57, 49, 56, -1, 57, -1, -1,
- 77, -1, 72, -1, 81, -1, 58, -1, 60, -1,
- 59, -1, 1, -1, 30, 71, 21, 10, -1, 32,
- 10, 43, 71, -1, 32, 10, 34, 71, -1, 71,
- -1, 72, -1, 61, -1, 65, 50, 64, 51, 70,
- 69, 15, 31, -1, 66, 43, 71, 69, 34, 71,
- 69, 70, 69, 15, 31, -1, 66, 43, 71, 69,
- 13, 34, 71, 69, 70, 69, 15, 31, -1, 67,
- 64, 33, 68, 59, 69, -1, 67, 64, 33, 70,
- 69, 15, 20, -1, 67, 64, 33, 70, 69, 14,
- 70, 69, 15, 20, -1, 67, 64, 33, 70, 69,
- 68, 62, 69, 15, 20, -1, 63, -1, 63, 49,
- 62, -1, 14, 67, 64, 33, 70, 69, -1, 71,
- -1, 71, 43, 71, -1, 50, 64, 51, -1, 31,
- 36, -1, 31, 35, 10, -1, 20, -1, -1, -1,
- -1, 70, 49, -1, 70, 59, -1, 7, -1, 8,
- -1, 9, 50, 82, 51, -1, 10, 50, 82, 51,
- -1, 10, -1, 58, -1, 71, 44, 71, -1, 71,
- 45, 71, -1, 71, 46, 71, -1, 71, 47, 71,
- -1, 71, 52, 71, -1, 71, 53, 71, -1, 71,
- 42, 71, -1, 71, 37, 71, -1, 71, 38, 71,
- -1, 44, 71, -1, 45, 71, -1, 50, 71, 51,
- -1, 24, 11, -1, 25, 10, -1, 30, 71, -1,
- 74, -1, 16, -1, 18, 73, -1, 10, -1, 73,
- 54, 10, -1, 19, 22, -1, 19, 27, -1, 19,
- 29, -1, 19, 75, -1, 19, 75, 76, -1, 19,
- 76, -1, 34, 17, 11, -1, 17, 11, -1, 34,
- 11, -1, 11, -1, 28, 26, 11, -1, 26, 11,
- -1, 34, 26, 11, -1, -1, 23, 10, 78, 68,
- 79, 49, 80, 70, -1, -1, 10, -1, 79, 54,
- 10, -1, 79, 49, 54, 10, -1, -1, 10, 68,
- 82, -1, -1, 71, -1, 82, 54, 71, -1
+ 57, 0, -1, 58, 50, 57, -1, 58, -1, -1,
+ 79, -1, 74, -1, 83, -1, 59, -1, 61, -1,
+ 60, -1, 1, -1, 31, 73, 22, 10, -1, 33,
+ 10, 44, 73, -1, 33, 10, 35, 73, -1, 73,
+ -1, 74, -1, 62, -1, 66, 51, 65, 52, 72,
+ 71, 16, 32, -1, 67, 44, 73, 71, 35, 73,
+ 71, 72, 71, 16, 32, -1, 67, 44, 73, 71,
+ 13, 35, 73, 71, 72, 71, 16, 32, -1, 68,
+ 65, 34, 70, 60, 71, -1, 68, 65, 34, 72,
+ 71, 16, 21, -1, 68, 65, 34, 72, 71, 14,
+ 72, 71, 16, 21, -1, 68, 65, 34, 72, 71,
+ 70, 63, 71, 16, 21, -1, 64, 63, -1, 64,
+ -1, 69, 65, 34, 72, -1, 73, -1, 73, 44,
+ 73, -1, 51, 65, 52, -1, 32, 37, -1, 32,
+ 36, 10, -1, 21, -1, 15, -1, -1, -1, -1,
+ 72, 50, -1, 72, 60, -1, 7, -1, 8, -1,
+ 9, 51, 84, 52, -1, 10, 51, 84, 52, -1,
+ 10, -1, 59, -1, 73, 45, 73, -1, 73, 46,
+ 73, -1, 73, 47, 73, -1, 73, 48, 73, -1,
+ 73, 53, 73, -1, 73, 54, 73, -1, 73, 43,
+ 73, -1, 73, 38, 73, -1, 73, 39, 73, -1,
+ 45, 73, -1, 46, 73, -1, 51, 73, 52, -1,
+ 25, 11, -1, 26, 10, -1, 31, 73, -1, 76,
+ -1, 17, -1, 19, 75, -1, 10, -1, 75, 55,
+ 10, -1, 20, 23, -1, 20, 28, -1, 20, 30,
+ -1, 20, 77, -1, 20, 77, 78, -1, 20, 78,
+ -1, 35, 18, 11, -1, 18, 11, -1, 35, 11,
+ -1, 11, -1, 29, 27, 11, -1, 27, 11, -1,
+ 35, 27, 11, -1, -1, 24, 10, 80, 70, 81,
+ 50, 82, 72, -1, -1, 10, -1, 81, 55, 10,
+ -1, 81, 50, 55, 10, -1, -1, 10, 70, 84,
+ -1, -1, 73, -1, 84, 55, 73, -1
};
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
@@ -540,12 +542,12 @@ static const yytype_uint16 yyrline[] =
0, 92, 92, 93, 96, 97, 98, 99, 100, 101,
102, 103, 106, 112, 118, 126, 127, 128, 133, 144,
160, 174, 182, 188, 196, 206, 207, 210, 220, 221,
- 222, 224, 226, 232, 234, 236, 238, 239, 240, 243,
- 248, 251, 257, 265, 268, 269, 270, 271, 272, 273,
- 274, 275, 276, 277, 278, 279, 280, 283, 284, 285,
- 286, 287, 289, 292, 293, 304, 305, 306, 307, 312,
- 318, 325, 326, 327, 328, 331, 332, 333, 361, 361,
- 368, 369, 370, 371, 373, 376, 384, 385, 386
+ 222, 224, 226, 232, 234, 236, 238, 240, 241, 242,
+ 245, 250, 253, 259, 267, 270, 271, 272, 273, 274,
+ 275, 276, 277, 278, 279, 280, 281, 282, 285, 286,
+ 287, 288, 289, 291, 294, 295, 306, 307, 308, 309,
+ 314, 320, 327, 328, 329, 330, 333, 334, 335, 363,
+ 363, 370, 371, 372, 373, 375, 378, 386, 387, 388
};
#endif
@@ -555,16 +557,17 @@ static const yytype_uint16 yyrline[] =
static const char *const yytname[] =
{
"$end", "error", "$undefined", "CASTREF", "UNARY", "VOID", "VAR", "INT",
- "FLOAT", "BLTIN", "ID", "STRING", "HANDLER", "tDOWN", "tELSE", "tEND",
- "tEXIT", "tFRAME", "tGLOBAL", "tGO", "tIF", "tINTO", "tLOOP", "tMACRO",
- "tMCI", "tMCIWAIT", "tMOVIE", "tNEXT", "tOF", "tPREVIOUS", "tPUT",
- "tREPEAT", "tSET", "tTHEN", "tTO", "tWITH", "tWHILE", "tGE", "tLE",
- "tGT", "tLT", "tEQ", "tNEQ", "'='", "'+'", "'-'", "'*'", "'/'", "'%'",
- "'\\n'", "'('", "')'", "'>'", "'<'", "','", "$accept", "program",
- "programline", "asgn", "stmt", "stmtoneliner", "ifstmt", "elseif",
- "elseif1", "cond", "repeatwhile", "repeatwith", "if", "begin", "end",
- "stmtlist", "expr", "func", "globallist", "gotofunc", "gotoframe",
- "gotomovie", "defn", "@1", "argdef", "argstore", "macro", "arglist", 0
+ "FLOAT", "BLTIN", "ID", "STRING", "HANDLER", "tDOWN", "tELSE", "tELSIF",
+ "tEND", "tEXIT", "tFRAME", "tGLOBAL", "tGO", "tIF", "tINTO", "tLOOP",
+ "tMACRO", "tMCI", "tMCIWAIT", "tMOVIE", "tNEXT", "tOF", "tPREVIOUS",
+ "tPUT", "tREPEAT", "tSET", "tTHEN", "tTO", "tWITH", "tWHILE", "tGE",
+ "tLE", "tGT", "tLT", "tEQ", "tNEQ", "'='", "'+'", "'-'", "'*'", "'/'",
+ "'%'", "'\\n'", "'('", "')'", "'>'", "'<'", "','", "$accept", "program",
+ "programline", "asgn", "stmt", "stmtoneliner", "ifstmt", "elseifstmt",
+ "elseifstmt1", "cond", "repeatwhile", "repeatwith", "if", "elseif",
+ "begin", "end", "stmtlist", "expr", "func", "globallist", "gotofunc",
+ "gotoframe", "gotomovie", "defn", "@1", "argdef", "argstore", "macro",
+ "arglist", 0
};
#endif
@@ -577,23 +580,23 @@ static const yytype_uint16 yytoknum[] =
265, 266, 267, 268, 269, 270, 271, 272, 273, 274,
275, 276, 277, 278, 279, 280, 281, 282, 283, 284,
285, 286, 287, 288, 289, 290, 291, 292, 293, 294,
- 295, 296, 297, 61, 43, 45, 42, 47, 37, 10,
- 40, 41, 62, 60, 44
+ 295, 296, 297, 298, 61, 43, 45, 42, 47, 37,
+ 10, 40, 41, 62, 60, 44
};
# endif
/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
static const yytype_uint8 yyr1[] =
{
- 0, 55, 56, 56, 57, 57, 57, 57, 57, 57,
- 57, 57, 58, 58, 58, 59, 59, 59, 59, 59,
- 59, 60, 61, 61, 61, 62, 62, 63, 64, 64,
- 64, 65, 66, 67, 68, 69, 70, 70, 70, 71,
- 71, 71, 71, 71, 71, 71, 71, 71, 71, 71,
- 71, 71, 71, 71, 71, 71, 71, 72, 72, 72,
- 72, 72, 72, 73, 73, 74, 74, 74, 74, 74,
- 74, 75, 75, 75, 75, 76, 76, 76, 78, 77,
- 79, 79, 79, 79, 80, 81, 82, 82, 82
+ 0, 56, 57, 57, 58, 58, 58, 58, 58, 58,
+ 58, 58, 59, 59, 59, 60, 60, 60, 60, 60,
+ 60, 61, 62, 62, 62, 63, 63, 64, 65, 65,
+ 65, 66, 67, 68, 69, 70, 71, 72, 72, 72,
+ 73, 73, 73, 73, 73, 73, 73, 73, 73, 73,
+ 73, 73, 73, 73, 73, 73, 73, 73, 74, 74,
+ 74, 74, 74, 74, 75, 75, 76, 76, 76, 76,
+ 76, 76, 77, 77, 77, 77, 78, 78, 78, 80,
+ 79, 81, 81, 81, 81, 82, 83, 84, 84, 84
};
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
@@ -601,13 +604,13 @@ static const yytype_uint8 yyr2[] =
{
0, 2, 3, 1, 0, 1, 1, 1, 1, 1,
1, 1, 4, 4, 4, 1, 1, 1, 8, 11,
- 12, 6, 7, 10, 10, 1, 3, 6, 1, 3,
- 3, 2, 3, 1, 0, 0, 0, 2, 2, 1,
- 1, 4, 4, 1, 1, 3, 3, 3, 3, 3,
- 3, 3, 3, 3, 2, 2, 3, 2, 2, 2,
- 1, 1, 2, 1, 3, 2, 2, 2, 2, 3,
- 2, 3, 2, 2, 1, 3, 2, 3, 0, 8,
- 0, 1, 3, 4, 0, 3, 0, 1, 3
+ 12, 6, 7, 10, 10, 2, 1, 4, 1, 3,
+ 3, 2, 3, 1, 1, 0, 0, 0, 2, 2,
+ 1, 1, 4, 4, 1, 1, 3, 3, 3, 3,
+ 3, 3, 3, 3, 3, 2, 2, 3, 2, 2,
+ 2, 1, 1, 2, 1, 3, 2, 2, 2, 2,
+ 3, 2, 3, 2, 2, 1, 3, 2, 3, 0,
+ 8, 0, 1, 3, 4, 0, 3, 0, 1, 3
};
/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
@@ -615,173 +618,171 @@ static const yytype_uint8 yyr2[] =
means the default is an error. */
static const yytype_uint8 yydefact[] =
{
- 0, 11, 39, 40, 0, 34, 61, 0, 0, 33,
+ 0, 11, 40, 41, 0, 35, 62, 0, 0, 33,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 3, 44, 10, 9, 17, 0, 0, 0, 15, 6,
- 60, 5, 7, 86, 86, 86, 63, 62, 74, 0,
- 65, 0, 66, 0, 67, 0, 68, 70, 78, 57,
- 58, 43, 0, 44, 59, 0, 31, 0, 54, 55,
+ 3, 45, 10, 9, 17, 0, 0, 0, 15, 6,
+ 61, 5, 7, 87, 87, 87, 64, 63, 75, 0,
+ 66, 0, 67, 0, 68, 0, 69, 71, 79, 58,
+ 59, 44, 0, 45, 60, 0, 31, 0, 55, 56,
0, 1, 0, 0, 0, 0, 0, 28, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 87, 0, 0,
- 85, 0, 72, 76, 0, 73, 0, 0, 0, 69,
- 34, 0, 0, 32, 0, 0, 56, 2, 0, 35,
- 0, 0, 34, 0, 52, 53, 51, 45, 46, 47,
- 48, 49, 50, 41, 0, 42, 64, 75, 71, 77,
- 80, 12, 14, 13, 36, 0, 30, 0, 35, 29,
- 88, 81, 0, 35, 0, 0, 35, 0, 16, 37,
- 38, 0, 84, 0, 0, 0, 35, 21, 0, 36,
- 0, 0, 0, 36, 82, 0, 35, 36, 36, 35,
- 22, 0, 35, 25, 83, 79, 18, 36, 35, 0,
- 0, 0, 0, 35, 0, 0, 0, 0, 26, 0,
- 0, 23, 36, 24, 0, 19, 35, 20, 27
+ 0, 0, 0, 0, 0, 0, 0, 88, 0, 0,
+ 86, 0, 73, 77, 0, 74, 0, 0, 0, 70,
+ 35, 0, 0, 32, 0, 0, 57, 2, 0, 36,
+ 0, 0, 35, 0, 53, 54, 52, 46, 47, 48,
+ 49, 50, 51, 42, 0, 43, 65, 76, 72, 78,
+ 81, 12, 14, 13, 37, 0, 30, 0, 36, 29,
+ 89, 82, 0, 36, 0, 0, 36, 0, 16, 38,
+ 39, 35, 85, 0, 0, 0, 36, 21, 0, 37,
+ 0, 0, 0, 37, 83, 0, 36, 37, 37, 36,
+ 22, 34, 36, 26, 0, 84, 80, 18, 37, 36,
+ 0, 0, 25, 0, 36, 0, 0, 0, 37, 0,
+ 0, 23, 24, 27, 0, 19, 20
};
/* YYDEFGOTO[NTERM-NUM]. */
static const yytype_int16 yydefgoto[] =
{
-1, 19, 20, 53, 140, 23, 24, 162, 163, 66,
- 25, 26, 137, 35, 125, 128, 28, 138, 37, 30,
- 46, 47, 31, 90, 132, 153, 32, 78
+ 25, 26, 137, 164, 35, 125, 128, 28, 138, 37,
+ 30, 46, 47, 31, 90, 132, 153, 32, 78
};
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */
-#define YYPACT_NINF -87
+#define YYPACT_NINF -84
static const yytype_int16 yypact[] =
{
- 126, -87, -87, -87, -43, 286, -87, -1, 88, -87,
- 16, 13, 51, 197, 17, 64, 197, 197, 197, 80,
- 33, 2, -87, -87, -87, 36, 45, 241, 274, -87,
- -87, -87, -87, 197, 197, 197, -87, 38, -87, 82,
- -87, 83, -87, 69, -87, 20, -7, -87, -87, -87,
- -87, 46, 197, -87, -3, 90, -87, -11, 130, 130,
- 250, -87, 126, 241, 197, 241, 70, 262, 197, 197,
- 197, 197, 197, 197, 197, 197, 197, 274, -18, -6,
- 48, 96, -87, -87, 100, -87, 108, 109, 95, -87,
- -87, -3, 113, -87, 197, 197, -87, -87, 73, 274,
- 74, 223, -9, 197, 274, 274, 274, 101, 101, 130,
- 130, 274, 274, -87, 197, -87, -87, -87, -87, -87,
- 118, -87, 274, 274, -87, 4, -87, 214, 170, 274,
- 274, -87, -29, 170, 107, 197, -87, 241, -87, -87,
- -87, 42, 75, 142, 140, 197, 274, -87, 127, -87,
- 139, 148, 153, -87, -87, 133, 274, -87, -87, 170,
- -87, 146, -87, 120, -87, 170, -87, -87, 170, 158,
- 241, 159, 148, 170, 166, 164, 152, 167, -87, 176,
- 161, -87, -87, -87, 162, -87, 170, -87, -87
+ 133, -84, -84, -84, -26, 273, -84, 22, 8, -84,
+ 43, 35, 79, 129, 47, 84, 129, 129, 129, 97,
+ 48, 15, -84, -84, -84, 49, 61, 161, 261, -84,
+ -84, -84, -84, 129, 129, 129, -84, 51, -84, 104,
+ -84, 105, -84, 90, -84, 6, 13, -84, -84, -84,
+ -84, 69, 129, -84, 65, 111, -84, -17, -9, -9,
+ 237, -84, 133, 161, 129, 161, 89, 249, 129, 129,
+ 129, 129, 129, 129, 129, 129, 129, 261, 23, 36,
+ 70, 116, -84, -84, 117, -84, 119, 120, 100, -84,
+ -84, 65, 125, -84, 129, 129, -84, -84, 92, 261,
+ 93, 219, -3, 129, 261, 261, 261, 198, 198, -9,
+ -9, 261, 261, -84, 129, -84, -84, -84, -84, -84,
+ 136, -84, 261, 261, -84, -12, -84, 223, 178, 261,
+ 261, -84, -1, 178, 112, 129, -84, 161, -84, -84,
+ -84, 63, 94, 138, 139, 129, 261, -84, 122, -84,
+ 140, 148, 157, -84, -84, 141, 261, -84, -84, 178,
+ -84, -84, -84, 148, 161, -84, 178, -84, -84, 178,
+ 156, 160, -84, 143, 178, 165, 168, 169, -84, 166,
+ 159, -84, -84, 178, 164, -84, -84
};
/* YYPGOTO[NTERM-NUM]. */
static const yytype_int16 yypgoto[] =
{
- -87, 134, -87, 14, 10, -87, -87, 25, -87, -62,
- -87, -87, 0, -86, -55, -70, -5, 15, -87, -87,
- -87, 157, -87, -87, -87, -87, -87, 50
+ -84, 131, -84, 7, 2, -84, -84, 37, -84, -57,
+ -84, -84, 9, -84, -74, -60, -83, -13, 10, -84,
+ -84, -84, 155, -84, -84, -84, -84, -84, 58
};
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
positive, shift that token. If negative, reduce the rule which
number is the opposite. If zero, do what YYDEFACT says.
If YYTABLE_NINF, syntax error. */
-#define YYTABLE_NINF -44
+#define YYTABLE_NINF -45
static const yytype_int16 yytable[] =
{
- 27, 98, -8, 100, 120, -36, -36, 33, 54, 36,
- 22, 58, 59, 60, 21, 29, 127, 134, 92, 41,
- 142, 43, 67, 94, 49, 143, 48, 88, 77, 77,
- 77, 85, 95, 113, 68, 69, 114, 86, 135, 70,
- -36, 71, 72, 73, 74, 115, 87, 91, 114, 75,
- 76, -8, 55, 56, 133, 151, 149, 150, 67, 99,
- 101, 50, 27, 104, 105, 106, 107, 108, 109, 110,
- 111, 112, 22, 141, 57, 148, 21, 29, 144, 159,
- 61, 147, 62, 165, 79, 80, 63, 168, 64, 122,
- 123, 157, 81, 82, 83, 84, 34, 173, 129, 38,
- 93, 167, 114, 102, 169, 39, 116, 171, 176, 130,
- 40, 117, 186, 174, 41, 42, 43, 44, 179, 118,
- 119, 87, 45, 121, 124, 126, -4, 1, 131, 152,
- 146, 188, 67, 2, 3, 4, 5, 136, 68, 69,
- 156, 145, 6, 70, 7, 8, 9, 73, 74, 10,
- 11, 12, 154, 75, 76, 155, 13, 14, 15, 160,
- 158, 170, 161, 164, 166, 67, 9, 68, 69, 172,
- 16, 17, 70, 175, 177, -4, 18, 2, 3, 4,
- 51, 180, 75, 76, 181, 182, 6, 183, 7, 8,
- 9, 184, 185, 187, 11, 12, 97, 178, 0, 0,
- 13, 14, 15, 89, 2, 3, 4, 51, 0, 0,
- 0, 0, 0, 0, 16, 17, 0, 0, 0, 139,
- 18, 2, 3, 4, 51, 0, 0, 52, 0, 15,
- 6, 0, 7, 8, 9, 0, 0, 0, 11, 12,
- 0, 16, 17, 0, 13, 14, 15, 18, 2, 3,
- 4, 51, 0, 0, 0, 0, 0, 0, 16, 17,
- 68, 69, 0, 0, 18, 70, 103, 71, 72, 73,
- 74, 52, 0, 15, 96, 75, 76, 0, 0, 0,
- 0, 0, 0, 0, 0, 16, 17, 68, 69, 0,
- 0, 65, 70, 0, 71, 72, 73, 74, 0, 68,
- 69, 96, 75, 76, 70, 103, 71, 72, 73, 74,
- 0, 68, 69, 0, 75, 76, 70, 0, 71, 72,
- 73, 74, 0, -43, -43, 0, 75, 76, -43, 0,
- 0, 0, -43, -43, 0, 0, 34, 0, -43, -43
+ 54, 134, 22, 58, 59, 60, 98, 21, 100, 27,
+ 29, -37, -37, -37, 67, -8, 120, 85, 94, 38,
+ 77, 77, 77, 135, 86, 33, 39, 95, 127, 68,
+ 69, 40, 36, 87, 70, 41, 42, 43, 44, 91,
+ 41, 133, 43, 45, 75, 76, 49, -37, 88, 142,
+ 67, 99, 101, 48, 143, 104, 105, 106, 107, 108,
+ 109, 110, 111, 112, 22, -8, 159, 151, 141, 21,
+ 166, 27, 29, 144, 169, 113, 147, 149, 114, 150,
+ 148, 122, 123, 55, 56, 174, 157, 92, 115, 50,
+ 129, 114, 79, 80, 57, 183, 168, 61, 62, 170,
+ 63, 130, 171, 68, 69, 64, 81, 173, 70, 175,
+ 71, 72, 73, 74, 179, 82, 83, 84, 75, 76,
+ 34, 93, 146, 102, 67, 114, 116, 87, 117, 136,
+ 118, 119, 156, -4, 1, 121, 2, 3, 4, 51,
+ 2, 3, 4, 5, 124, 126, 131, 145, 154, 152,
+ 6, 67, 7, 8, 9, 155, 158, 10, 11, 12,
+ 52, 160, 15, 161, 13, 14, 15, 165, 2, 3,
+ 4, 51, 176, 167, 16, 17, 177, 178, 16, 17,
+ 18, 180, 184, -4, 18, 2, 3, 4, 51, 181,
+ 182, 185, 52, 97, 15, 6, 186, 7, 8, 9,
+ 172, 89, 0, 11, 12, 0, 16, 17, 0, 13,
+ 14, 15, 65, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 16, 17, 0, 0, 0, 139, 18,
+ 2, 3, 4, 51, 0, 0, 68, 69, 0, 0,
+ 6, 70, 7, 8, 9, 73, 74, 0, 11, 12,
+ 0, 75, 76, 0, 13, 14, 15, 68, 69, 0,
+ 0, 0, 70, 103, 71, 72, 73, 74, 16, 17,
+ 0, 96, 75, 76, 18, 68, 69, 0, 0, 0,
+ 70, 0, 71, 72, 73, 74, 0, 68, 69, 96,
+ 75, 76, 70, 103, 71, 72, 73, 74, 0, 68,
+ 69, 0, 75, 76, 70, 0, 71, 72, 73, 74,
+ 0, -44, -44, 0, 75, 76, -44, 0, 0, 0,
+ -44, -44, 0, 0, 34, 0, -44, -44
};
static const yytype_int16 yycheck[] =
{
- 0, 63, 0, 65, 90, 14, 15, 50, 13, 10,
- 0, 16, 17, 18, 0, 0, 102, 13, 21, 26,
- 49, 28, 27, 34, 11, 54, 10, 34, 33, 34,
- 35, 11, 43, 51, 37, 38, 54, 17, 34, 42,
- 49, 44, 45, 46, 47, 51, 26, 52, 54, 52,
- 53, 49, 35, 36, 124, 141, 14, 15, 63, 64,
- 65, 10, 62, 68, 69, 70, 71, 72, 73, 74,
- 75, 76, 62, 128, 10, 137, 62, 62, 133, 149,
- 0, 136, 49, 153, 34, 35, 50, 157, 43, 94,
- 95, 146, 54, 11, 11, 26, 50, 167, 103, 11,
- 10, 156, 54, 33, 159, 17, 10, 162, 170, 114,
- 22, 11, 182, 168, 26, 27, 28, 29, 173, 11,
- 11, 26, 34, 10, 51, 51, 0, 1, 10, 54,
- 135, 186, 137, 7, 8, 9, 10, 127, 37, 38,
- 145, 34, 16, 42, 18, 19, 20, 46, 47, 23,
- 24, 25, 10, 52, 53, 15, 30, 31, 32, 20,
- 33, 161, 14, 10, 31, 170, 20, 37, 38, 49,
- 44, 45, 42, 15, 15, 49, 50, 7, 8, 9,
- 10, 15, 52, 53, 20, 33, 16, 20, 18, 19,
- 20, 15, 31, 31, 24, 25, 62, 172, -1, -1,
- 30, 31, 32, 46, 7, 8, 9, 10, -1, -1,
- -1, -1, -1, -1, 44, 45, -1, -1, -1, 49,
- 50, 7, 8, 9, 10, -1, -1, 30, -1, 32,
- 16, -1, 18, 19, 20, -1, -1, -1, 24, 25,
- -1, 44, 45, -1, 30, 31, 32, 50, 7, 8,
- 9, 10, -1, -1, -1, -1, -1, -1, 44, 45,
- 37, 38, -1, -1, 50, 42, 43, 44, 45, 46,
- 47, 30, -1, 32, 51, 52, 53, -1, -1, -1,
- -1, -1, -1, -1, -1, 44, 45, 37, 38, -1,
- -1, 50, 42, -1, 44, 45, 46, 47, -1, 37,
- 38, 51, 52, 53, 42, 43, 44, 45, 46, 47,
- -1, 37, 38, -1, 52, 53, 42, -1, 44, 45,
- 46, 47, -1, 37, 38, -1, 52, 53, 42, -1,
- -1, -1, 46, 47, -1, -1, 50, -1, 52, 53
+ 13, 13, 0, 16, 17, 18, 63, 0, 65, 0,
+ 0, 14, 15, 16, 27, 0, 90, 11, 35, 11,
+ 33, 34, 35, 35, 18, 51, 18, 44, 102, 38,
+ 39, 23, 10, 27, 43, 27, 28, 29, 30, 52,
+ 27, 124, 29, 35, 53, 54, 11, 50, 35, 50,
+ 63, 64, 65, 10, 55, 68, 69, 70, 71, 72,
+ 73, 74, 75, 76, 62, 50, 149, 141, 128, 62,
+ 153, 62, 62, 133, 157, 52, 136, 14, 55, 16,
+ 137, 94, 95, 36, 37, 168, 146, 22, 52, 10,
+ 103, 55, 34, 35, 10, 178, 156, 0, 50, 159,
+ 51, 114, 162, 38, 39, 44, 55, 164, 43, 169,
+ 45, 46, 47, 48, 174, 11, 11, 27, 53, 54,
+ 51, 10, 135, 34, 137, 55, 10, 27, 11, 127,
+ 11, 11, 145, 0, 1, 10, 7, 8, 9, 10,
+ 7, 8, 9, 10, 52, 52, 10, 35, 10, 55,
+ 17, 164, 19, 20, 21, 16, 34, 24, 25, 26,
+ 31, 21, 33, 15, 31, 32, 33, 10, 7, 8,
+ 9, 10, 16, 32, 45, 46, 16, 34, 45, 46,
+ 51, 16, 16, 50, 51, 7, 8, 9, 10, 21,
+ 21, 32, 31, 62, 33, 17, 32, 19, 20, 21,
+ 163, 46, -1, 25, 26, -1, 45, 46, -1, 31,
+ 32, 33, 51, -1, -1, -1, -1, -1, -1, -1,
+ -1, -1, -1, 45, 46, -1, -1, -1, 50, 51,
+ 7, 8, 9, 10, -1, -1, 38, 39, -1, -1,
+ 17, 43, 19, 20, 21, 47, 48, -1, 25, 26,
+ -1, 53, 54, -1, 31, 32, 33, 38, 39, -1,
+ -1, -1, 43, 44, 45, 46, 47, 48, 45, 46,
+ -1, 52, 53, 54, 51, 38, 39, -1, -1, -1,
+ 43, -1, 45, 46, 47, 48, -1, 38, 39, 52,
+ 53, 54, 43, 44, 45, 46, 47, 48, -1, 38,
+ 39, -1, 53, 54, 43, -1, 45, 46, 47, 48,
+ -1, 38, 39, -1, 53, 54, 43, -1, -1, -1,
+ 47, 48, -1, -1, 51, -1, 53, 54
};
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
symbol of state STATE-NUM. */
static const yytype_uint8 yystos[] =
{
- 0, 1, 7, 8, 9, 10, 16, 18, 19, 20,
- 23, 24, 25, 30, 31, 32, 44, 45, 50, 56,
- 57, 58, 59, 60, 61, 65, 66, 67, 71, 72,
- 74, 77, 81, 50, 50, 68, 10, 73, 11, 17,
- 22, 26, 27, 28, 29, 34, 75, 76, 10, 11,
- 10, 10, 30, 58, 71, 35, 36, 10, 71, 71,
- 71, 0, 49, 50, 43, 50, 64, 71, 37, 38,
- 42, 44, 45, 46, 47, 52, 53, 71, 82, 82,
- 82, 54, 11, 11, 26, 11, 17, 26, 34, 76,
- 78, 71, 21, 10, 34, 43, 51, 56, 64, 71,
- 64, 71, 33, 43, 71, 71, 71, 71, 71, 71,
- 71, 71, 71, 51, 54, 51, 10, 11, 11, 11,
- 68, 10, 71, 71, 51, 69, 51, 68, 70, 71,
- 71, 10, 79, 70, 13, 34, 59, 67, 72, 49,
- 59, 69, 49, 54, 69, 34, 71, 69, 64, 14,
- 15, 68, 54, 80, 10, 15, 71, 69, 33, 70,
- 20, 14, 62, 63, 10, 70, 31, 69, 70, 69,
- 67, 69, 49, 70, 69, 15, 64, 15, 62, 69,
- 15, 20, 33, 20, 15, 31, 70, 31, 69
+ 0, 1, 7, 8, 9, 10, 17, 19, 20, 21,
+ 24, 25, 26, 31, 32, 33, 45, 46, 51, 57,
+ 58, 59, 60, 61, 62, 66, 67, 68, 73, 74,
+ 76, 79, 83, 51, 51, 70, 10, 75, 11, 18,
+ 23, 27, 28, 29, 30, 35, 77, 78, 10, 11,
+ 10, 10, 31, 59, 73, 36, 37, 10, 73, 73,
+ 73, 0, 50, 51, 44, 51, 65, 73, 38, 39,
+ 43, 45, 46, 47, 48, 53, 54, 73, 84, 84,
+ 84, 55, 11, 11, 27, 11, 18, 27, 35, 78,
+ 80, 73, 22, 10, 35, 44, 52, 57, 65, 73,
+ 65, 73, 34, 44, 73, 73, 73, 73, 73, 73,
+ 73, 73, 73, 52, 55, 52, 10, 11, 11, 11,
+ 70, 10, 73, 73, 52, 71, 52, 70, 72, 73,
+ 73, 10, 81, 72, 13, 35, 60, 68, 74, 50,
+ 60, 71, 50, 55, 71, 35, 73, 71, 65, 14,
+ 16, 70, 55, 82, 10, 16, 73, 71, 34, 72,
+ 21, 15, 63, 64, 69, 10, 72, 32, 71, 72,
+ 71, 71, 63, 65, 72, 71, 16, 16, 34, 71,
+ 16, 21, 21, 72, 16, 32, 32
};
#define yyerrok (yyerrstatus = 0)
@@ -1730,12 +1731,12 @@ yyreduce:
#line 210 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, else1 = 0, end = 0;
- WRITE_UINT32(&then, (yyvsp[(5) - (6)].code));
- WRITE_UINT32(&else1, (yyvsp[(6) - (6)].code));
+ WRITE_UINT32(&then, (yyvsp[(4) - (4)].code));
+ WRITE_UINT32(&else1, 0);
WRITE_UINT32(&end, 0);
- (*g_lingo->_currentScript)[(yyvsp[(2) - (6)].code) + 1] = then; /* thenpart */
- (*g_lingo->_currentScript)[(yyvsp[(2) - (6)].code) + 2] = else1; /* elsepart */
- (*g_lingo->_currentScript)[(yyvsp[(2) - (6)].code) + 3] = end; ;}
+ (*g_lingo->_currentScript)[(yyvsp[(2) - (4)].code) + 1] = then; /* thenpart */
+ (*g_lingo->_currentScript)[(yyvsp[(2) - (4)].code) + 2] = else1; /* elsepart */
+ (*g_lingo->_currentScript)[(yyvsp[(2) - (4)].code) + 3] = end; ;}
break;
case 28:
@@ -1769,21 +1770,26 @@ yyreduce:
case 34:
#line 234 "engines/director/lingo/lingo-gr.y"
- { (yyval.code) = g_lingo->_currentScript->size(); ;}
+ { (yyval.code) = g_lingo->code1(g_lingo->c_ifcode); g_lingo->code3(STOP, STOP, STOP); ;}
break;
case 35:
#line 236 "engines/director/lingo/lingo-gr.y"
- { g_lingo->code1(STOP); (yyval.code) = g_lingo->_currentScript->size(); ;}
+ { (yyval.code) = g_lingo->_currentScript->size(); ;}
break;
case 36:
#line 238 "engines/director/lingo/lingo-gr.y"
+ { g_lingo->code1(STOP); (yyval.code) = g_lingo->_currentScript->size(); ;}
+ break;
+
+ case 37:
+#line 240 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = g_lingo->_currentScript->size(); ;}
break;
- case 39:
-#line 243 "engines/director/lingo/lingo-gr.y"
+ case 40:
+#line 245 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_constpush);
inst i = 0;
@@ -1791,15 +1797,15 @@ yyreduce:
g_lingo->code1(i); ;}
break;
- case 40:
-#line 248 "engines/director/lingo/lingo-gr.y"
+ case 41:
+#line 250 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_fconstpush);
g_lingo->codeFloat((yyvsp[(1) - (1)].f)); ;}
break;
- case 41:
-#line 251 "engines/director/lingo/lingo-gr.y"
+ case 42:
+#line 253 "engines/director/lingo/lingo-gr.y"
{
if ((yyvsp[(3) - (4)].narg) != g_lingo->_builtins[*(yyvsp[(1) - (4)].s)]->nargs)
error("Built-in function %s expects %d arguments but got %d", (yyvsp[(1) - (4)].s)->c_str(), g_lingo->_builtins[*(yyvsp[(1) - (4)].s)]->nargs, (yyvsp[(3) - (4)].narg));
@@ -1808,8 +1814,8 @@ yyreduce:
delete (yyvsp[(1) - (4)].s); ;}
break;
- case 42:
-#line 257 "engines/director/lingo/lingo-gr.y"
+ case 43:
+#line 259 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_call);
g_lingo->codeString((yyvsp[(1) - (4)].s)->c_str());
@@ -1820,121 +1826,121 @@ yyreduce:
delete (yyvsp[(1) - (4)].s); ;}
break;
- case 43:
-#line 265 "engines/director/lingo/lingo-gr.y"
+ case 44:
+#line 267 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->codeId(*(yyvsp[(1) - (1)].s));
delete (yyvsp[(1) - (1)].s); ;}
break;
- case 45:
-#line 269 "engines/director/lingo/lingo-gr.y"
+ case 46:
+#line 271 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_add); ;}
break;
- case 46:
-#line 270 "engines/director/lingo/lingo-gr.y"
+ case 47:
+#line 272 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_sub); ;}
break;
- case 47:
-#line 271 "engines/director/lingo/lingo-gr.y"
+ case 48:
+#line 273 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_mul); ;}
break;
- case 48:
-#line 272 "engines/director/lingo/lingo-gr.y"
+ case 49:
+#line 274 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_div); ;}
break;
- case 49:
-#line 273 "engines/director/lingo/lingo-gr.y"
+ case 50:
+#line 275 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gt); ;}
break;
- case 50:
-#line 274 "engines/director/lingo/lingo-gr.y"
+ case 51:
+#line 276 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_lt); ;}
break;
- case 51:
-#line 275 "engines/director/lingo/lingo-gr.y"
+ case 52:
+#line 277 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_neq); ;}
break;
- case 52:
-#line 276 "engines/director/lingo/lingo-gr.y"
+ case 53:
+#line 278 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_ge); ;}
break;
- case 53:
-#line 277 "engines/director/lingo/lingo-gr.y"
+ case 54:
+#line 279 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_le); ;}
break;
- case 54:
-#line 278 "engines/director/lingo/lingo-gr.y"
+ case 55:
+#line 280 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (2)].code); ;}
break;
- case 55:
-#line 279 "engines/director/lingo/lingo-gr.y"
+ case 56:
+#line 281 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (2)].code); g_lingo->code1(g_lingo->c_negate); ;}
break;
- case 56:
-#line 280 "engines/director/lingo/lingo-gr.y"
+ case 57:
+#line 282 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (3)].code); ;}
break;
- case 57:
-#line 283 "engines/director/lingo/lingo-gr.y"
+ case 58:
+#line 285 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_mci); g_lingo->codeString((yyvsp[(2) - (2)].s)->c_str()); delete (yyvsp[(2) - (2)].s); ;}
break;
- case 58:
-#line 284 "engines/director/lingo/lingo-gr.y"
+ case 59:
+#line 286 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_mciwait); g_lingo->codeString((yyvsp[(2) - (2)].s)->c_str()); delete (yyvsp[(2) - (2)].s); ;}
break;
- case 59:
-#line 285 "engines/director/lingo/lingo-gr.y"
+ case 60:
+#line 287 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_printtop); ;}
break;
- case 61:
-#line 287 "engines/director/lingo/lingo-gr.y"
+ case 62:
+#line 289 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code2(g_lingo->c_constpush, (inst)0); // Push fake value on stack
g_lingo->code1(g_lingo->c_procret); ;}
break;
- case 63:
-#line 292 "engines/director/lingo/lingo-gr.y"
+ case 64:
+#line 294 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_global); g_lingo->codeString((yyvsp[(1) - (1)].s)->c_str()); delete (yyvsp[(1) - (1)].s); ;}
break;
- case 64:
-#line 293 "engines/director/lingo/lingo-gr.y"
+ case 65:
+#line 295 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_global); g_lingo->codeString((yyvsp[(3) - (3)].s)->c_str()); delete (yyvsp[(3) - (3)].s); ;}
break;
- case 65:
-#line 304 "engines/director/lingo/lingo-gr.y"
+ case 66:
+#line 306 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotoloop); ;}
break;
- case 66:
-#line 305 "engines/director/lingo/lingo-gr.y"
+ case 67:
+#line 307 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotonext); ;}
break;
- case 67:
-#line 306 "engines/director/lingo/lingo-gr.y"
+ case 68:
+#line 308 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotoprevious); ;}
break;
- case 68:
-#line 307 "engines/director/lingo/lingo-gr.y"
+ case 69:
+#line 309 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString((yyvsp[(2) - (2)].s)->c_str());
@@ -1942,8 +1948,8 @@ yyreduce:
delete (yyvsp[(2) - (2)].s); ;}
break;
- case 69:
-#line 312 "engines/director/lingo/lingo-gr.y"
+ case 70:
+#line 314 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString((yyvsp[(2) - (3)].s)->c_str());
@@ -1952,8 +1958,8 @@ yyreduce:
delete (yyvsp[(3) - (3)].s); ;}
break;
- case 70:
-#line 318 "engines/director/lingo/lingo-gr.y"
+ case 71:
+#line 320 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString("");
@@ -1961,48 +1967,48 @@ yyreduce:
delete (yyvsp[(2) - (2)].s); ;}
break;
- case 71:
-#line 325 "engines/director/lingo/lingo-gr.y"
+ case 72:
+#line 327 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 72:
-#line 326 "engines/director/lingo/lingo-gr.y"
+ case 73:
+#line 328 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 73:
-#line 327 "engines/director/lingo/lingo-gr.y"
+ case 74:
+#line 329 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 74:
-#line 328 "engines/director/lingo/lingo-gr.y"
+ case 75:
+#line 330 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(1) - (1)].s); ;}
break;
- case 75:
-#line 331 "engines/director/lingo/lingo-gr.y"
+ case 76:
+#line 333 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 76:
-#line 332 "engines/director/lingo/lingo-gr.y"
+ case 77:
+#line 334 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 77:
-#line 333 "engines/director/lingo/lingo-gr.y"
+ case 78:
+#line 335 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 78:
-#line 361 "engines/director/lingo/lingo-gr.y"
+ case 79:
+#line 363 "engines/director/lingo/lingo-gr.y"
{ g_lingo->_indef = true; ;}
break;
- case 79:
-#line 362 "engines/director/lingo/lingo-gr.y"
+ case 80:
+#line 364 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code2(g_lingo->c_constpush, (inst)0); // Push fake value on stack
g_lingo->code1(g_lingo->c_procret);
@@ -2010,33 +2016,33 @@ yyreduce:
g_lingo->_indef = false; ;}
break;
- case 80:
-#line 368 "engines/director/lingo/lingo-gr.y"
+ case 81:
+#line 370 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 0; ;}
break;
- case 81:
-#line 369 "engines/director/lingo/lingo-gr.y"
+ case 82:
+#line 371 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg((yyvsp[(1) - (1)].s)); (yyval.narg) = 1; ;}
break;
- case 82:
-#line 370 "engines/director/lingo/lingo-gr.y"
+ case 83:
+#line 372 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg((yyvsp[(3) - (3)].s)); (yyval.narg) = (yyvsp[(1) - (3)].narg) + 1; ;}
break;
- case 83:
-#line 371 "engines/director/lingo/lingo-gr.y"
+ case 84:
+#line 373 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg((yyvsp[(4) - (4)].s)); (yyval.narg) = (yyvsp[(1) - (4)].narg) + 1; ;}
break;
- case 84:
-#line 373 "engines/director/lingo/lingo-gr.y"
+ case 85:
+#line 375 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArgStore(); ;}
break;
- case 85:
-#line 376 "engines/director/lingo/lingo-gr.y"
+ case 86:
+#line 378 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_call);
g_lingo->codeString((yyvsp[(1) - (3)].s)->c_str());
@@ -2045,24 +2051,24 @@ yyreduce:
g_lingo->code1(numpar); ;}
break;
- case 86:
-#line 384 "engines/director/lingo/lingo-gr.y"
+ case 87:
+#line 386 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 0; ;}
break;
- case 87:
-#line 385 "engines/director/lingo/lingo-gr.y"
+ case 88:
+#line 387 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 1; ;}
break;
- case 88:
-#line 386 "engines/director/lingo/lingo-gr.y"
+ case 89:
+#line 388 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = (yyvsp[(1) - (3)].narg) + 1; ;}
break;
/* Line 1267 of yacc.c. */
-#line 2066 "engines/director/lingo/lingo-gr.cpp"
+#line 2072 "engines/director/lingo/lingo-gr.cpp"
default: break;
}
YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
@@ -2276,6 +2282,6 @@ yyreturn:
}
-#line 389 "engines/director/lingo/lingo-gr.y"
+#line 391 "engines/director/lingo/lingo-gr.y"
diff --git a/engines/director/lingo/lingo-gr.h b/engines/director/lingo/lingo-gr.h
index 2aff182464..4216ad6d2e 100644
--- a/engines/director/lingo/lingo-gr.h
+++ b/engines/director/lingo/lingo-gr.h
@@ -51,34 +51,35 @@
HANDLER = 267,
tDOWN = 268,
tELSE = 269,
- tEND = 270,
- tEXIT = 271,
- tFRAME = 272,
- tGLOBAL = 273,
- tGO = 274,
- tIF = 275,
- tINTO = 276,
- tLOOP = 277,
- tMACRO = 278,
- tMCI = 279,
- tMCIWAIT = 280,
- tMOVIE = 281,
- tNEXT = 282,
- tOF = 283,
- tPREVIOUS = 284,
- tPUT = 285,
- tREPEAT = 286,
- tSET = 287,
- tTHEN = 288,
- tTO = 289,
- tWITH = 290,
- tWHILE = 291,
- tGE = 292,
- tLE = 293,
- tGT = 294,
- tLT = 295,
- tEQ = 296,
- tNEQ = 297
+ tELSIF = 270,
+ tEND = 271,
+ tEXIT = 272,
+ tFRAME = 273,
+ tGLOBAL = 274,
+ tGO = 275,
+ tIF = 276,
+ tINTO = 277,
+ tLOOP = 278,
+ tMACRO = 279,
+ tMCI = 280,
+ tMCIWAIT = 281,
+ tMOVIE = 282,
+ tNEXT = 283,
+ tOF = 284,
+ tPREVIOUS = 285,
+ tPUT = 286,
+ tREPEAT = 287,
+ tSET = 288,
+ tTHEN = 289,
+ tTO = 290,
+ tWITH = 291,
+ tWHILE = 292,
+ tGE = 293,
+ tLE = 294,
+ tGT = 295,
+ tLT = 296,
+ tEQ = 297,
+ tNEQ = 298
};
#endif
/* Tokens. */
@@ -94,34 +95,35 @@
#define HANDLER 267
#define tDOWN 268
#define tELSE 269
-#define tEND 270
-#define tEXIT 271
-#define tFRAME 272
-#define tGLOBAL 273
-#define tGO 274
-#define tIF 275
-#define tINTO 276
-#define tLOOP 277
-#define tMACRO 278
-#define tMCI 279
-#define tMCIWAIT 280
-#define tMOVIE 281
-#define tNEXT 282
-#define tOF 283
-#define tPREVIOUS 284
-#define tPUT 285
-#define tREPEAT 286
-#define tSET 287
-#define tTHEN 288
-#define tTO 289
-#define tWITH 290
-#define tWHILE 291
-#define tGE 292
-#define tLE 293
-#define tGT 294
-#define tLT 295
-#define tEQ 296
-#define tNEQ 297
+#define tELSIF 270
+#define tEND 271
+#define tEXIT 272
+#define tFRAME 273
+#define tGLOBAL 274
+#define tGO 275
+#define tIF 276
+#define tINTO 277
+#define tLOOP 278
+#define tMACRO 279
+#define tMCI 280
+#define tMCIWAIT 281
+#define tMOVIE 282
+#define tNEXT 283
+#define tOF 284
+#define tPREVIOUS 285
+#define tPUT 286
+#define tREPEAT 287
+#define tSET 288
+#define tTHEN 289
+#define tTO 290
+#define tWITH 291
+#define tWHILE 292
+#define tGE 293
+#define tLE 294
+#define tGT 295
+#define tLT 296
+#define tEQ 297
+#define tNEQ 298
@@ -137,7 +139,7 @@ typedef union YYSTYPE
int narg; /* number of arguments */
}
/* Line 1529 of yacc.c. */
-#line 141 "engines/director/lingo/lingo-gr.hpp"
+#line 143 "engines/director/lingo/lingo-gr.hpp"
YYSTYPE;
# define yystype YYSTYPE /* obsolescent; will be withdrawn */
# define YYSTYPE_IS_DECLARED 1
diff --git a/engines/director/lingo/lingo-gr.y b/engines/director/lingo/lingo-gr.y
index de153b9bdc..35d589b782 100644
--- a/engines/director/lingo/lingo-gr.y
+++ b/engines/director/lingo/lingo-gr.y
@@ -74,11 +74,11 @@ using namespace Director;
%token<i> INT
%token<f> FLOAT
%token<s> BLTIN ID STRING HANDLER
-%token tDOWN tELSE tEND tEXIT tFRAME tGLOBAL tGO tIF tINTO tLOOP tMACRO tMCI tMCIWAIT
+%token tDOWN tELSE tELSIF tEND tEXIT tFRAME tGLOBAL tGO tIF tINTO tLOOP tMACRO tMCI tMCIWAIT
%token tMOVIE tNEXT tOF tPREVIOUS tPUT tREPEAT tSET tTHEN tTO tWITH tWHILE
%token tGE tLE tGT tLT tEQ tNEQ
-%type<code> asgn begin cond end expr if repeatwhile repeatwith stmtlist
+%type<code> asgn begin cond elseif end expr if repeatwhile repeatwith stmtlist
%type<s> gotoframe gotomovie
%type<narg> argdef arglist
@@ -193,7 +193,7 @@ ifstmt: if cond tTHEN stmtlist end tEND tIF {
(*g_lingo->_currentScript)[$1 + 1] = then; /* thenpart */
(*g_lingo->_currentScript)[$1 + 2] = else1; /* elsepart */
(*g_lingo->_currentScript)[$1 + 3] = end; } /* end, if cond fails */
- | if cond tTHEN stmtlist end begin elseif end tEND tIF {
+ | if cond tTHEN stmtlist end begin elseifstmt end tEND tIF {
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, $4);
WRITE_UINT32(&else1, $6);
@@ -203,14 +203,14 @@ ifstmt: if cond tTHEN stmtlist end tEND tIF {
(*g_lingo->_currentScript)[$1 + 3] = end; } /* end, if cond fails */
;
-elseif: elseif1
- | elseif1 '\n' elseif
+elseifstmt: elseifstmt1 elseifstmt
+ | elseifstmt1
;
-elseif1: tELSE if cond tTHEN stmtlist end {
+elseifstmt1: elseif cond tTHEN stmtlist {
inst then = 0, else1 = 0, end = 0;
- WRITE_UINT32(&then, $5);
- WRITE_UINT32(&else1, $6);
+ WRITE_UINT32(&then, $4);
+ WRITE_UINT32(&else1, 0);
WRITE_UINT32(&end, 0);
(*g_lingo->_currentScript)[$2 + 1] = then; /* thenpart */
(*g_lingo->_currentScript)[$2 + 2] = else1; /* elsepart */
@@ -229,7 +229,9 @@ repeatwith: tREPEAT tWITH ID {
g_lingo->codeString($3->c_str());
delete $3; }
;
-if: tIF { $$ = g_lingo->code1(g_lingo->c_ifcode); g_lingo->code3(STOP, STOP, STOP); }
+if: tIF { $$ = g_lingo->code1(g_lingo->c_ifcode); g_lingo->code3(STOP, STOP, STOP); }
+ ;
+elseif: tELSIF { $$ = g_lingo->code1(g_lingo->c_ifcode); g_lingo->code3(STOP, STOP, STOP); }
;
begin: /* nothing */ { $$ = g_lingo->_currentScript->size(); }
;
diff --git a/engines/director/lingo/lingo-lex.cpp b/engines/director/lingo/lingo-lex.cpp
index bd84f79d7b..bbe427579a 100644
--- a/engines/director/lingo/lingo-lex.cpp
+++ b/engines/director/lingo/lingo-lex.cpp
@@ -364,8 +364,8 @@ static void yy_fatal_error (yyconst char msg[] );
*yy_cp = '\0'; \
(yy_c_buf_p) = yy_cp;
-#define YY_NUM_RULES 38
-#define YY_END_OF_BUFFER 39
+#define YY_NUM_RULES 39
+#define YY_END_OF_BUFFER 40
/* This struct is not used in this scanner,
but its presence is necessary. */
struct yy_trans_info
@@ -373,21 +373,22 @@ struct yy_trans_info
flex_int32_t yy_verify;
flex_int32_t yy_nxt;
};
-static yyconst flex_int16_t yy_accept[121] =
+static yyconst flex_int16_t yy_accept[124] =
{ 0,
- 0, 0, 39, 37, 3, 35, 35, 37, 37, 37,
- 34, 34, 33, 34, 34, 31, 31, 31, 31, 31,
- 31, 31, 31, 31, 31, 31, 31, 31, 31, 31,
- 2, 2, 3, 35, 0, 28, 0, 36, 1, 32,
- 33, 30, 29, 31, 31, 31, 31, 31, 31, 31,
- 11, 5, 31, 31, 31, 31, 31, 31, 19, 31,
- 31, 31, 31, 31, 25, 31, 31, 1, 32, 31,
- 31, 7, 31, 31, 31, 31, 31, 31, 15, 31,
- 31, 31, 21, 31, 23, 31, 31, 31, 4, 6,
- 8, 31, 31, 12, 13, 31, 31, 31, 18, 31,
-
- 31, 24, 31, 26, 9, 31, 14, 31, 17, 31,
- 31, 27, 10, 31, 31, 22, 16, 31, 20, 0
+ 0, 0, 40, 38, 3, 36, 36, 38, 38, 38,
+ 35, 35, 34, 35, 35, 32, 32, 32, 32, 32,
+ 32, 32, 32, 32, 32, 32, 32, 32, 32, 32,
+ 2, 2, 3, 36, 0, 29, 0, 37, 1, 33,
+ 34, 31, 30, 32, 32, 32, 32, 32, 32, 32,
+ 12, 5, 32, 32, 32, 32, 32, 32, 20, 32,
+ 32, 32, 32, 32, 26, 32, 32, 1, 33, 32,
+ 32, 8, 32, 32, 32, 32, 32, 32, 16, 32,
+ 32, 32, 22, 32, 24, 32, 32, 32, 4, 7,
+ 9, 32, 32, 13, 14, 32, 32, 32, 19, 32,
+
+ 32, 25, 32, 27, 0, 10, 32, 15, 32, 18,
+ 32, 32, 28, 0, 11, 32, 32, 23, 6, 17,
+ 32, 21, 0
} ;
static yyconst flex_int32_t yy_ec[256] =
@@ -432,43 +433,43 @@ static yyconst flex_int32_t yy_meta[58] =
4, 4, 4, 4, 4, 4, 4
} ;
-static yyconst flex_int16_t yy_base[124] =
+static yyconst flex_int16_t yy_base[127] =
{ 0,
- 0, 56, 244, 270, 60, 56, 63, 66, 230, 235,
- 270, 232, 62, 155, 145, 0, 46, 50, 46, 53,
+ 0, 56, 250, 287, 60, 56, 63, 66, 236, 241,
+ 287, 236, 62, 228, 203, 0, 46, 50, 46, 53,
62, 51, 75, 64, 64, 78, 68, 72, 93, 94,
- 123, 131, 141, 90, 145, 270, 116, 270, 0, 111,
- 108, 270, 270, 0, 45, 89, 112, 108, 125, 123,
+ 123, 131, 141, 90, 145, 287, 161, 287, 0, 147,
+ 108, 287, 287, 0, 45, 89, 112, 108, 125, 123,
0, 0, 122, 127, 139, 134, 125, 124, 0, 142,
- 131, 135, 133, 147, 0, 144, 137, 0, 77, 143,
+ 131, 135, 133, 147, 0, 144, 137, 0, 112, 143,
152, 0, 141, 148, 161, 154, 158, 162, 161, 174,
- 168, 167, 0, 179, 0, 175, 179, 183, 0, 0,
+ 168, 167, 0, 179, 0, 175, 179, 183, 0, 83,
0, 187, 192, 0, 0, 181, 195, 192, 0, 189,
- 199, 0, 196, 0, 0, 193, 0, 193, 0, 196,
- 194, 0, 0, 199, 202, 0, 0, 209, 0, 270,
- 261, 81, 265
+ 199, 0, 196, 0, 233, 0, 193, 0, 201, 0,
+ 198, 199, 0, 220, 0, 210, 210, 0, 287, 0,
+ 213, 0, 287, 278, 118, 282
} ;
-static yyconst flex_int16_t yy_def[124] =
+static yyconst flex_int16_t yy_def[127] =
{ 0,
- 120, 1, 120, 120, 120, 120, 120, 120, 120, 121,
- 120, 120, 120, 120, 120, 122, 122, 122, 122, 122,
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 122,
- 120, 120, 120, 120, 120, 120, 121, 120, 123, 120,
- 120, 120, 120, 122, 122, 122, 122, 122, 122, 122,
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 122,
- 122, 122, 122, 122, 122, 122, 122, 123, 120, 122,
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 122,
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 122,
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 122,
-
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 122,
- 122, 122, 122, 122, 122, 122, 122, 122, 122, 0,
- 120, 120, 120
+ 123, 1, 123, 123, 123, 123, 123, 123, 123, 124,
+ 123, 123, 123, 123, 123, 125, 125, 125, 125, 125,
+ 125, 125, 125, 125, 125, 125, 125, 125, 125, 125,
+ 123, 123, 123, 123, 123, 123, 124, 123, 126, 123,
+ 123, 123, 123, 125, 125, 125, 125, 125, 125, 125,
+ 125, 125, 125, 125, 125, 125, 125, 125, 125, 125,
+ 125, 125, 125, 125, 125, 125, 125, 126, 123, 125,
+ 125, 125, 125, 125, 125, 125, 125, 125, 125, 125,
+ 125, 125, 125, 125, 125, 125, 125, 125, 125, 125,
+ 125, 125, 125, 125, 125, 125, 125, 125, 125, 125,
+
+ 125, 125, 125, 125, 123, 125, 125, 125, 125, 125,
+ 125, 125, 125, 123, 125, 125, 125, 125, 123, 125,
+ 125, 125, 0, 123, 123, 123
} ;
-static yyconst flex_int16_t yy_nxt[328] =
+static yyconst flex_int16_t yy_nxt[345] =
{ 0,
4, 5, 6, 7, 8, 9, 10, 11, 12, 4,
13, 14, 11, 15, 16, 16, 16, 17, 18, 19,
@@ -478,37 +479,39 @@ static yyconst flex_int16_t yy_nxt[328] =
27, 28, 29, 16, 16, 30, 16, 31, 34, 34,
32, 33, 34, 34, 35, 34, 34, 35, 34, 34,
35, 40, 41, 45, 46, 49, 47, 50, 54, 70,
- 51, 52, 58, 59, 44, 48, 62, 69, 53, 55,
+ 51, 52, 58, 59, 105, 48, 62, 105, 53, 55,
63, 56, 34, 34, 45, 46, 49, 47, 50, 54,
70, 51, 57, 52, 58, 59, 48, 60, 62, 53,
61, 55, 63, 56, 64, 66, 67, 40, 41, 71,
- 65, 69, 38, 57, 33, 34, 34, 35, 60, 72,
+ 65, 44, 69, 57, 33, 34, 34, 35, 60, 72,
73, 61, 35, 34, 34, 35, 64, 66, 67, 74,
71, 65, 33, 34, 34, 35, 35, 34, 34, 35,
- 75, 72, 73, 76, 77, 78, 79, 43, 80, 81,
- 82, 74, 83, 84, 85, 86, 87, 42, 88, 89,
+ 75, 72, 73, 76, 77, 78, 79, 69, 80, 81,
+ 82, 74, 83, 84, 85, 86, 87, 38, 88, 89,
90, 75, 91, 92, 76, 77, 93, 78, 79, 80,
81, 94, 82, 83, 84, 85, 95, 86, 87, 88,
89, 96, 90, 91, 92, 97, 98, 101, 93, 99,
- 100, 102, 94, 103, 104, 105, 106, 95, 107, 108,
- 109, 110, 96, 111, 112, 114, 97, 113, 98, 101,
- 99, 100, 102, 115, 103, 116, 104, 105, 106, 107,
- 117, 108, 109, 110, 118, 111, 112, 114, 113, 119,
- 39, 38, 36, 120, 115, 120, 116, 120, 120, 120,
- 120, 117, 120, 120, 120, 118, 120, 120, 120, 120,
- 119, 37, 120, 37, 37, 68, 120, 120, 68, 3,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
-
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120
+ 100, 102, 94, 103, 104, 106, 107, 95, 108, 109,
+ 110, 111, 96, 112, 113, 43, 97, 115, 98, 101,
+ 99, 100, 102, 116, 103, 117, 104, 106, 107, 108,
+ 118, 109, 110, 111, 105, 112, 113, 105, 115, 119,
+ 42, 120, 121, 122, 39, 116, 117, 38, 36, 123,
+ 123, 118, 123, 123, 123, 114, 123, 123, 123, 123,
+ 123, 119, 120, 121, 122, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 114, 37, 123,
+ 37, 37, 68, 123, 123, 68, 3, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123
} ;
-static yyconst flex_int16_t yy_chk[328] =
+static yyconst flex_int16_t yy_chk[345] =
{ 0,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
@@ -518,34 +521,36 @@ static yyconst flex_int16_t yy_chk[328] =
1, 1, 1, 1, 1, 1, 1, 2, 6, 6,
2, 5, 5, 5, 5, 7, 7, 8, 8, 8,
8, 13, 13, 17, 18, 19, 18, 20, 22, 45,
- 20, 21, 24, 25, 122, 18, 27, 69, 21, 23,
+ 20, 21, 24, 25, 90, 18, 27, 90, 21, 23,
28, 23, 34, 34, 17, 18, 19, 18, 20, 22,
45, 20, 23, 21, 24, 25, 18, 26, 27, 21,
26, 23, 28, 23, 29, 30, 30, 41, 41, 46,
- 29, 40, 37, 23, 31, 31, 31, 31, 26, 47,
+ 29, 125, 69, 23, 31, 31, 31, 31, 26, 47,
48, 26, 32, 32, 32, 32, 29, 30, 30, 49,
46, 29, 33, 33, 33, 33, 35, 35, 35, 35,
- 50, 47, 48, 53, 54, 55, 56, 15, 57, 58,
- 60, 49, 61, 62, 63, 64, 66, 14, 67, 70,
+ 50, 47, 48, 53, 54, 55, 56, 40, 57, 58,
+ 60, 49, 61, 62, 63, 64, 66, 37, 67, 70,
71, 50, 73, 74, 53, 54, 75, 55, 56, 57,
58, 76, 60, 61, 62, 63, 77, 64, 66, 67,
70, 78, 71, 73, 74, 79, 80, 84, 75, 81,
82, 86, 76, 87, 88, 92, 93, 77, 96, 97,
- 98, 100, 78, 101, 103, 108, 79, 106, 80, 84,
- 81, 82, 86, 110, 87, 111, 88, 92, 93, 96,
- 114, 97, 98, 100, 115, 101, 103, 108, 106, 118,
- 12, 10, 9, 3, 110, 0, 111, 0, 0, 0,
- 0, 114, 0, 0, 0, 115, 0, 0, 0, 0,
- 118, 121, 0, 121, 121, 123, 0, 0, 123, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
-
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120, 120, 120, 120,
- 120, 120, 120, 120, 120, 120, 120
+ 98, 100, 78, 101, 103, 15, 79, 107, 80, 84,
+ 81, 82, 86, 109, 87, 111, 88, 92, 93, 96,
+ 112, 97, 98, 100, 105, 101, 103, 105, 107, 114,
+ 14, 116, 117, 121, 12, 109, 111, 10, 9, 3,
+ 0, 112, 0, 0, 0, 105, 0, 0, 0, 0,
+ 0, 114, 116, 117, 121, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 105, 124, 0,
+ 124, 124, 126, 0, 0, 126, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123, 123, 123, 123, 123, 123, 123,
+ 123, 123, 123, 123
} ;
static yy_state_type yy_last_accepting_state;
@@ -595,7 +600,7 @@ char *yytext;
int yyparse();
-#line 599 "engines/director/lingo/lingo-lex.cpp"
+#line 604 "engines/director/lingo/lingo-lex.cpp"
#define INITIAL 0
@@ -783,7 +788,7 @@ YY_DECL
#line 45 "engines/director/lingo/lingo-lex.l"
-#line 787 "engines/director/lingo/lingo-lex.cpp"
+#line 792 "engines/director/lingo/lingo-lex.cpp"
if ( !(yy_init) )
{
@@ -837,13 +842,13 @@ yy_match:
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
{
yy_current_state = (int) yy_def[yy_current_state];
- if ( yy_current_state >= 121 )
+ if ( yy_current_state >= 124 )
yy_c = yy_meta[(unsigned int) yy_c];
}
yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
++yy_cp;
}
- while ( yy_base[yy_current_state] != 270 );
+ while ( yy_base[yy_current_state] != 287 );
yy_find_action:
yy_act = yy_accept[yy_current_state];
@@ -895,131 +900,136 @@ YY_RULE_SETUP
case 6:
YY_RULE_SETUP
#line 53 "engines/director/lingo/lingo-lex.l"
-{ return tELSE; }
+{ return tELSIF; }
YY_BREAK
case 7:
YY_RULE_SETUP
#line 54 "engines/director/lingo/lingo-lex.l"
-{ return tEND; }
+{ return tELSE; }
YY_BREAK
case 8:
YY_RULE_SETUP
#line 55 "engines/director/lingo/lingo-lex.l"
-{ return tEXIT; }
+{ return tEND; }
YY_BREAK
case 9:
YY_RULE_SETUP
#line 56 "engines/director/lingo/lingo-lex.l"
-{ return tFRAME; }
+{ return tEXIT; }
YY_BREAK
case 10:
YY_RULE_SETUP
#line 57 "engines/director/lingo/lingo-lex.l"
-{ return tGLOBAL; }
+{ return tFRAME; }
YY_BREAK
case 11:
YY_RULE_SETUP
#line 58 "engines/director/lingo/lingo-lex.l"
-{ return tGO; }
+{ return tGLOBAL; }
YY_BREAK
case 12:
YY_RULE_SETUP
#line 59 "engines/director/lingo/lingo-lex.l"
-{ return tINTO; }
+{ return tGO; }
YY_BREAK
case 13:
YY_RULE_SETUP
#line 60 "engines/director/lingo/lingo-lex.l"
-{ return tLOOP; }
+{ return tINTO; }
YY_BREAK
case 14:
YY_RULE_SETUP
#line 61 "engines/director/lingo/lingo-lex.l"
-{ return tMACRO; }
+{ return tLOOP; }
YY_BREAK
case 15:
YY_RULE_SETUP
#line 62 "engines/director/lingo/lingo-lex.l"
-{ return tMCI; }
+{ return tMACRO; }
YY_BREAK
case 16:
YY_RULE_SETUP
#line 63 "engines/director/lingo/lingo-lex.l"
-{ return tMCIWAIT; }
+{ return tMCI; }
YY_BREAK
case 17:
YY_RULE_SETUP
#line 64 "engines/director/lingo/lingo-lex.l"
-{ return tMOVIE; }
+{ return tMCIWAIT; }
YY_BREAK
case 18:
YY_RULE_SETUP
#line 65 "engines/director/lingo/lingo-lex.l"
-{ return tNEXT; }
+{ return tMOVIE; }
YY_BREAK
case 19:
YY_RULE_SETUP
#line 66 "engines/director/lingo/lingo-lex.l"
-{ return tOF; }
+{ return tNEXT; }
YY_BREAK
case 20:
YY_RULE_SETUP
#line 67 "engines/director/lingo/lingo-lex.l"
-{ return tPREVIOUS; }
+{ return tOF; }
YY_BREAK
case 21:
YY_RULE_SETUP
#line 68 "engines/director/lingo/lingo-lex.l"
-{ return tPUT; }
+{ return tPREVIOUS; }
YY_BREAK
case 22:
YY_RULE_SETUP
#line 69 "engines/director/lingo/lingo-lex.l"
-{ return tREPEAT; }
+{ return tPUT; }
YY_BREAK
case 23:
YY_RULE_SETUP
#line 70 "engines/director/lingo/lingo-lex.l"
-{ return tSET; }
+{ return tREPEAT; }
YY_BREAK
case 24:
YY_RULE_SETUP
#line 71 "engines/director/lingo/lingo-lex.l"
-{ return tTHEN; }
+{ return tSET; }
YY_BREAK
case 25:
YY_RULE_SETUP
#line 72 "engines/director/lingo/lingo-lex.l"
-{ return tTO; }
+{ return tTHEN; }
YY_BREAK
case 26:
YY_RULE_SETUP
#line 73 "engines/director/lingo/lingo-lex.l"
-{ return tWITH; }
+{ return tTO; }
YY_BREAK
case 27:
YY_RULE_SETUP
#line 74 "engines/director/lingo/lingo-lex.l"
-{ return tWHILE; }
+{ return tWITH; }
YY_BREAK
case 28:
YY_RULE_SETUP
-#line 76 "engines/director/lingo/lingo-lex.l"
-{ return tNEQ; }
+#line 75 "engines/director/lingo/lingo-lex.l"
+{ return tWHILE; }
YY_BREAK
case 29:
YY_RULE_SETUP
#line 77 "engines/director/lingo/lingo-lex.l"
-{ return tGE; }
+{ return tNEQ; }
YY_BREAK
case 30:
YY_RULE_SETUP
#line 78 "engines/director/lingo/lingo-lex.l"
-{ return tLE; }
+{ return tGE; }
YY_BREAK
case 31:
YY_RULE_SETUP
-#line 80 "engines/director/lingo/lingo-lex.l"
+#line 79 "engines/director/lingo/lingo-lex.l"
+{ return tLE; }
+ YY_BREAK
+case 32:
+YY_RULE_SETUP
+#line 81 "engines/director/lingo/lingo-lex.l"
{
yylval.s = new Common::String(yytext);
@@ -1029,43 +1039,43 @@ YY_RULE_SETUP
return ID;
}
YY_BREAK
-case 32:
-YY_RULE_SETUP
-#line 88 "engines/director/lingo/lingo-lex.l"
-{ yylval.f = atof(yytext); return FLOAT; }
- YY_BREAK
case 33:
YY_RULE_SETUP
#line 89 "engines/director/lingo/lingo-lex.l"
-{ yylval.i = strtol(yytext, NULL, 10); return INT; }
+{ yylval.f = atof(yytext); return FLOAT; }
YY_BREAK
case 34:
YY_RULE_SETUP
#line 90 "engines/director/lingo/lingo-lex.l"
-{ return *yytext; }
+{ yylval.i = strtol(yytext, NULL, 10); return INT; }
YY_BREAK
case 35:
-/* rule 35 can match eol */
YY_RULE_SETUP
#line 91 "engines/director/lingo/lingo-lex.l"
-{ return '\n'; }
+{ return *yytext; }
YY_BREAK
case 36:
+/* rule 36 can match eol */
YY_RULE_SETUP
#line 92 "engines/director/lingo/lingo-lex.l"
-{ yylval.s = new Common::String(&yytext[1]); yylval.s->deleteLastChar(); return STRING; }
+{ return '\n'; }
YY_BREAK
case 37:
YY_RULE_SETUP
#line 93 "engines/director/lingo/lingo-lex.l"
-
+{ yylval.s = new Common::String(&yytext[1]); yylval.s->deleteLastChar(); return STRING; }
YY_BREAK
case 38:
YY_RULE_SETUP
-#line 95 "engines/director/lingo/lingo-lex.l"
+#line 94 "engines/director/lingo/lingo-lex.l"
+
+ YY_BREAK
+case 39:
+YY_RULE_SETUP
+#line 96 "engines/director/lingo/lingo-lex.l"
ECHO;
YY_BREAK
-#line 1069 "engines/director/lingo/lingo-lex.cpp"
+#line 1079 "engines/director/lingo/lingo-lex.cpp"
case YY_STATE_EOF(INITIAL):
yyterminate();
@@ -1358,7 +1368,7 @@ static int yy_get_next_buffer (void)
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
{
yy_current_state = (int) yy_def[yy_current_state];
- if ( yy_current_state >= 121 )
+ if ( yy_current_state >= 124 )
yy_c = yy_meta[(unsigned int) yy_c];
}
yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
@@ -1386,11 +1396,11 @@ static int yy_get_next_buffer (void)
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
{
yy_current_state = (int) yy_def[yy_current_state];
- if ( yy_current_state >= 121 )
+ if ( yy_current_state >= 124 )
yy_c = yy_meta[(unsigned int) yy_c];
}
yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
- yy_is_jam = (yy_current_state == 120);
+ yy_is_jam = (yy_current_state == 123);
return yy_is_jam ? 0 : yy_current_state;
}
@@ -2065,7 +2075,7 @@ void yyfree (void * ptr )
#define YYTABLES_NAME "yytables"
-#line 95 "engines/director/lingo/lingo-lex.l"
+#line 96 "engines/director/lingo/lingo-lex.l"
diff --git a/engines/director/lingo/lingo-lex.l b/engines/director/lingo/lingo-lex.l
index 6144bba448..2580f4f822 100644
--- a/engines/director/lingo/lingo-lex.l
+++ b/engines/director/lingo/lingo-lex.l
@@ -50,6 +50,7 @@ whitespace [\t ]
(?i:down) { return tDOWN; }
(?i:if) { return tIF; }
+(?i:else[\t ]+if) { return tELSIF; }
(?i:else) { return tELSE; }
(?i:end) { return tEND; }
(?i:exit) { return tEXIT; }