aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEugene Sandulenko2016-06-25 12:54:38 +0200
committerEugene Sandulenko2016-08-03 23:40:36 +0200
commitaee02d7282e696d68a01465b29c4d9da0018a76d (patch)
treeb98847305bcab30f3a1a24e003830d42351f24bb
parent327e625507f34c5656e4392c07d1b73bab95b976 (diff)
downloadscummvm-rg350-aee02d7282e696d68a01465b29c4d9da0018a76d.tar.gz
scummvm-rg350-aee02d7282e696d68a01465b29c4d9da0018a76d.tar.bz2
scummvm-rg350-aee02d7282e696d68a01465b29c4d9da0018a76d.zip
DIRECTOR: Lingo: Initial code for function call grammar
-rw-r--r--engines/director/lingo/lingo-code.cpp4
-rw-r--r--engines/director/lingo/lingo-gr.cpp402
-rw-r--r--engines/director/lingo/lingo-gr.y16
-rw-r--r--engines/director/lingo/lingo.h1
4 files changed, 236 insertions, 187 deletions
diff --git a/engines/director/lingo/lingo-code.cpp b/engines/director/lingo/lingo-code.cpp
index e14ecfe297..ef134a07ba 100644
--- a/engines/director/lingo/lingo-code.cpp
+++ b/engines/director/lingo/lingo-code.cpp
@@ -404,6 +404,10 @@ void Lingo::codeArg(Common::String &s) {
g_lingo->code1(g_lingo->c_assign);
}
+void Lingo::c_call() {
+ warning("STUB: c_call()");
+}
+
void Lingo::c_procret() {
warning("STUB: c_procret()");
}
diff --git a/engines/director/lingo/lingo-gr.cpp b/engines/director/lingo/lingo-gr.cpp
index d3980bdc64..11f9de2459 100644
--- a/engines/director/lingo/lingo-gr.cpp
+++ b/engines/director/lingo/lingo-gr.cpp
@@ -418,18 +418,18 @@ union yyalloc
#endif
/* YYFINAL -- State number of the termination state. */
-#define YYFINAL 49
+#define YYFINAL 51
/* YYLAST -- Last index in YYTABLE. */
-#define YYLAST 300
+#define YYLAST 315
/* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 51
/* YYNNTS -- Number of nonterminals. */
-#define YYNNTS 20
+#define YYNNTS 21
/* YYNRULES -- Number of rules. */
-#define YYNRULES 72
+#define YYNRULES 76
/* YYNRULES -- Number of states. */
-#define YYNSTATES 148
+#define YYNSTATES 156
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2
@@ -476,16 +476,16 @@ static const yytype_uint8 yytranslate[] =
#if YYDEBUG
/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
YYRHS. */
-static const yytype_uint8 yyprhs[] =
+static const yytype_uint16 yyprhs[] =
{
0, 0, 3, 7, 10, 12, 13, 15, 17, 19,
21, 23, 25, 26, 31, 36, 41, 43, 45, 53,
64, 73, 85, 98, 100, 104, 108, 111, 115, 117,
118, 119, 120, 123, 126, 128, 130, 132, 136, 140,
144, 148, 152, 156, 160, 164, 168, 171, 174, 178,
- 181, 184, 187, 189, 191, 194, 197, 200, 203, 207,
- 210, 214, 217, 220, 222, 226, 229, 233, 234, 242,
- 243, 245, 249
+ 184, 187, 190, 193, 195, 197, 200, 203, 206, 209,
+ 213, 216, 220, 223, 226, 228, 232, 235, 239, 240,
+ 248, 249, 251, 255, 260, 261, 263
};
/* YYRHS -- A `-1'-separated list of the rules' RHS. */
@@ -508,15 +508,16 @@ static const yytype_int8 yyrhs[] =
63, 42, 63, -1, 63, 43, 63, -1, 63, 48,
63, -1, 63, 49, 63, -1, 63, 38, 63, -1,
63, 33, 63, -1, 63, 34, 63, -1, 40, 63,
- -1, 41, 63, -1, 46, 63, 47, -1, 20, 8,
- -1, 21, 7, -1, 26, 63, -1, 65, -1, 13,
- -1, 15, 18, -1, 15, 23, -1, 15, 25, -1,
- 15, 66, -1, 15, 66, 67, -1, 15, 67, -1,
- 30, 14, 8, -1, 14, 8, -1, 30, 8, -1,
- 8, -1, 24, 22, 8, -1, 22, 8, -1, 30,
- 22, 8, -1, -1, 19, 7, 69, 60, 70, 62,
- 61, -1, -1, 7, -1, 70, 50, 7, -1, 70,
- 50, 45, 7, -1
+ -1, 41, 63, -1, 46, 63, 47, -1, 7, 60,
+ 46, 71, 47, -1, 20, 8, -1, 21, 7, -1,
+ 26, 63, -1, 65, -1, 13, -1, 15, 18, -1,
+ 15, 23, -1, 15, 25, -1, 15, 66, -1, 15,
+ 66, 67, -1, 15, 67, -1, 30, 14, 8, -1,
+ 14, 8, -1, 30, 8, -1, 8, -1, 24, 22,
+ 8, -1, 22, 8, -1, 30, 22, 8, -1, -1,
+ 19, 7, 69, 60, 70, 62, 61, -1, -1, 7,
+ -1, 70, 50, 7, -1, 70, 50, 45, 7, -1,
+ -1, 63, -1, 71, 50, 63, -1
};
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
@@ -527,9 +528,9 @@ static const yytype_uint16 yyrline[] =
147, 158, 174, 188, 189, 190, 192, 194, 200, 202,
204, 206, 207, 208, 211, 216, 221, 222, 223, 224,
225, 226, 227, 228, 229, 230, 231, 232, 233, 236,
- 237, 238, 239, 240, 251, 252, 253, 254, 259, 265,
- 272, 273, 274, 275, 278, 279, 280, 308, 308, 314,
- 315, 316, 317
+ 242, 243, 244, 245, 246, 257, 258, 259, 260, 265,
+ 271, 278, 279, 280, 281, 284, 285, 286, 314, 314,
+ 320, 321, 322, 323, 326, 327, 328
};
#endif
@@ -546,7 +547,8 @@ static const char *const yytname[] =
"'*'", "'/'", "'%'", "'\\n'", "'('", "')'", "'>'", "'<'", "','",
"$accept", "program", "programline", "asgn", "stmt", "cond",
"repeatwhile", "repeatwith", "if", "begin", "end", "stmtlist", "expr",
- "func", "gotofunc", "gotoframe", "gotomovie", "defn", "@1", "argdef", 0
+ "func", "gotofunc", "gotoframe", "gotomovie", "defn", "@1", "argdef",
+ "arglist", 0
};
#endif
@@ -572,9 +574,9 @@ static const yytype_uint8 yyr1[] =
55, 55, 55, 56, 56, 56, 57, 58, 59, 60,
61, 62, 62, 62, 63, 63, 63, 63, 63, 63,
63, 63, 63, 63, 63, 63, 63, 63, 63, 64,
- 64, 64, 64, 64, 65, 65, 65, 65, 65, 65,
- 66, 66, 66, 66, 67, 67, 67, 69, 68, 70,
- 70, 70, 70
+ 64, 64, 64, 64, 64, 65, 65, 65, 65, 65,
+ 65, 66, 66, 66, 66, 67, 67, 67, 69, 68,
+ 70, 70, 70, 70, 71, 71, 71
};
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
@@ -584,10 +586,10 @@ static const yytype_uint8 yyr2[] =
1, 1, 0, 4, 4, 4, 1, 1, 7, 10,
8, 11, 12, 1, 3, 3, 2, 3, 1, 0,
0, 0, 2, 2, 1, 1, 1, 3, 3, 3,
- 3, 3, 3, 3, 3, 3, 2, 2, 3, 2,
- 2, 2, 1, 1, 2, 2, 2, 2, 3, 2,
- 3, 2, 2, 1, 3, 2, 3, 0, 7, 0,
- 1, 3, 4
+ 3, 3, 3, 3, 3, 3, 2, 2, 3, 5,
+ 2, 2, 2, 1, 1, 2, 2, 2, 2, 3,
+ 2, 3, 2, 2, 1, 3, 2, 3, 0, 7,
+ 0, 1, 3, 4, 0, 1, 3
};
/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
@@ -595,57 +597,61 @@ static const yytype_uint8 yyr2[] =
means the default is an error. */
static const yytype_uint8 yydefact[] =
{
- 0, 11, 34, 35, 53, 0, 28, 0, 0, 0,
+ 0, 11, 34, 35, 54, 0, 28, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 8, 9,
- 0, 0, 0, 10, 7, 52, 6, 63, 0, 54,
- 0, 55, 0, 56, 0, 57, 59, 67, 49, 50,
- 0, 36, 51, 0, 26, 0, 46, 47, 0, 1,
- 0, 3, 0, 0, 0, 0, 23, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 61, 65, 0, 62,
- 0, 0, 0, 58, 29, 0, 0, 27, 0, 0,
- 48, 2, 0, 30, 0, 0, 31, 0, 44, 45,
- 43, 37, 38, 39, 40, 41, 42, 64, 60, 66,
- 69, 13, 15, 14, 31, 0, 25, 30, 24, 70,
- 31, 30, 0, 0, 32, 33, 0, 16, 17, 0,
- 30, 0, 0, 30, 31, 0, 71, 0, 68, 0,
- 30, 31, 30, 18, 72, 20, 31, 30, 0, 30,
- 0, 0, 0, 0, 19, 0, 21, 22
+ 0, 0, 0, 10, 7, 53, 6, 0, 64, 0,
+ 55, 0, 56, 0, 57, 0, 58, 60, 68, 50,
+ 51, 35, 0, 36, 52, 0, 26, 0, 46, 47,
+ 0, 1, 0, 3, 0, 0, 0, 0, 23, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 74, 62,
+ 66, 0, 63, 0, 0, 0, 59, 29, 0, 0,
+ 27, 0, 0, 48, 2, 0, 30, 0, 0, 31,
+ 0, 44, 45, 43, 37, 38, 39, 40, 41, 42,
+ 75, 0, 65, 61, 67, 70, 13, 15, 14, 31,
+ 0, 25, 30, 24, 49, 0, 71, 31, 30, 0,
+ 0, 32, 33, 0, 16, 17, 76, 0, 30, 0,
+ 0, 30, 31, 0, 72, 0, 69, 0, 30, 31,
+ 30, 18, 73, 20, 31, 30, 0, 30, 0, 0,
+ 0, 0, 19, 0, 21, 22
};
/* YYDEFGOTO[NTERM-NUM]. */
static const yytype_int8 yydefgoto[] =
{
- -1, 16, 17, 41, 115, 55, 20, 21, 22, 100,
- 105, 107, 117, 118, 25, 35, 36, 26, 74, 110
+ -1, 16, 17, 43, 122, 57, 20, 21, 22, 27,
+ 110, 112, 124, 125, 25, 36, 37, 26, 77, 117,
+ 101
};
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */
-#define YYPACT_NINF -34
+#define YYPACT_NINF -43
static const yytype_int16 yypact[] =
{
- 69, -34, -34, -34, -34, 198, -34, -3, 24, 5,
- -2, 15, 12, -2, -2, -2, 8, 111, 239, -34,
- -12, 33, 2, 227, -34, -34, -34, -34, 28, -34,
- 47, -34, 58, -34, 23, 51, -34, -34, -34, -34,
- -2, -34, 162, 76, -34, -10, 87, 87, 203, -34,
- 69, -34, 2, -2, 2, 57, 215, -2, -2, -2,
- -2, -2, -2, -2, -2, -2, -34, -34, 84, -34,
- 85, 86, 77, -34, -34, 162, 93, -34, -2, -2,
- -34, -34, 54, 227, 55, 191, -34, -2, 227, 227,
- 227, 251, 251, 87, 87, 227, 227, -34, -34, -34,
- 97, -34, 227, 227, -34, 11, -34, 148, 227, -34,
- 67, 148, 75, -2, -34, -34, 56, 227, -34, 4,
- 148, 94, -2, 227, -34, 91, -34, 101, -34, 92,
- 227, -34, 148, -34, -34, -34, -34, 148, 116, 148,
- 117, 107, 121, 113, -34, 114, -34, -34
+ 72, -43, -43, -42, -43, 213, -43, 9, 13, 18,
+ -2, 15, 22, -2, -2, -2, 32, 121, 254, -43,
+ -12, 12, 118, 242, -43, -43, -43, 4, -43, 49,
+ -43, 61, -43, 48, -43, 23, 11, -43, -43, -43,
+ -43, -43, -2, -43, 177, 67, -43, -19, 142, 142,
+ 218, -43, 72, -43, 118, -2, 118, 46, 230, -2,
+ -2, -2, -2, -2, -2, -2, -2, -2, -2, -43,
+ -43, 68, -43, 70, 75, 58, -43, -43, 177, 77,
+ -43, -2, -2, -43, -43, 39, 242, 42, 206, -43,
+ -2, 242, 242, 242, 266, 266, 142, 142, 242, 242,
+ 242, -38, -43, -43, -43, 87, -43, 242, 242, -43,
+ -3, -43, 158, 242, -43, -2, -43, 45, 158, 66,
+ -2, -43, -43, 37, 242, -43, 242, -5, 158, 85,
+ -2, 242, -43, 86, -43, 94, -43, 76, 242, -43,
+ 158, -43, -43, -43, -43, 158, 92, 158, 93, 90,
+ 95, 82, -43, 83, -43, -43
};
/* YYPGOTO[NTERM-NUM]. */
static const yytype_int8 yypgoto[] =
{
- -34, -15, -34, 1, 6, -27, -34, -34, -34, -34,
- 60, -33, 0, 16, -34, -34, 99, -34, -34, -34
+ -43, -9, -43, 1, 6, -26, -43, -43, -43, 34,
+ 69, -1, 0, 19, -43, -43, 78, -43, -43, -43,
+ -43
};
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
@@ -655,72 +661,74 @@ static const yytype_int8 yypgoto[] =
#define YYTABLE_NINF -37
static const yytype_int16 yytable[] =
{
- 23, 18, 51, 2, 37, 3, 19, 2, 49, 3,
- 42, 126, 39, 46, 47, 48, 24, 23, 18, 45,
- 78, 112, 56, 19, 40, 82, 12, 84, 40, 79,
- 12, 69, 38, 24, 52, 81, 66, 70, 13, 14,
- 75, 113, 13, 14, 15, 71, 43, 44, 54, 127,
- 23, 18, 56, 83, 85, 67, 19, 88, 89, 90,
- 91, 92, 93, 94, 95, 96, 24, 124, 125, -5,
- 1, 111, 53, 30, 2, 32, 3, 120, 102, 103,
- 68, 72, 4, 77, 5, 6, 86, 108, 7, 8,
- 9, 132, 97, 98, 99, 10, 11, 12, 137, 71,
- 101, 104, 106, 139, 109, 122, 129, 133, 134, 13,
- 14, -4, 1, 123, -5, 15, 2, 119, 3, 135,
- 57, 58, 130, 144, 4, 59, 5, 6, 141, 143,
- 7, 8, 9, 145, 73, 64, 65, 10, 11, 12,
- 146, 147, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 13, 14, 2, 0, 3, 50, 15, 0, 0,
- 0, 4, 0, 5, 6, 0, 0, 116, 8, 9,
- 0, 121, 0, 0, 10, 11, 12, 0, 0, 76,
- 128, 0, 0, 131, 0, 0, 0, 0, 13, 14,
- 136, 0, 138, 114, 15, 57, 58, 140, 0, 142,
- 59, 0, 60, 61, 62, 63, 27, 0, 0, 0,
- 64, 65, 28, 0, 0, 0, 29, 0, 0, 0,
- 30, 31, 32, 33, 57, 58, 0, 0, 34, 59,
- 87, 60, 61, 62, 63, 0, 57, 58, 80, 64,
- 65, 59, 0, 60, 61, 62, 63, 0, 57, 58,
- 80, 64, 65, 59, 87, 60, 61, 62, 63, 0,
- 57, 58, 0, 64, 65, 59, 0, 60, 61, 62,
- 63, 0, -36, -36, 0, 64, 65, -36, 0, 0,
- 0, -36, -36, 0, 57, 58, 0, -36, -36, 59,
- 0, 0, 0, 62, 63, 0, 0, 0, 0, 64,
- 65
+ 23, 18, 134, 2, -29, 41, 19, 119, 53, 114,
+ 44, 81, 115, 48, 49, 50, 38, 23, 18, 24,
+ 82, 39, 58, 19, 42, 40, 12, 120, 85, 47,
+ 87, 72, 51, 31, 54, 33, 24, 73, 13, 14,
+ 135, 75, 78, 84, 15, 74, 45, 46, 132, 133,
+ 68, 55, 23, 18, 58, 86, 88, 69, 19, 91,
+ 92, 93, 94, 95, 96, 97, 98, 99, 100, 70,
+ 71, 24, -5, 1, 80, 89, 102, 2, 103, 3,
+ 74, 107, 108, 104, 106, 4, 109, 5, 6, 111,
+ 113, 7, 8, 9, 116, 127, 130, 137, 10, 11,
+ 12, 142, 141, 143, 149, 151, 152, 153, 118, 154,
+ 155, 105, 13, 14, 76, 126, 128, -5, 15, 0,
+ 131, -4, 1, 2, 0, 41, 2, 0, 3, 0,
+ 138, 140, 0, 0, 4, 0, 5, 6, 145, 0,
+ 7, 8, 9, 147, 42, 0, 12, 10, 11, 12,
+ 0, 0, 0, 0, 0, 0, 0, 0, 13, 14,
+ 0, 13, 14, 2, 56, 3, 52, 15, 0, 0,
+ 0, 4, 0, 5, 6, 59, 60, 0, 8, 9,
+ 61, 123, 0, 0, 10, 11, 12, 129, 0, 0,
+ 66, 67, 0, 0, 79, 0, 0, 136, 13, 14,
+ 139, 0, 0, 121, 15, 0, 0, 144, 0, 146,
+ 59, 60, 0, 0, 148, 61, 150, 62, 63, 64,
+ 65, 28, 0, 0, 0, 66, 67, 29, 0, 0,
+ 0, 30, 0, 0, 0, 31, 32, 33, 34, 59,
+ 60, 0, 0, 35, 61, 90, 62, 63, 64, 65,
+ 0, 59, 60, 83, 66, 67, 61, 0, 62, 63,
+ 64, 65, 0, 59, 60, 83, 66, 67, 61, 90,
+ 62, 63, 64, 65, 0, 59, 60, 0, 66, 67,
+ 61, 0, 62, 63, 64, 65, 0, -36, -36, 0,
+ 66, 67, -36, 0, 0, 0, -36, -36, 0, 59,
+ 60, 0, -36, -36, 61, 0, 0, 0, 64, 65,
+ 0, 0, 0, 0, 66, 67
};
static const yytype_int16 yycheck[] =
{
- 0, 0, 17, 5, 7, 7, 0, 5, 0, 7,
- 10, 7, 7, 13, 14, 15, 0, 17, 17, 7,
- 30, 10, 22, 17, 26, 52, 28, 54, 26, 39,
- 28, 8, 8, 17, 46, 50, 8, 14, 40, 41,
- 40, 30, 40, 41, 46, 22, 31, 32, 46, 45,
- 50, 50, 52, 53, 54, 8, 50, 57, 58, 59,
- 60, 61, 62, 63, 64, 65, 50, 11, 12, 0,
- 1, 104, 39, 22, 5, 24, 7, 110, 78, 79,
- 22, 30, 13, 7, 15, 16, 29, 87, 19, 20,
- 21, 124, 8, 8, 8, 26, 27, 28, 131, 22,
- 7, 47, 47, 136, 7, 30, 12, 16, 7, 40,
- 41, 0, 1, 113, 45, 46, 5, 50, 7, 27,
- 33, 34, 122, 16, 13, 38, 15, 16, 12, 12,
- 19, 20, 21, 12, 35, 48, 49, 26, 27, 28,
- 27, 27, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, 40, 41, 5, -1, 7, 45, 46, -1, -1,
- -1, 13, -1, 15, 16, -1, -1, 107, 20, 21,
- -1, 111, -1, -1, 26, 27, 28, -1, -1, 17,
- 120, -1, -1, 123, -1, -1, -1, -1, 40, 41,
- 130, -1, 132, 45, 46, 33, 34, 137, -1, 139,
- 38, -1, 40, 41, 42, 43, 8, -1, -1, -1,
- 48, 49, 14, -1, -1, -1, 18, -1, -1, -1,
- 22, 23, 24, 25, 33, 34, -1, -1, 30, 38,
- 39, 40, 41, 42, 43, -1, 33, 34, 47, 48,
- 49, 38, -1, 40, 41, 42, 43, -1, 33, 34,
- 47, 48, 49, 38, 39, 40, 41, 42, 43, -1,
- 33, 34, -1, 48, 49, 38, -1, 40, 41, 42,
- 43, -1, 33, 34, -1, 48, 49, 38, -1, -1,
- -1, 42, 43, -1, 33, 34, -1, 48, 49, 38,
- -1, -1, -1, 42, 43, -1, -1, -1, -1, 48,
- 49
+ 0, 0, 7, 5, 46, 7, 0, 10, 17, 47,
+ 10, 30, 50, 13, 14, 15, 7, 17, 17, 0,
+ 39, 8, 22, 17, 26, 7, 28, 30, 54, 7,
+ 56, 8, 0, 22, 46, 24, 17, 14, 40, 41,
+ 45, 30, 42, 52, 46, 22, 31, 32, 11, 12,
+ 46, 39, 52, 52, 54, 55, 56, 8, 52, 59,
+ 60, 61, 62, 63, 64, 65, 66, 67, 68, 8,
+ 22, 52, 0, 1, 7, 29, 8, 5, 8, 7,
+ 22, 81, 82, 8, 7, 13, 47, 15, 16, 47,
+ 90, 19, 20, 21, 7, 50, 30, 12, 26, 27,
+ 28, 7, 16, 27, 12, 12, 16, 12, 109, 27,
+ 27, 77, 40, 41, 36, 115, 117, 45, 46, -1,
+ 120, 0, 1, 5, -1, 7, 5, -1, 7, -1,
+ 130, 132, -1, -1, 13, -1, 15, 16, 139, -1,
+ 19, 20, 21, 144, 26, -1, 28, 26, 27, 28,
+ -1, -1, -1, -1, -1, -1, -1, -1, 40, 41,
+ -1, 40, 41, 5, 46, 7, 45, 46, -1, -1,
+ -1, 13, -1, 15, 16, 33, 34, -1, 20, 21,
+ 38, 112, -1, -1, 26, 27, 28, 118, -1, -1,
+ 48, 49, -1, -1, 17, -1, -1, 128, 40, 41,
+ 131, -1, -1, 45, 46, -1, -1, 138, -1, 140,
+ 33, 34, -1, -1, 145, 38, 147, 40, 41, 42,
+ 43, 8, -1, -1, -1, 48, 49, 14, -1, -1,
+ -1, 18, -1, -1, -1, 22, 23, 24, 25, 33,
+ 34, -1, -1, 30, 38, 39, 40, 41, 42, 43,
+ -1, 33, 34, 47, 48, 49, 38, -1, 40, 41,
+ 42, 43, -1, 33, 34, 47, 48, 49, 38, 39,
+ 40, 41, 42, 43, -1, 33, 34, -1, 48, 49,
+ 38, -1, 40, 41, 42, 43, -1, 33, 34, -1,
+ 48, 49, 38, -1, -1, -1, 42, 43, -1, 33,
+ 34, -1, 48, 49, 38, -1, -1, -1, 42, 43,
+ -1, -1, -1, -1, 48, 49
};
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
@@ -729,19 +737,20 @@ static const yytype_uint8 yystos[] =
{
0, 1, 5, 7, 13, 15, 16, 19, 20, 21,
26, 27, 28, 40, 41, 46, 52, 53, 54, 55,
- 57, 58, 59, 63, 64, 65, 68, 8, 14, 18,
- 22, 23, 24, 25, 30, 66, 67, 7, 8, 7,
- 26, 54, 63, 31, 32, 7, 63, 63, 63, 0,
- 45, 52, 46, 39, 46, 56, 63, 33, 34, 38,
- 40, 41, 42, 43, 48, 49, 8, 8, 22, 8,
- 14, 22, 30, 67, 69, 63, 17, 7, 30, 39,
- 47, 52, 56, 63, 56, 63, 29, 39, 63, 63,
- 63, 63, 63, 63, 63, 63, 63, 8, 8, 8,
- 60, 7, 63, 63, 47, 61, 47, 62, 63, 7,
- 70, 62, 10, 30, 45, 55, 61, 63, 64, 50,
- 62, 61, 30, 63, 11, 12, 7, 45, 61, 12,
- 63, 61, 62, 16, 7, 27, 61, 62, 61, 62,
- 61, 12, 61, 12, 16, 12, 27, 27
+ 57, 58, 59, 63, 64, 65, 68, 60, 8, 14,
+ 18, 22, 23, 24, 25, 30, 66, 67, 7, 8,
+ 7, 7, 26, 54, 63, 31, 32, 7, 63, 63,
+ 63, 0, 45, 52, 46, 39, 46, 56, 63, 33,
+ 34, 38, 40, 41, 42, 43, 48, 49, 46, 8,
+ 8, 22, 8, 14, 22, 30, 67, 69, 63, 17,
+ 7, 30, 39, 47, 52, 56, 63, 56, 63, 29,
+ 39, 63, 63, 63, 63, 63, 63, 63, 63, 63,
+ 63, 71, 8, 8, 8, 60, 7, 63, 63, 47,
+ 61, 47, 62, 63, 47, 50, 7, 70, 62, 10,
+ 30, 45, 55, 61, 63, 64, 63, 50, 62, 61,
+ 30, 63, 11, 12, 7, 45, 61, 12, 63, 61,
+ 62, 16, 7, 27, 61, 62, 61, 62, 61, 12,
+ 61, 12, 16, 12, 27, 27
};
#define yyerrok (yyerrstatus = 0)
@@ -1793,41 +1802,51 @@ yyreduce:
case 49:
#line 236 "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); ;}
+ {
+ g_lingo->code1(g_lingo->c_call);
+ g_lingo->codeString((yyvsp[(1) - (5)].s)->c_str());
+ inst numpar = 0;
+ WRITE_UINT32(&numpar, (yyvsp[(4) - (5)].narg));
+ g_lingo->code1(numpar); ;}
break;
case 50:
-#line 237 "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); ;}
+#line 242 "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 51:
-#line 238 "engines/director/lingo/lingo-gr.y"
+#line 243 "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 52:
+#line 244 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_printtop); ;}
break;
- case 53:
-#line 240 "engines/director/lingo/lingo-gr.y"
+ case 54:
+#line 246 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_exit); ;}
break;
- case 54:
-#line 251 "engines/director/lingo/lingo-gr.y"
+ case 55:
+#line 257 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotoloop); ;}
break;
- case 55:
-#line 252 "engines/director/lingo/lingo-gr.y"
+ case 56:
+#line 258 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotonext); ;}
break;
- case 56:
-#line 253 "engines/director/lingo/lingo-gr.y"
+ case 57:
+#line 259 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotoprevious); ;}
break;
- case 57:
-#line 254 "engines/director/lingo/lingo-gr.y"
+ case 58:
+#line 260 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString((yyvsp[(2) - (2)].s)->c_str());
@@ -1835,8 +1854,8 @@ yyreduce:
delete (yyvsp[(2) - (2)].s); ;}
break;
- case 58:
-#line 259 "engines/director/lingo/lingo-gr.y"
+ case 59:
+#line 265 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString((yyvsp[(2) - (3)].s)->c_str());
@@ -1845,8 +1864,8 @@ yyreduce:
delete (yyvsp[(3) - (3)].s); ;}
break;
- case 59:
-#line 265 "engines/director/lingo/lingo-gr.y"
+ case 60:
+#line 271 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString("");
@@ -1854,77 +1873,92 @@ yyreduce:
delete (yyvsp[(2) - (2)].s); ;}
break;
- case 60:
-#line 272 "engines/director/lingo/lingo-gr.y"
+ case 61:
+#line 278 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 61:
-#line 273 "engines/director/lingo/lingo-gr.y"
+ case 62:
+#line 279 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 62:
-#line 274 "engines/director/lingo/lingo-gr.y"
+ case 63:
+#line 280 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 63:
-#line 275 "engines/director/lingo/lingo-gr.y"
+ case 64:
+#line 281 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(1) - (1)].s); ;}
break;
- case 64:
-#line 278 "engines/director/lingo/lingo-gr.y"
+ case 65:
+#line 284 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 65:
-#line 279 "engines/director/lingo/lingo-gr.y"
+ case 66:
+#line 285 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 66:
-#line 280 "engines/director/lingo/lingo-gr.y"
+ case 67:
+#line 286 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 67:
-#line 308 "engines/director/lingo/lingo-gr.y"
+ case 68:
+#line 314 "engines/director/lingo/lingo-gr.y"
{ g_lingo->_indef = true; ;}
break;
- case 68:
-#line 309 "engines/director/lingo/lingo-gr.y"
+ case 69:
+#line 315 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_procret);
g_lingo->define(*(yyvsp[(2) - (7)].s), (yyvsp[(4) - (7)].code), (yyvsp[(7) - (7)].code), (yyvsp[(5) - (7)].narg));
g_lingo->_indef = false; ;}
break;
- case 69:
-#line 314 "engines/director/lingo/lingo-gr.y"
+ case 70:
+#line 320 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 0; ;}
break;
- case 70:
-#line 315 "engines/director/lingo/lingo-gr.y"
+ case 71:
+#line 321 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg(*(yyvsp[(1) - (1)].s)); delete (yyvsp[(1) - (1)].s); (yyval.narg) = 1; ;}
break;
- case 71:
-#line 316 "engines/director/lingo/lingo-gr.y"
+ case 72:
+#line 322 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg(*(yyvsp[(3) - (3)].s)); delete (yyvsp[(3) - (3)].s); (yyval.narg) = (yyvsp[(1) - (3)].narg) + 1; ;}
break;
- case 72:
-#line 317 "engines/director/lingo/lingo-gr.y"
+ case 73:
+#line 323 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg(*(yyvsp[(4) - (4)].s)); delete (yyvsp[(4) - (4)].s); (yyval.narg) = (yyvsp[(1) - (4)].narg) + 1; ;}
break;
+ case 74:
+#line 326 "engines/director/lingo/lingo-gr.y"
+ { (yyval.narg) = 0; ;}
+ break;
+
+ case 75:
+#line 327 "engines/director/lingo/lingo-gr.y"
+ { (yyval.narg) = 1; ;}
+ break;
+
+ case 76:
+#line 328 "engines/director/lingo/lingo-gr.y"
+ { (yyval.narg) = (yyvsp[(1) - (3)].narg) + 1; ;}
+ break;
+
/* Line 1267 of yacc.c. */
-#line 1928 "engines/director/lingo/lingo-gr.cpp"
+#line 1962 "engines/director/lingo/lingo-gr.cpp"
default: break;
}
YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
@@ -2138,6 +2172,6 @@ yyreturn:
}
-#line 321 "engines/director/lingo/lingo-gr.y"
+#line 331 "engines/director/lingo/lingo-gr.y"
diff --git a/engines/director/lingo/lingo-gr.y b/engines/director/lingo/lingo-gr.y
index 5b02796be3..bd64f93c20 100644
--- a/engines/director/lingo/lingo-gr.y
+++ b/engines/director/lingo/lingo-gr.y
@@ -80,7 +80,7 @@ using namespace Director;
%type<code> asgn begin cond end expr if repeatwhile repeatwith stmtlist
%type<s> gotoframe gotomovie
-%type<narg> argdef
+%type<narg> argdef arglist
%right '='
%left '+' '-'
@@ -233,7 +233,13 @@ expr: INT {
| '(' expr ')' { $$ = $2; }
;
-func: tMCI STRING { g_lingo->code1(g_lingo->c_mci); g_lingo->codeString($2->c_str()); delete $2; }
+func: ID begin '(' arglist ')' {
+ g_lingo->code1(g_lingo->c_call);
+ g_lingo->codeString($1->c_str());
+ inst numpar = 0;
+ WRITE_UINT32(&numpar, $4);
+ g_lingo->code1(numpar); };
+ | tMCI STRING { g_lingo->code1(g_lingo->c_mci); g_lingo->codeString($2->c_str()); delete $2; }
| tMCIWAIT ID { g_lingo->code1(g_lingo->c_mciwait); g_lingo->codeString($2->c_str()); delete $2; }
| tPUT expr { g_lingo->code1(g_lingo->c_printtop); }
| gotofunc
@@ -311,11 +317,15 @@ defn: tMACRO ID { g_lingo->_indef = true; }
g_lingo->define(*$2, $4, $7, $5);
g_lingo->_indef = false; }
;
-argdef: /* nothing */ { $$ = 0; }
+argdef: /* nothing */ { $$ = 0; }
| ID { g_lingo->codeArg(*$1); delete $1; $$ = 1; }
| argdef ',' ID { g_lingo->codeArg(*$3); delete $3; $$ = $1 + 1; }
| argdef ',' '\n' ID { g_lingo->codeArg(*$4); delete $4; $$ = $1 + 1; }
;
+arglist: /* nothing */ { $$ = 0; }
+ | expr { $$ = 1; }
+ | arglist ',' expr { $$ = $1 + 1; }
+ ;
%%
diff --git a/engines/director/lingo/lingo.h b/engines/director/lingo/lingo.h
index 519b9141b6..bee947931b 100644
--- a/engines/director/lingo/lingo.h
+++ b/engines/director/lingo/lingo.h
@@ -146,6 +146,7 @@ public:
static void c_lt();
static void c_ge();
static void c_le();
+ static void c_call();
static void c_procret();
static void c_exit();