aboutsummaryrefslogtreecommitdiff
path: root/engines/director
diff options
context:
space:
mode:
authorEugene Sandulenko2016-07-07 19:35:45 +0200
committerEugene Sandulenko2016-08-03 23:40:36 +0200
commit6636c9006bf9e274f6d7e85556f3426e4b3594df (patch)
tree8fb67af9f9bf60939d2d55b805209bd7ab6b6d5e /engines/director
parent1745917752f5ec85f8a3b2b65dc1b2321aa576ab (diff)
downloadscummvm-rg350-6636c9006bf9e274f6d7e85556f3426e4b3594df.tar.gz
scummvm-rg350-6636c9006bf9e274f6d7e85556f3426e4b3594df.tar.bz2
scummvm-rg350-6636c9006bf9e274f6d7e85556f3426e4b3594df.zip
DIRECTOR: Lingo: Provide error position in the file
Diffstat (limited to 'engines/director')
-rw-r--r--engines/director/director.cpp2
-rw-r--r--engines/director/lingo/lingo-gr.cpp770
-rw-r--r--engines/director/lingo/lingo-gr.y21
-rw-r--r--engines/director/lingo/lingo-lex.cpp174
-rw-r--r--engines/director/lingo/lingo-lex.l88
-rw-r--r--engines/director/lingo/lingo.cpp4
-rw-r--r--engines/director/lingo/lingo.h3
7 files changed, 555 insertions, 507 deletions
diff --git a/engines/director/director.cpp b/engines/director/director.cpp
index 29b62e2996..8dc9ca7f67 100644
--- a/engines/director/director.cpp
+++ b/engines/director/director.cpp
@@ -121,7 +121,7 @@ Common::Error DirectorEngine::run() {
else if x = 2 then\n\
put 2.1\n\
put 2.2\n\
- else if x = 3 then put 3\n\
+ else if x = 3 then put 3\n\
end if\n\
if x = 4 then put 4\n\
else put 5\n\
diff --git a/engines/director/lingo/lingo-gr.cpp b/engines/director/lingo/lingo-gr.cpp
index 2b8e37a76a..f295ea0bc3 100644
--- a/engines/director/lingo/lingo-gr.cpp
+++ b/engines/director/lingo/lingo-gr.cpp
@@ -169,7 +169,7 @@
extern int yylex();
extern int yyparse();
-void yyerror(char *s) { error("%s", s); }
+void yyerror(char *s) { error("%s at line %d col %d", s, Director::g_lingo->_linenumber, Director::g_lingo->_colnumber); }
using namespace Director;
@@ -432,16 +432,16 @@ union yyalloc
/* YYFINAL -- State number of the termination state. */
#define YYFINAL 61
/* YYLAST -- Last index in YYTABLE. */
-#define YYLAST 383
+#define YYLAST 384
/* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 57
/* YYNNTS -- Number of nonterminals. */
-#define YYNNTS 31
+#define YYNNTS 32
/* YYNRULES -- Number of rules. */
-#define YYNRULES 95
+#define YYNRULES 96
/* YYNRULES -- Number of states. */
-#define YYNSTATES 204
+#define YYNSTATES 205
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2
@@ -490,72 +490,72 @@ static const yytype_uint8 yytranslate[] =
YYRHS. */
static const yytype_uint16 yyprhs[] =
{
- 0, 0, 3, 7, 9, 10, 12, 14, 16, 18,
- 20, 22, 27, 32, 37, 39, 41, 43, 45, 54,
- 66, 79, 88, 100, 112, 119, 130, 141, 142, 146,
- 149, 151, 158, 160, 166, 168, 172, 176, 179, 183,
- 185, 187, 188, 189, 190, 193, 196, 198, 200, 205,
- 210, 212, 214, 218, 222, 226, 230, 234, 238, 242,
- 246, 250, 253, 256, 260, 263, 266, 269, 271, 273,
- 276, 278, 282, 285, 288, 291, 294, 298, 301, 305,
- 308, 311, 313, 317, 320, 324, 325, 334, 335, 337,
- 341, 346, 347, 351, 352, 354
+ 0, 0, 3, 7, 9, 11, 12, 14, 16, 18,
+ 20, 22, 24, 29, 34, 39, 41, 43, 45, 47,
+ 56, 68, 81, 90, 102, 114, 121, 132, 143, 144,
+ 148, 151, 153, 160, 162, 168, 170, 174, 178, 181,
+ 185, 187, 189, 190, 191, 192, 195, 198, 200, 202,
+ 207, 212, 214, 216, 220, 224, 228, 232, 236, 240,
+ 244, 248, 252, 255, 258, 262, 265, 268, 271, 273,
+ 275, 278, 280, 284, 287, 290, 293, 296, 300, 303,
+ 307, 310, 313, 315, 319, 322, 326, 327, 336, 337,
+ 339, 343, 348, 349, 353, 354, 356
};
/* YYRHS -- A `-1'-separated list of the rules' RHS. */
static const yytype_int8 yyrhs[] =
{
- 58, 0, -1, 58, 51, 59, -1, 59, -1, -1,
- 82, -1, 77, -1, 86, -1, 60, -1, 62, -1,
- 1, -1, 31, 76, 22, 10, -1, 33, 10, 45,
- 76, -1, 33, 10, 35, 76, -1, 76, -1, 77,
- -1, 61, -1, 63, -1, 69, 52, 68, 53, 75,
- 74, 16, 32, -1, 70, 45, 76, 74, 35, 76,
- 74, 75, 74, 16, 32, -1, 70, 45, 76, 74,
- 13, 35, 76, 74, 75, 74, 16, 32, -1, 71,
- 68, 34, 51, 75, 74, 16, 21, -1, 71, 68,
- 34, 51, 75, 74, 14, 75, 74, 16, 21, -1,
- 71, 68, 34, 51, 75, 74, 73, 65, 74, 16,
- 21, -1, 71, 68, 34, 73, 61, 74, -1, 71,
- 68, 34, 73, 61, 74, 38, 73, 61, 74, -1,
- 71, 68, 34, 73, 61, 74, 66, 74, 64, 74,
- -1, -1, 38, 73, 61, -1, 65, 67, -1, 67,
- -1, 72, 68, 34, 73, 62, 74, -1, 66, -1,
- 72, 68, 34, 75, 74, -1, 76, -1, 76, 45,
- 76, -1, 52, 68, 53, -1, 32, 37, -1, 32,
- 36, 10, -1, 21, -1, 15, -1, -1, -1, -1,
- 75, 51, -1, 75, 62, -1, 7, -1, 8, -1,
- 9, 52, 87, 53, -1, 10, 52, 87, 53, -1,
- 10, -1, 60, -1, 76, 46, 76, -1, 76, 47,
- 76, -1, 76, 48, 76, -1, 76, 49, 76, -1,
- 76, 54, 76, -1, 76, 55, 76, -1, 76, 44,
- 76, -1, 76, 39, 76, -1, 76, 40, 76, -1,
- 46, 76, -1, 47, 76, -1, 52, 76, 53, -1,
- 25, 11, -1, 26, 10, -1, 31, 76, -1, 79,
- -1, 17, -1, 19, 78, -1, 10, -1, 78, 56,
- 10, -1, 20, 23, -1, 20, 28, -1, 20, 30,
- -1, 20, 80, -1, 20, 80, 81, -1, 20, 81,
- -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, 83, 73, 84,
- 51, 85, 75, -1, -1, 10, -1, 84, 56, 10,
- -1, 84, 51, 56, 10, -1, -1, 10, 73, 87,
- -1, -1, 76, -1, 87, 56, 76, -1
+ 58, 0, -1, 58, 59, 60, -1, 60, -1, 51,
+ -1, -1, 83, -1, 78, -1, 87, -1, 61, -1,
+ 63, -1, 1, -1, 31, 77, 22, 10, -1, 33,
+ 10, 45, 77, -1, 33, 10, 35, 77, -1, 77,
+ -1, 78, -1, 62, -1, 64, -1, 70, 52, 69,
+ 53, 76, 75, 16, 32, -1, 71, 45, 77, 75,
+ 35, 77, 75, 76, 75, 16, 32, -1, 71, 45,
+ 77, 75, 13, 35, 77, 75, 76, 75, 16, 32,
+ -1, 72, 69, 34, 59, 76, 75, 16, 21, -1,
+ 72, 69, 34, 59, 76, 75, 14, 76, 75, 16,
+ 21, -1, 72, 69, 34, 59, 76, 75, 74, 66,
+ 75, 16, 21, -1, 72, 69, 34, 74, 62, 75,
+ -1, 72, 69, 34, 74, 62, 75, 38, 74, 62,
+ 75, -1, 72, 69, 34, 74, 62, 75, 67, 75,
+ 65, 75, -1, -1, 38, 74, 62, -1, 66, 68,
+ -1, 68, -1, 73, 69, 34, 74, 63, 75, -1,
+ 67, -1, 73, 69, 34, 76, 75, -1, 77, -1,
+ 77, 45, 77, -1, 52, 69, 53, -1, 32, 37,
+ -1, 32, 36, 10, -1, 21, -1, 15, -1, -1,
+ -1, -1, 76, 59, -1, 76, 63, -1, 7, -1,
+ 8, -1, 9, 52, 88, 53, -1, 10, 52, 88,
+ 53, -1, 10, -1, 61, -1, 77, 46, 77, -1,
+ 77, 47, 77, -1, 77, 48, 77, -1, 77, 49,
+ 77, -1, 77, 54, 77, -1, 77, 55, 77, -1,
+ 77, 44, 77, -1, 77, 39, 77, -1, 77, 40,
+ 77, -1, 46, 77, -1, 47, 77, -1, 52, 77,
+ 53, -1, 25, 11, -1, 26, 10, -1, 31, 77,
+ -1, 80, -1, 17, -1, 19, 79, -1, 10, -1,
+ 79, 56, 10, -1, 20, 23, -1, 20, 28, -1,
+ 20, 30, -1, 20, 81, -1, 20, 81, 82, -1,
+ 20, 82, -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, 84,
+ 74, 85, 59, 86, 76, -1, -1, 10, -1, 85,
+ 56, 10, -1, 85, 59, 56, 10, -1, -1, 10,
+ 74, 88, -1, -1, 77, -1, 88, 56, 77, -1
};
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
static const yytype_uint16 yyrline[] =
{
- 0, 93, 93, 94, 97, 98, 99, 100, 101, 102,
- 103, 106, 112, 118, 125, 126, 128, 129, 134, 145,
- 161, 175, 182, 191, 200, 210, 220, 231, 232, 235,
- 236, 239, 246, 247, 255, 256, 257, 259, 261, 267,
- 273, 280, 282, 284, 285, 286, 289, 294, 297, 303,
- 311, 314, 315, 316, 317, 318, 319, 320, 321, 322,
- 323, 324, 325, 326, 329, 330, 331, 332, 333, 335,
- 338, 339, 350, 351, 352, 353, 358, 364, 371, 372,
- 373, 374, 377, 378, 379, 407, 407, 414, 415, 416,
- 417, 419, 422, 430, 431, 432
+ 0, 93, 93, 94, 97, 102, 103, 104, 105, 106,
+ 107, 108, 111, 117, 123, 130, 131, 133, 134, 139,
+ 150, 166, 180, 187, 196, 205, 215, 225, 236, 237,
+ 240, 241, 244, 251, 252, 260, 261, 262, 264, 266,
+ 272, 278, 285, 287, 289, 290, 291, 294, 299, 302,
+ 308, 316, 319, 320, 321, 322, 323, 324, 325, 326,
+ 327, 328, 329, 330, 331, 334, 335, 336, 337, 338,
+ 340, 343, 344, 355, 356, 357, 358, 363, 369, 376,
+ 377, 378, 379, 382, 383, 384, 412, 412, 419, 420,
+ 421, 422, 424, 427, 435, 436, 437
};
#endif
@@ -571,7 +571,7 @@ static const char *const yytname[] =
"tPREVIOUS", "tPUT", "tREPEAT", "tSET", "tTHEN", "tTO", "tWITH",
"tWHILE", "tNLELSE", "tGE", "tLE", "tGT", "tLT", "tEQ", "tNEQ", "'='",
"'+'", "'-'", "'*'", "'/'", "'%'", "'\\n'", "'('", "')'", "'>'", "'<'",
- "','", "$accept", "program", "programline", "asgn", "stmtoneliner",
+ "','", "$accept", "program", "nl", "programline", "asgn", "stmtoneliner",
"stmt", "ifstmt", "elsestmtoneliner", "elseifstmt", "elseifstmtoneliner",
"elseifstmt1", "cond", "repeatwhile", "repeatwith", "if", "elseif",
"begin", "end", "stmtlist", "expr", "func", "globallist", "gotofunc",
@@ -597,31 +597,31 @@ static const yytype_uint16 yytoknum[] =
/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
static const yytype_uint8 yyr1[] =
{
- 0, 57, 58, 58, 59, 59, 59, 59, 59, 59,
- 59, 60, 60, 60, 61, 61, 62, 62, 62, 62,
- 62, 63, 63, 63, 63, 63, 63, 64, 64, 65,
- 65, 66, 67, 67, 68, 68, 68, 69, 70, 71,
- 72, 73, 74, 75, 75, 75, 76, 76, 76, 76,
- 76, 76, 76, 76, 76, 76, 76, 76, 76, 76,
- 76, 76, 76, 76, 77, 77, 77, 77, 77, 77,
- 78, 78, 79, 79, 79, 79, 79, 79, 80, 80,
- 80, 80, 81, 81, 81, 83, 82, 84, 84, 84,
- 84, 85, 86, 87, 87, 87
+ 0, 57, 58, 58, 59, 60, 60, 60, 60, 60,
+ 60, 60, 61, 61, 61, 62, 62, 63, 63, 63,
+ 63, 63, 64, 64, 64, 64, 64, 64, 65, 65,
+ 66, 66, 67, 68, 68, 69, 69, 69, 70, 71,
+ 72, 73, 74, 75, 76, 76, 76, 77, 77, 77,
+ 77, 77, 77, 77, 77, 77, 77, 77, 77, 77,
+ 77, 77, 77, 77, 77, 78, 78, 78, 78, 78,
+ 78, 79, 79, 80, 80, 80, 80, 80, 80, 81,
+ 81, 81, 81, 82, 82, 82, 84, 83, 85, 85,
+ 85, 85, 86, 87, 88, 88, 88
};
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
static const yytype_uint8 yyr2[] =
{
- 0, 2, 3, 1, 0, 1, 1, 1, 1, 1,
- 1, 4, 4, 4, 1, 1, 1, 1, 8, 11,
- 12, 8, 11, 11, 6, 10, 10, 0, 3, 2,
- 1, 6, 1, 5, 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
+ 0, 2, 3, 1, 1, 0, 1, 1, 1, 1,
+ 1, 1, 4, 4, 4, 1, 1, 1, 1, 8,
+ 11, 12, 8, 11, 11, 6, 10, 10, 0, 3,
+ 2, 1, 6, 1, 5, 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
@@ -629,36 +629,36 @@ static const yytype_uint8 yyr2[] =
means the default is an error. */
static const yytype_uint8 yydefact[] =
{
- 0, 10, 46, 47, 0, 41, 68, 0, 0, 39,
+ 0, 11, 47, 48, 0, 42, 69, 0, 0, 40,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 3, 51, 16, 9, 17, 0, 0, 0, 14, 6,
- 67, 5, 7, 93, 93, 93, 70, 69, 81, 0,
- 72, 0, 73, 0, 74, 0, 75, 77, 85, 64,
- 65, 50, 0, 51, 66, 0, 37, 0, 61, 62,
- 0, 1, 0, 0, 0, 0, 0, 34, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 94, 0, 0,
- 92, 0, 79, 83, 0, 80, 0, 0, 0, 76,
- 41, 0, 0, 38, 0, 0, 63, 2, 0, 42,
- 0, 0, 41, 0, 59, 60, 58, 52, 53, 54,
- 55, 56, 57, 48, 0, 49, 71, 82, 78, 84,
- 87, 11, 13, 12, 43, 0, 36, 43, 0, 35,
- 95, 88, 0, 42, 0, 0, 42, 42, 15, 91,
- 0, 44, 45, 0, 0, 42, 41, 24, 0, 43,
- 89, 0, 42, 43, 43, 0, 0, 40, 41, 42,
- 0, 90, 86, 18, 43, 42, 42, 21, 42, 32,
- 30, 0, 0, 27, 0, 42, 0, 0, 29, 0,
- 0, 42, 41, 42, 41, 0, 0, 0, 0, 41,
- 25, 0, 26, 0, 0, 19, 22, 23, 42, 28,
- 42, 20, 33, 31
+ 3, 52, 17, 10, 18, 0, 0, 0, 15, 7,
+ 68, 6, 8, 94, 94, 94, 71, 70, 82, 0,
+ 73, 0, 74, 0, 75, 0, 76, 78, 86, 65,
+ 66, 51, 0, 52, 67, 0, 38, 0, 62, 63,
+ 0, 1, 4, 0, 0, 0, 0, 0, 35, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 95, 0,
+ 0, 93, 0, 80, 84, 0, 81, 0, 0, 0,
+ 77, 42, 0, 0, 39, 0, 0, 64, 2, 0,
+ 43, 0, 0, 42, 0, 60, 61, 59, 53, 54,
+ 55, 56, 57, 58, 49, 0, 50, 72, 83, 79,
+ 85, 88, 12, 14, 13, 44, 0, 37, 44, 0,
+ 36, 96, 89, 0, 43, 0, 0, 43, 43, 16,
+ 0, 92, 45, 46, 0, 0, 43, 42, 25, 90,
+ 0, 44, 0, 43, 44, 44, 0, 0, 41, 42,
+ 43, 0, 91, 87, 19, 44, 43, 43, 22, 43,
+ 33, 31, 0, 0, 28, 0, 43, 0, 0, 30,
+ 0, 0, 43, 42, 43, 42, 0, 0, 0, 0,
+ 42, 26, 0, 27, 0, 0, 20, 23, 24, 43,
+ 29, 43, 21, 34, 32
};
/* YYDEFGOTO[NTERM-NUM]. */
static const yytype_int16 yydefgoto[] =
{
- -1, 19, 20, 53, 22, 142, 24, 183, 168, 169,
- 170, 66, 25, 26, 27, 171, 193, 125, 133, 28,
- 138, 37, 30, 46, 47, 31, 90, 132, 149, 32,
- 78
+ -1, 19, 142, 20, 53, 22, 143, 24, 184, 169,
+ 170, 171, 67, 25, 26, 27, 172, 194, 126, 134,
+ 28, 139, 37, 30, 46, 47, 31, 91, 133, 151,
+ 32, 79
};
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
@@ -666,127 +666,127 @@ static const yytype_int16 yydefgoto[] =
#define YYPACT_NINF -124
static const yytype_int16 yypact[] =
{
- 143, -124, -124, -124, -39, 328, -124, 35, 287, -124,
- 40, 15, 41, 172, -25, 46, 172, 172, 172, 3,
- -124, 7, -124, -124, -124, 8, 18, 218, 316, -124,
- -124, -124, -124, 172, 172, 172, -124, 31, -124, 77,
- -124, 78, -124, 63, -124, 13, 32, -124, -124, -124,
- -124, 39, 172, -124, 86, 82, -124, -20, -17, -17,
- 292, -124, 143, 218, 172, 218, 60, 304, 172, 172,
- 172, 172, 172, 172, 172, 172, 172, 316, -23, -1,
- 47, 87, -124, -124, 90, -124, 91, 94, 79, -124,
- -124, 86, 99, -124, 172, 172, -124, -124, 58, 316,
- 59, 280, 66, 172, 316, 316, 316, 240, 240, -17,
- -17, 316, 316, -124, 172, -124, -124, -124, -124, -124,
- 108, -124, 316, 316, -124, -3, -124, -124, 266, 316,
- 316, -124, -8, 189, 84, 172, 189, -124, -124, 64,
- 111, -124, -124, 106, 172, 316, 25, -9, 114, -124,
- -124, 95, 316, -124, -124, 107, 122, -124, -124, -124,
- 218, -124, 189, -124, -124, 189, 189, -124, 122, -124,
- -124, 218, 266, 100, 105, 189, 131, 133, -124, 139,
- 123, -124, -124, -124, -124, 140, 126, 138, 144, -7,
- -124, 266, -124, 235, 134, -124, -124, -124, 189, -124,
- -124, -124, -124, -124
+ 144, -124, -124, -124, -40, 329, -124, 23, 288, -124,
+ 28, 29, 37, 173, 6, 42, 173, 173, 173, 7,
+ -124, 9, -124, -124, -124, 5, 17, 219, 317, -124,
+ -124, -124, -124, 173, 173, 173, -124, 8, -124, 50,
+ -124, 57, -124, 53, -124, 12, -3, -124, -124, -124,
+ -124, 38, 173, -124, 87, 71, -124, -14, 148, 148,
+ 293, -124, -124, 144, 219, 173, 219, 55, 305, 173,
+ 173, 173, 173, 173, 173, 173, 173, 173, 317, -12,
+ -2, 35, 82, -124, -124, 84, -124, 91, 92, 66,
+ -124, -124, 87, 88, -124, 173, 173, -124, -124, 51,
+ 317, 54, 281, 59, 173, 317, 317, 317, 241, 241,
+ 148, 148, 317, 317, -124, 173, -124, -124, -124, -124,
+ -124, 96, -124, 317, 317, -124, 2, -124, -124, 267,
+ 317, 317, -124, -43, 190, 77, 173, 190, -124, -124,
+ 103, 63, -124, -124, 104, 173, 317, 13, -13, -124,
+ 111, -124, 90, 317, -124, -124, 102, 110, -124, -124,
+ -124, 219, -124, 190, -124, -124, 190, 190, -124, 110,
+ -124, -124, 219, 267, 100, 94, 190, 113, 123, -124,
+ 124, 114, -124, -124, -124, -124, 134, 125, 135, 137,
+ -5, -124, 267, -124, 236, 127, -124, -124, -124, 190,
+ -124, -124, -124, -124, -124
};
/* YYPGOTO[NTERM-NUM]. */
static const yytype_int16 yypgoto[] =
{
- -124, -124, 109, 16, -123, 0, -124, -124, -124, 23,
- 5, -61, -124, -124, -124, 30, -4, -52, -107, 1,
- 21, -124, -124, -124, 137, -124, -124, -124, -124, -124,
- 45
+ -124, -124, -15, 97, 16, -123, 0, -124, -124, -124,
+ 18, 3, -61, -124, -124, -124, 19, -4, -52, -106,
+ 1, 20, -124, -124, -124, 128, -124, -124, -124, -124,
+ -124, 21
};
/* 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 -51
+#define YYTABLE_NINF -52
static const yytype_int16 yytable[] =
{
- 23, 35, 98, 61, 100, 137, 157, -8, -43, -43,
- 134, 55, 56, 33, 54, 94, 21, 58, 59, 60,
- 136, 29, 68, 69, 85, 95, 49, 70, 67, 158,
- 113, 86, 135, 114, 77, 77, 77, 75, 76, 154,
- 87, 155, 162, 139, -43, 36, 165, 166, 140, 181,
- 48, 50, 115, 91, 62, 114, 57, 175, -8, 41,
- 63, 43, 23, 64, 67, 99, 101, 88, 199, 104,
- 105, 106, 107, 108, 109, 110, 111, 112, 21, 79,
- 80, 143, 198, 29, 146, 147, 120, 81, 82, 83,
- 84, 34, 93, 153, 102, 122, 123, 116, 128, 174,
- 164, 117, 118, 114, 129, 119, 87, 173, 92, 121,
- 180, 124, 126, 176, 177, 130, 179, 127, 131, 144,
- 148, 150, 151, 185, 161, 68, 69, 163, 167, 190,
- 70, 192, 71, 72, 73, 74, 145, 157, 182, 184,
- 75, 76, 156, -4, 1, 152, 202, 186, 203, 187,
- 2, 3, 4, 5, 172, 188, 194, 189, 195, 196,
- 6, 67, 7, 8, 9, 197, 201, 10, 11, 12,
- 159, 97, 67, 178, 13, 14, 15, 160, 191, 2,
- 3, 4, 51, 89, 0, 0, 0, 0, 0, 16,
- 17, 0, 0, 200, -4, 18, 2, 3, 4, 51,
- 0, 0, 0, 52, 0, 15, 6, 0, 7, 8,
- 9, 0, 0, 0, 11, 12, 0, 0, 16, 17,
- 13, 14, 15, 0, 18, 2, 3, 4, 51, 0,
- 0, 0, 0, 0, 0, 16, 17, 0, 0, 0,
- 141, 18, 2, 3, 4, 51, 0, 0, 0, 52,
- 0, 15, 6, 0, 7, 8, 9, 0, 0, 0,
- 11, 12, 0, 0, 16, 17, 13, 14, 15, 0,
- 65, 0, 0, 2, 3, 4, 51, 0, 0, 68,
- 69, 16, 17, 6, 70, 7, 8, 18, 73, 74,
- 0, 11, 12, 0, 75, 76, 0, 13, 38, 15,
- 0, 0, 0, 0, 0, 39, 0, 0, 0, 0,
- 40, 0, 16, 17, 41, 42, 43, 44, 18, 68,
- 69, 0, 45, 0, 70, 103, 71, 72, 73, 74,
- 0, 68, 69, 96, 75, 76, 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, -50, -50, 0,
- 75, 76, -50, 0, 0, 0, -50, -50, 0, 0,
- 34, 0, -50, -50
+ 23, 35, 158, 99, 63, 101, 138, 61, 62, -9,
+ -44, -44, 33, 140, 54, 135, 21, 58, 59, 60,
+ 29, 95, 137, 86, 41, 159, 43, 155, 68, 156,
+ 87, 96, 89, 36, 78, 78, 78, 136, 48, 88,
+ 49, 114, 55, 56, 115, 163, -44, 50, 166, 167,
+ 182, 116, 57, 92, 115, 80, 81, 64, 62, 176,
+ -9, 83, 65, 23, 82, 68, 100, 102, 84, 200,
+ 105, 106, 107, 108, 109, 110, 111, 112, 113, 21,
+ 85, 94, 144, 29, 199, 147, 148, 121, 128, 103,
+ 34, 115, 117, 88, 154, 118, 123, 124, 122, 129,
+ 175, 165, 119, 120, 125, 130, 132, 127, 174, 93,
+ 62, 181, 145, 149, 177, 178, 131, 180, 141, 150,
+ 152, 162, 164, 168, 186, 158, 69, 70, 185, 187,
+ 191, 71, 193, 72, 73, 74, 75, 146, 183, 188,
+ 189, 76, 77, 157, -5, 1, 153, 203, 190, 204,
+ 195, 2, 3, 4, 5, 173, 197, 196, 198, 202,
+ 98, 6, 68, 7, 8, 9, 160, 161, 10, 11,
+ 12, 0, 179, 68, 90, 13, 14, 15, 0, 192,
+ 2, 3, 4, 51, 0, 0, 0, 69, 70, 0,
+ 16, 17, 71, 0, 201, -5, 18, 2, 3, 4,
+ 51, 0, 76, 77, 52, 0, 15, 6, 0, 7,
+ 8, 9, 0, 0, 0, 11, 12, 0, 0, 16,
+ 17, 13, 14, 15, 0, 18, 2, 3, 4, 51,
+ 0, 0, 0, 0, 0, 0, 16, 17, 0, 0,
+ 0, 62, 18, 2, 3, 4, 51, 0, 0, 0,
+ 52, 0, 15, 6, 0, 7, 8, 9, 0, 0,
+ 0, 11, 12, 0, 0, 16, 17, 13, 14, 15,
+ 0, 66, 0, 0, 2, 3, 4, 51, 0, 0,
+ 69, 70, 16, 17, 6, 71, 7, 8, 18, 74,
+ 75, 0, 11, 12, 0, 76, 77, 0, 13, 38,
+ 15, 0, 0, 0, 0, 0, 39, 0, 0, 0,
+ 0, 40, 0, 16, 17, 41, 42, 43, 44, 18,
+ 69, 70, 0, 45, 0, 71, 104, 72, 73, 74,
+ 75, 0, 69, 70, 97, 76, 77, 71, 0, 72,
+ 73, 74, 75, 0, 69, 70, 97, 76, 77, 71,
+ 104, 72, 73, 74, 75, 0, 69, 70, 0, 76,
+ 77, 71, 0, 72, 73, 74, 75, 0, -51, -51,
+ 0, 76, 77, -51, 0, 0, 0, -51, -51, 0,
+ 0, 34, 0, -51, -51
};
static const yytype_int16 yycheck[] =
{
- 0, 5, 63, 0, 65, 128, 15, 0, 15, 16,
- 13, 36, 37, 52, 13, 35, 0, 16, 17, 18,
- 127, 0, 39, 40, 11, 45, 11, 44, 27, 38,
- 53, 18, 35, 56, 33, 34, 35, 54, 55, 14,
- 27, 16, 149, 51, 51, 10, 153, 154, 56, 172,
- 10, 10, 53, 52, 51, 56, 10, 164, 51, 27,
- 52, 29, 62, 45, 63, 64, 65, 35, 191, 68,
- 69, 70, 71, 72, 73, 74, 75, 76, 62, 34,
- 35, 133, 189, 62, 136, 137, 90, 56, 11, 11,
- 27, 52, 10, 145, 34, 94, 95, 10, 102, 160,
- 152, 11, 11, 56, 103, 11, 27, 159, 22, 10,
- 171, 53, 53, 165, 166, 114, 168, 51, 10, 35,
- 56, 10, 16, 175, 10, 39, 40, 32, 21, 181,
- 44, 183, 46, 47, 48, 49, 135, 15, 38, 34,
- 54, 55, 146, 0, 1, 144, 198, 16, 200, 16,
- 7, 8, 9, 10, 158, 16, 16, 34, 32, 21,
- 17, 160, 19, 20, 21, 21, 32, 24, 25, 26,
- 147, 62, 171, 168, 31, 32, 33, 147, 182, 7,
- 8, 9, 10, 46, -1, -1, -1, -1, -1, 46,
- 47, -1, -1, 193, 51, 52, 7, 8, 9, 10,
- -1, -1, -1, 31, -1, 33, 17, -1, 19, 20,
- 21, -1, -1, -1, 25, 26, -1, -1, 46, 47,
- 31, 32, 33, -1, 52, 7, 8, 9, 10, -1,
- -1, -1, -1, -1, -1, 46, 47, -1, -1, -1,
- 51, 52, 7, 8, 9, 10, -1, -1, -1, 31,
- -1, 33, 17, -1, 19, 20, 21, -1, -1, -1,
- 25, 26, -1, -1, 46, 47, 31, 32, 33, -1,
- 52, -1, -1, 7, 8, 9, 10, -1, -1, 39,
- 40, 46, 47, 17, 44, 19, 20, 52, 48, 49,
- -1, 25, 26, -1, 54, 55, -1, 31, 11, 33,
- -1, -1, -1, -1, -1, 18, -1, -1, -1, -1,
- 23, -1, 46, 47, 27, 28, 29, 30, 52, 39,
- 40, -1, 35, -1, 44, 45, 46, 47, 48, 49,
- -1, 39, 40, 53, 54, 55, 44, -1, 46, 47,
- 48, 49, -1, 39, 40, 53, 54, 55, 44, 45,
- 46, 47, 48, 49, -1, 39, 40, -1, 54, 55,
- 44, -1, 46, 47, 48, 49, -1, 39, 40, -1,
- 54, 55, 44, -1, -1, -1, 48, 49, -1, -1,
- 52, -1, 54, 55
+ 0, 5, 15, 64, 19, 66, 129, 0, 51, 0,
+ 15, 16, 52, 56, 13, 13, 0, 16, 17, 18,
+ 0, 35, 128, 11, 27, 38, 29, 14, 27, 16,
+ 18, 45, 35, 10, 33, 34, 35, 35, 10, 27,
+ 11, 53, 36, 37, 56, 151, 51, 10, 154, 155,
+ 173, 53, 10, 52, 56, 34, 35, 52, 51, 165,
+ 51, 11, 45, 63, 56, 64, 65, 66, 11, 192,
+ 69, 70, 71, 72, 73, 74, 75, 76, 77, 63,
+ 27, 10, 134, 63, 190, 137, 138, 91, 103, 34,
+ 52, 56, 10, 27, 146, 11, 95, 96, 10, 103,
+ 161, 153, 11, 11, 53, 104, 10, 53, 160, 22,
+ 51, 172, 35, 10, 166, 167, 115, 169, 133, 56,
+ 16, 10, 32, 21, 176, 15, 39, 40, 34, 16,
+ 182, 44, 184, 46, 47, 48, 49, 136, 38, 16,
+ 16, 54, 55, 147, 0, 1, 145, 199, 34, 201,
+ 16, 7, 8, 9, 10, 159, 21, 32, 21, 32,
+ 63, 17, 161, 19, 20, 21, 148, 148, 24, 25,
+ 26, -1, 169, 172, 46, 31, 32, 33, -1, 183,
+ 7, 8, 9, 10, -1, -1, -1, 39, 40, -1,
+ 46, 47, 44, -1, 194, 51, 52, 7, 8, 9,
+ 10, -1, 54, 55, 31, -1, 33, 17, -1, 19,
+ 20, 21, -1, -1, -1, 25, 26, -1, -1, 46,
+ 47, 31, 32, 33, -1, 52, 7, 8, 9, 10,
+ -1, -1, -1, -1, -1, -1, 46, 47, -1, -1,
+ -1, 51, 52, 7, 8, 9, 10, -1, -1, -1,
+ 31, -1, 33, 17, -1, 19, 20, 21, -1, -1,
+ -1, 25, 26, -1, -1, 46, 47, 31, 32, 33,
+ -1, 52, -1, -1, 7, 8, 9, 10, -1, -1,
+ 39, 40, 46, 47, 17, 44, 19, 20, 52, 48,
+ 49, -1, 25, 26, -1, 54, 55, -1, 31, 11,
+ 33, -1, -1, -1, -1, -1, 18, -1, -1, -1,
+ -1, 23, -1, 46, 47, 27, 28, 29, 30, 52,
+ 39, 40, -1, 35, -1, 44, 45, 46, 47, 48,
+ 49, -1, 39, 40, 53, 54, 55, 44, -1, 46,
+ 47, 48, 49, -1, 39, 40, 53, 54, 55, 44,
+ 45, 46, 47, 48, 49, -1, 39, 40, -1, 54,
+ 55, 44, -1, 46, 47, 48, 49, -1, 39, 40,
+ -1, 54, 55, 44, -1, -1, -1, 48, 49, -1,
+ -1, 52, -1, 54, 55
};
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
@@ -795,25 +795,25 @@ static const yytype_uint8 yystos[] =
{
0, 1, 7, 8, 9, 10, 17, 19, 20, 21,
24, 25, 26, 31, 32, 33, 46, 47, 52, 58,
- 59, 60, 61, 62, 63, 69, 70, 71, 76, 77,
- 79, 82, 86, 52, 52, 73, 10, 78, 11, 18,
- 23, 27, 28, 29, 30, 35, 80, 81, 10, 11,
- 10, 10, 31, 60, 76, 36, 37, 10, 76, 76,
- 76, 0, 51, 52, 45, 52, 68, 76, 39, 40,
- 44, 46, 47, 48, 49, 54, 55, 76, 87, 87,
- 87, 56, 11, 11, 27, 11, 18, 27, 35, 81,
- 83, 76, 22, 10, 35, 45, 53, 59, 68, 76,
- 68, 76, 34, 45, 76, 76, 76, 76, 76, 76,
- 76, 76, 76, 53, 56, 53, 10, 11, 11, 11,
- 73, 10, 76, 76, 53, 74, 53, 51, 73, 76,
- 76, 10, 84, 75, 13, 35, 75, 61, 77, 51,
- 56, 51, 62, 74, 35, 76, 74, 74, 56, 85,
- 10, 16, 76, 74, 14, 16, 73, 15, 38, 66,
- 72, 10, 75, 32, 74, 75, 75, 21, 65, 66,
- 67, 72, 73, 74, 68, 75, 74, 74, 67, 74,
- 68, 61, 38, 64, 34, 74, 16, 16, 16, 34,
- 74, 73, 74, 73, 16, 32, 21, 21, 75, 61,
- 62, 32, 74, 74
+ 60, 61, 62, 63, 64, 70, 71, 72, 77, 78,
+ 80, 83, 87, 52, 52, 74, 10, 79, 11, 18,
+ 23, 27, 28, 29, 30, 35, 81, 82, 10, 11,
+ 10, 10, 31, 61, 77, 36, 37, 10, 77, 77,
+ 77, 0, 51, 59, 52, 45, 52, 69, 77, 39,
+ 40, 44, 46, 47, 48, 49, 54, 55, 77, 88,
+ 88, 88, 56, 11, 11, 27, 11, 18, 27, 35,
+ 82, 84, 77, 22, 10, 35, 45, 53, 60, 69,
+ 77, 69, 77, 34, 45, 77, 77, 77, 77, 77,
+ 77, 77, 77, 77, 53, 56, 53, 10, 11, 11,
+ 11, 74, 10, 77, 77, 53, 75, 53, 59, 74,
+ 77, 77, 10, 85, 76, 13, 35, 76, 62, 78,
+ 56, 59, 59, 63, 75, 35, 77, 75, 75, 10,
+ 56, 86, 16, 77, 75, 14, 16, 74, 15, 38,
+ 67, 73, 10, 76, 32, 75, 76, 76, 21, 66,
+ 67, 68, 73, 74, 75, 69, 76, 75, 75, 68,
+ 75, 69, 62, 38, 65, 34, 75, 16, 16, 16,
+ 34, 75, 74, 75, 74, 16, 32, 21, 21, 76,
+ 62, 63, 32, 75, 75
};
#define yyerrok (yyerrstatus = 0)
@@ -1627,18 +1627,26 @@ yyreduce:
YY_REDUCE_PRINT (yyn);
switch (yyn)
{
- case 8:
-#line 101 "engines/director/lingo/lingo-gr.y"
+ case 4:
+#line 97 "engines/director/lingo/lingo-gr.y"
+ {
+ g_lingo->_linenumber++;
+ g_lingo->_colnumber = 1;
+ ;}
+ break;
+
+ case 9:
+#line 106 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_xpop); ;}
break;
- case 10:
-#line 103 "engines/director/lingo/lingo-gr.y"
+ case 11:
+#line 108 "engines/director/lingo/lingo-gr.y"
{ yyerrok; ;}
break;
- case 11:
-#line 106 "engines/director/lingo/lingo-gr.y"
+ case 12:
+#line 111 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_varpush);
g_lingo->codeString((yyvsp[(4) - (4)].s)->c_str());
@@ -1647,8 +1655,8 @@ yyreduce:
delete (yyvsp[(4) - (4)].s); ;}
break;
- case 12:
-#line 112 "engines/director/lingo/lingo-gr.y"
+ case 13:
+#line 117 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_varpush);
g_lingo->codeString((yyvsp[(2) - (4)].s)->c_str());
@@ -1657,8 +1665,8 @@ yyreduce:
delete (yyvsp[(2) - (4)].s); ;}
break;
- case 13:
-#line 118 "engines/director/lingo/lingo-gr.y"
+ case 14:
+#line 123 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_varpush);
g_lingo->codeString((yyvsp[(2) - (4)].s)->c_str());
@@ -1667,13 +1675,13 @@ yyreduce:
delete (yyvsp[(2) - (4)].s); ;}
break;
- case 14:
-#line 125 "engines/director/lingo/lingo-gr.y"
+ case 15:
+#line 130 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_xpop); ;}
break;
- case 18:
-#line 134 "engines/director/lingo/lingo-gr.y"
+ case 19:
+#line 139 "engines/director/lingo/lingo-gr.y"
{
inst body = 0, end = 0;
WRITE_UINT32(&body, (yyvsp[(5) - (8)].code));
@@ -1682,8 +1690,8 @@ yyreduce:
(*g_lingo->_currentScript)[(yyvsp[(1) - (8)].code) + 2] = end; ;}
break;
- case 19:
-#line 145 "engines/director/lingo/lingo-gr.y"
+ case 20:
+#line 150 "engines/director/lingo/lingo-gr.y"
{
inst init = 0, finish = 0, body = 0, end = 0, inc = 0;
WRITE_UINT32(&init, (yyvsp[(3) - (11)].code));
@@ -1698,8 +1706,8 @@ yyreduce:
(*g_lingo->_currentScript)[(yyvsp[(1) - (11)].code) + 5] = end; ;}
break;
- case 20:
-#line 161 "engines/director/lingo/lingo-gr.y"
+ case 21:
+#line 166 "engines/director/lingo/lingo-gr.y"
{
inst init = 0, finish = 0, body = 0, end = 0, inc = 0;
WRITE_UINT32(&init, (yyvsp[(3) - (12)].code));
@@ -1714,8 +1722,8 @@ yyreduce:
(*g_lingo->_currentScript)[(yyvsp[(1) - (12)].code) + 5] = end; ;}
break;
- case 21:
-#line 175 "engines/director/lingo/lingo-gr.y"
+ case 22:
+#line 180 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, end = 0;
WRITE_UINT32(&then, (yyvsp[(5) - (8)].code));
@@ -1725,8 +1733,8 @@ yyreduce:
g_lingo->processIf(0, 0); ;}
break;
- case 22:
-#line 182 "engines/director/lingo/lingo-gr.y"
+ case 23:
+#line 187 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, (yyvsp[(5) - (11)].code));
@@ -1738,8 +1746,8 @@ yyreduce:
g_lingo->processIf(0, 0); ;}
break;
- case 23:
-#line 191 "engines/director/lingo/lingo-gr.y"
+ case 24:
+#line 196 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, (yyvsp[(5) - (11)].code));
@@ -1751,8 +1759,8 @@ yyreduce:
g_lingo->processIf(0, (yyvsp[(9) - (11)].code)); ;}
break;
- case 24:
-#line 200 "engines/director/lingo/lingo-gr.y"
+ case 25:
+#line 205 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, (yyvsp[(4) - (6)].code));
@@ -1765,8 +1773,8 @@ yyreduce:
g_lingo->processIf(0, 0); ;}
break;
- case 25:
-#line 210 "engines/director/lingo/lingo-gr.y"
+ case 26:
+#line 215 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, (yyvsp[(4) - (10)].code));
@@ -1779,8 +1787,8 @@ yyreduce:
g_lingo->processIf(0, 0); ;}
break;
- case 26:
-#line 220 "engines/director/lingo/lingo-gr.y"
+ case 27:
+#line 225 "engines/director/lingo/lingo-gr.y"
{
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, (yyvsp[(4) - (10)].code));
@@ -1793,18 +1801,18 @@ yyreduce:
g_lingo->processIf(0, (yyvsp[(10) - (10)].code)); ;}
break;
- case 27:
-#line 231 "engines/director/lingo/lingo-gr.y"
+ case 28:
+#line 236 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = 0; ;}
break;
- case 28:
-#line 232 "engines/director/lingo/lingo-gr.y"
+ case 29:
+#line 237 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (3)].code); ;}
break;
- case 31:
-#line 239 "engines/director/lingo/lingo-gr.y"
+ case 32:
+#line 244 "engines/director/lingo/lingo-gr.y"
{
inst then = 0;
WRITE_UINT32(&then, (yyvsp[(4) - (6)].code));
@@ -1813,8 +1821,8 @@ yyreduce:
g_lingo->codeLabel((yyvsp[(1) - (6)].code)); ;}
break;
- case 33:
-#line 247 "engines/director/lingo/lingo-gr.y"
+ case 34:
+#line 252 "engines/director/lingo/lingo-gr.y"
{
inst then = 0;
WRITE_UINT32(&then, (yyvsp[(4) - (5)].code));
@@ -1823,23 +1831,23 @@ yyreduce:
g_lingo->codeLabel((yyvsp[(1) - (5)].code)); ;}
break;
- case 34:
-#line 255 "engines/director/lingo/lingo-gr.y"
+ case 35:
+#line 260 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(STOP); ;}
break;
- case 35:
-#line 256 "engines/director/lingo/lingo-gr.y"
+ case 36:
+#line 261 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code2(g_lingo->c_eq, STOP); ;}
break;
- case 37:
-#line 259 "engines/director/lingo/lingo-gr.y"
+ case 38:
+#line 264 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = g_lingo->code3(g_lingo->c_repeatwhilecode, STOP, STOP); ;}
break;
- case 38:
-#line 261 "engines/director/lingo/lingo-gr.y"
+ case 39:
+#line 266 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code3(g_lingo->c_repeatwithcode, STOP, STOP);
g_lingo->code3(STOP, STOP, STOP);
@@ -1847,8 +1855,8 @@ yyreduce:
delete (yyvsp[(3) - (3)].s); ;}
break;
- case 39:
-#line 267 "engines/director/lingo/lingo-gr.y"
+ case 40:
+#line 272 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_ifcode);
g_lingo->code3(STOP, STOP, STOP);
@@ -1856,8 +1864,8 @@ yyreduce:
g_lingo->codeLabel(0); ;}
break;
- case 40:
-#line 273 "engines/director/lingo/lingo-gr.y"
+ case 41:
+#line 278 "engines/director/lingo/lingo-gr.y"
{
inst skipEnd;
WRITE_UINT32(&skipEnd, 1); // We have to skip end to avoid multiple executions
@@ -1866,23 +1874,23 @@ yyreduce:
g_lingo->code1(skipEnd); ;}
break;
- case 41:
-#line 280 "engines/director/lingo/lingo-gr.y"
+ case 42:
+#line 285 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = g_lingo->_currentScript->size(); ;}
break;
- case 42:
-#line 282 "engines/director/lingo/lingo-gr.y"
+ case 43:
+#line 287 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(STOP); (yyval.code) = g_lingo->_currentScript->size(); ;}
break;
- case 43:
-#line 284 "engines/director/lingo/lingo-gr.y"
+ case 44:
+#line 289 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = g_lingo->_currentScript->size(); ;}
break;
- case 46:
-#line 289 "engines/director/lingo/lingo-gr.y"
+ case 47:
+#line 294 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_constpush);
inst i = 0;
@@ -1890,15 +1898,15 @@ yyreduce:
g_lingo->code1(i); ;}
break;
- case 47:
-#line 294 "engines/director/lingo/lingo-gr.y"
+ case 48:
+#line 299 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_fconstpush);
g_lingo->codeFloat((yyvsp[(1) - (1)].f)); ;}
break;
- case 48:
-#line 297 "engines/director/lingo/lingo-gr.y"
+ case 49:
+#line 302 "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));
@@ -1907,8 +1915,8 @@ yyreduce:
delete (yyvsp[(1) - (4)].s); ;}
break;
- case 49:
-#line 303 "engines/director/lingo/lingo-gr.y"
+ case 50:
+#line 308 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->code1(g_lingo->c_call);
g_lingo->codeString((yyvsp[(1) - (4)].s)->c_str());
@@ -1919,121 +1927,121 @@ yyreduce:
delete (yyvsp[(1) - (4)].s); ;}
break;
- case 50:
-#line 311 "engines/director/lingo/lingo-gr.y"
+ case 51:
+#line 316 "engines/director/lingo/lingo-gr.y"
{
(yyval.code) = g_lingo->codeId(*(yyvsp[(1) - (1)].s));
delete (yyvsp[(1) - (1)].s); ;}
break;
- case 52:
-#line 315 "engines/director/lingo/lingo-gr.y"
+ case 53:
+#line 320 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_add); ;}
break;
- case 53:
-#line 316 "engines/director/lingo/lingo-gr.y"
+ case 54:
+#line 321 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_sub); ;}
break;
- case 54:
-#line 317 "engines/director/lingo/lingo-gr.y"
+ case 55:
+#line 322 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_mul); ;}
break;
- case 55:
-#line 318 "engines/director/lingo/lingo-gr.y"
+ case 56:
+#line 323 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_div); ;}
break;
- case 56:
-#line 319 "engines/director/lingo/lingo-gr.y"
+ case 57:
+#line 324 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gt); ;}
break;
- case 57:
-#line 320 "engines/director/lingo/lingo-gr.y"
+ case 58:
+#line 325 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_lt); ;}
break;
- case 58:
-#line 321 "engines/director/lingo/lingo-gr.y"
+ case 59:
+#line 326 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_neq); ;}
break;
- case 59:
-#line 322 "engines/director/lingo/lingo-gr.y"
+ case 60:
+#line 327 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_ge); ;}
break;
- case 60:
-#line 323 "engines/director/lingo/lingo-gr.y"
+ case 61:
+#line 328 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_le); ;}
break;
- case 61:
-#line 324 "engines/director/lingo/lingo-gr.y"
+ case 62:
+#line 329 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (2)].code); ;}
break;
- case 62:
-#line 325 "engines/director/lingo/lingo-gr.y"
+ case 63:
+#line 330 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (2)].code); g_lingo->code1(g_lingo->c_negate); ;}
break;
- case 63:
-#line 326 "engines/director/lingo/lingo-gr.y"
+ case 64:
+#line 331 "engines/director/lingo/lingo-gr.y"
{ (yyval.code) = (yyvsp[(2) - (3)].code); ;}
break;
- case 64:
-#line 329 "engines/director/lingo/lingo-gr.y"
+ case 65:
+#line 334 "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 65:
-#line 330 "engines/director/lingo/lingo-gr.y"
+ case 66:
+#line 335 "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 66:
-#line 331 "engines/director/lingo/lingo-gr.y"
+ case 67:
+#line 336 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_printtop); ;}
break;
- case 68:
-#line 333 "engines/director/lingo/lingo-gr.y"
+ case 69:
+#line 338 "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 70:
-#line 338 "engines/director/lingo/lingo-gr.y"
+ case 71:
+#line 343 "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 71:
-#line 339 "engines/director/lingo/lingo-gr.y"
+ case 72:
+#line 344 "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 72:
-#line 350 "engines/director/lingo/lingo-gr.y"
+ case 73:
+#line 355 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotoloop); ;}
break;
- case 73:
-#line 351 "engines/director/lingo/lingo-gr.y"
+ case 74:
+#line 356 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotonext); ;}
break;
- case 74:
-#line 352 "engines/director/lingo/lingo-gr.y"
+ case 75:
+#line 357 "engines/director/lingo/lingo-gr.y"
{ g_lingo->code1(g_lingo->c_gotoprevious); ;}
break;
- case 75:
-#line 353 "engines/director/lingo/lingo-gr.y"
+ case 76:
+#line 358 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString((yyvsp[(2) - (2)].s)->c_str());
@@ -2041,8 +2049,8 @@ yyreduce:
delete (yyvsp[(2) - (2)].s); ;}
break;
- case 76:
-#line 358 "engines/director/lingo/lingo-gr.y"
+ case 77:
+#line 363 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString((yyvsp[(2) - (3)].s)->c_str());
@@ -2051,8 +2059,8 @@ yyreduce:
delete (yyvsp[(3) - (3)].s); ;}
break;
- case 77:
-#line 364 "engines/director/lingo/lingo-gr.y"
+ case 78:
+#line 369 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_goto);
g_lingo->codeString("");
@@ -2060,48 +2068,48 @@ yyreduce:
delete (yyvsp[(2) - (2)].s); ;}
break;
- case 78:
-#line 371 "engines/director/lingo/lingo-gr.y"
+ case 79:
+#line 376 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 79:
-#line 372 "engines/director/lingo/lingo-gr.y"
+ case 80:
+#line 377 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 80:
-#line 373 "engines/director/lingo/lingo-gr.y"
+ case 81:
+#line 378 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 81:
-#line 374 "engines/director/lingo/lingo-gr.y"
+ case 82:
+#line 379 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(1) - (1)].s); ;}
break;
- case 82:
-#line 377 "engines/director/lingo/lingo-gr.y"
+ case 83:
+#line 382 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 83:
-#line 378 "engines/director/lingo/lingo-gr.y"
+ case 84:
+#line 383 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(2) - (2)].s); ;}
break;
- case 84:
-#line 379 "engines/director/lingo/lingo-gr.y"
+ case 85:
+#line 384 "engines/director/lingo/lingo-gr.y"
{ (yyval.s) = (yyvsp[(3) - (3)].s); ;}
break;
- case 85:
-#line 407 "engines/director/lingo/lingo-gr.y"
+ case 86:
+#line 412 "engines/director/lingo/lingo-gr.y"
{ g_lingo->_indef = true; ;}
break;
- case 86:
-#line 408 "engines/director/lingo/lingo-gr.y"
+ case 87:
+#line 413 "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);
@@ -2109,33 +2117,33 @@ yyreduce:
g_lingo->_indef = false; ;}
break;
- case 87:
-#line 414 "engines/director/lingo/lingo-gr.y"
+ case 88:
+#line 419 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 0; ;}
break;
- case 88:
-#line 415 "engines/director/lingo/lingo-gr.y"
+ case 89:
+#line 420 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg((yyvsp[(1) - (1)].s)); (yyval.narg) = 1; ;}
break;
- case 89:
-#line 416 "engines/director/lingo/lingo-gr.y"
+ case 90:
+#line 421 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg((yyvsp[(3) - (3)].s)); (yyval.narg) = (yyvsp[(1) - (3)].narg) + 1; ;}
break;
- case 90:
-#line 417 "engines/director/lingo/lingo-gr.y"
+ case 91:
+#line 422 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArg((yyvsp[(4) - (4)].s)); (yyval.narg) = (yyvsp[(1) - (4)].narg) + 1; ;}
break;
- case 91:
-#line 419 "engines/director/lingo/lingo-gr.y"
+ case 92:
+#line 424 "engines/director/lingo/lingo-gr.y"
{ g_lingo->codeArgStore(); ;}
break;
- case 92:
-#line 422 "engines/director/lingo/lingo-gr.y"
+ case 93:
+#line 427 "engines/director/lingo/lingo-gr.y"
{
g_lingo->code1(g_lingo->c_call);
g_lingo->codeString((yyvsp[(1) - (3)].s)->c_str());
@@ -2144,24 +2152,24 @@ yyreduce:
g_lingo->code1(numpar); ;}
break;
- case 93:
-#line 430 "engines/director/lingo/lingo-gr.y"
+ case 94:
+#line 435 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 0; ;}
break;
- case 94:
-#line 431 "engines/director/lingo/lingo-gr.y"
+ case 95:
+#line 436 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = 1; ;}
break;
- case 95:
-#line 432 "engines/director/lingo/lingo-gr.y"
+ case 96:
+#line 437 "engines/director/lingo/lingo-gr.y"
{ (yyval.narg) = (yyvsp[(1) - (3)].narg) + 1; ;}
break;
/* Line 1267 of yacc.c. */
-#line 2165 "engines/director/lingo/lingo-gr.cpp"
+#line 2173 "engines/director/lingo/lingo-gr.cpp"
default: break;
}
YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
@@ -2375,6 +2383,6 @@ yyreturn:
}
-#line 435 "engines/director/lingo/lingo-gr.y"
+#line 440 "engines/director/lingo/lingo-gr.y"
diff --git a/engines/director/lingo/lingo-gr.y b/engines/director/lingo/lingo-gr.y
index 221c7219db..e5d5e72f2b 100644
--- a/engines/director/lingo/lingo-gr.y
+++ b/engines/director/lingo/lingo-gr.y
@@ -56,7 +56,7 @@
extern int yylex();
extern int yyparse();
-void yyerror(char *s) { error("%s", s); }
+void yyerror(char *s) { error("%s at line %d col %d", s, Director::g_lingo->_linenumber, Director::g_lingo->_colnumber); }
using namespace Director;
@@ -90,10 +90,15 @@ using namespace Director;
%%
-program: program '\n' programline
+program: program nl programline
| programline
;
+nl: '\n' {
+ g_lingo->_linenumber++;
+ g_lingo->_colnumber = 1;
+ }
+
programline:
| defn
| func
@@ -172,14 +177,14 @@ stmt: stmtoneliner
(*g_lingo->_currentScript)[$1 + 5] = end; } /* end, if cond fails */
;
-ifstmt: if cond tTHEN '\n' stmtlist end tEND tIF {
+ifstmt: if cond tTHEN nl stmtlist end tEND tIF {
inst then = 0, end = 0;
WRITE_UINT32(&then, $5);
WRITE_UINT32(&end, $6);
(*g_lingo->_currentScript)[$1 + 1] = then; /* thenpart */
(*g_lingo->_currentScript)[$1 + 3] = end; /* end, if cond fails */
g_lingo->processIf(0, 0); }
- | if cond tTHEN '\n' stmtlist end tELSE stmtlist end tEND tIF {
+ | if cond tTHEN nl stmtlist end tELSE stmtlist end tEND tIF {
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, $5);
WRITE_UINT32(&else1, $8);
@@ -188,7 +193,7 @@ ifstmt: if cond tTHEN '\n' stmtlist end tEND tIF {
(*g_lingo->_currentScript)[$1 + 2] = else1; /* elsepart */
(*g_lingo->_currentScript)[$1 + 3] = end; /* end, if cond fails */
g_lingo->processIf(0, 0); }
- | if cond tTHEN '\n' stmtlist end begin elseifstmt end tEND tIF {
+ | if cond tTHEN nl stmtlist end begin elseifstmt end tEND tIF {
inst then = 0, else1 = 0, end = 0;
WRITE_UINT32(&then, $5);
WRITE_UINT32(&else1, $7);
@@ -282,7 +287,7 @@ begin: /* nothing */ { $$ = g_lingo->_currentScript->size(); }
end: /* nothing */ { g_lingo->code1(STOP); $$ = g_lingo->_currentScript->size(); }
;
stmtlist: /* nothing */ { $$ = g_lingo->_currentScript->size(); }
- | stmtlist '\n'
+ | stmtlist nl
| stmtlist stmt
;
@@ -405,7 +410,7 @@ gotomovie: tOF tMOVIE STRING { $$ = $3; }
// See also:
// on keyword
defn: tMACRO ID { g_lingo->_indef = true; }
- begin argdef '\n' argstore stmtlist {
+ begin argdef nl argstore stmtlist {
g_lingo->code2(g_lingo->c_constpush, (inst)0); // Push fake value on stack
g_lingo->code1(g_lingo->c_procret);
g_lingo->define(*$2, $4, $5);
@@ -414,7 +419,7 @@ defn: tMACRO ID { g_lingo->_indef = true; }
argdef: /* nothing */ { $$ = 0; }
| ID { g_lingo->codeArg($1); $$ = 1; }
| argdef ',' ID { g_lingo->codeArg($3); $$ = $1 + 1; }
- | argdef '\n' ',' ID { g_lingo->codeArg($4); $$ = $1 + 1; }
+ | argdef nl ',' ID { g_lingo->codeArg($4); $$ = $1 + 1; }
;
argstore: /* nothing */ { g_lingo->codeArgStore(); }
;
diff --git a/engines/director/lingo/lingo-lex.cpp b/engines/director/lingo/lingo-lex.cpp
index d302e38d0d..60ae1231f1 100644
--- a/engines/director/lingo/lingo-lex.cpp
+++ b/engines/director/lingo/lingo-lex.cpp
@@ -608,8 +608,21 @@ char *yytext;
#include "director/lingo/lingo-gr.h"
int yyparse();
+static void count() {
+ Director::g_lingo->_colnumber += strlen(yytext);
+}
+
+static void countnl() {
+ char *p = yytext;
-#line 613 "engines/director/lingo/lingo-lex.cpp"
+ while(*p == '\n' || *p == '\r')
+ p++;
+
+ Director::g_lingo->_linenumber++;
+ Director::g_lingo->_colnumber = strlen(p);
+}
+
+#line 626 "engines/director/lingo/lingo-lex.cpp"
#define INITIAL 0
@@ -794,10 +807,10 @@ YY_DECL
register char *yy_cp, *yy_bp;
register int yy_act;
-#line 45 "engines/director/lingo/lingo-lex.l"
+#line 58 "engines/director/lingo/lingo-lex.l"
-#line 801 "engines/director/lingo/lingo-lex.cpp"
+#line 814 "engines/director/lingo/lingo-lex.cpp"
if ( !(yy_init) )
{
@@ -883,170 +896,171 @@ do_action: /* This label is used only to access EOF actions. */
case 1:
YY_RULE_SETUP
-#line 47 "engines/director/lingo/lingo-lex.l"
+#line 60 "engines/director/lingo/lingo-lex.l"
YY_BREAK
case 2:
YY_RULE_SETUP
-#line 48 "engines/director/lingo/lingo-lex.l"
-
+#line 61 "engines/director/lingo/lingo-lex.l"
+{ count(); }
YY_BREAK
case 3:
YY_RULE_SETUP
-#line 49 "engines/director/lingo/lingo-lex.l"
-{ return ' '; }
+#line 62 "engines/director/lingo/lingo-lex.l"
+{ count(); return ' '; }
YY_BREAK
case 4:
YY_RULE_SETUP
-#line 51 "engines/director/lingo/lingo-lex.l"
-{ return tDOWN; }
+#line 64 "engines/director/lingo/lingo-lex.l"
+{ count(); return tDOWN; }
YY_BREAK
case 5:
YY_RULE_SETUP
-#line 52 "engines/director/lingo/lingo-lex.l"
-{ return tIF; }
+#line 65 "engines/director/lingo/lingo-lex.l"
+{ count(); return tIF; }
YY_BREAK
case 6:
/* rule 6 can match eol */
YY_RULE_SETUP
-#line 53 "engines/director/lingo/lingo-lex.l"
-{ return tNLELSIF; }
+#line 66 "engines/director/lingo/lingo-lex.l"
+{ countnl(); return tNLELSIF; }
YY_BREAK
case 7:
/* rule 7 can match eol */
YY_RULE_SETUP
-#line 54 "engines/director/lingo/lingo-lex.l"
-{ return tNLELSE; }
+#line 67 "engines/director/lingo/lingo-lex.l"
+{ countnl(); return tNLELSE; }
YY_BREAK
case 8:
YY_RULE_SETUP
-#line 55 "engines/director/lingo/lingo-lex.l"
-{ return tELSE; }
+#line 68 "engines/director/lingo/lingo-lex.l"
+{ count(); return tELSE; }
YY_BREAK
case 9:
YY_RULE_SETUP
-#line 56 "engines/director/lingo/lingo-lex.l"
-{ return tEND; }
+#line 69 "engines/director/lingo/lingo-lex.l"
+{ count(); return tEND; }
YY_BREAK
case 10:
YY_RULE_SETUP
-#line 57 "engines/director/lingo/lingo-lex.l"
-{ return tEXIT; }
+#line 70 "engines/director/lingo/lingo-lex.l"
+{ count(); return tEXIT; }
YY_BREAK
case 11:
YY_RULE_SETUP
-#line 58 "engines/director/lingo/lingo-lex.l"
-{ return tFRAME; }
+#line 71 "engines/director/lingo/lingo-lex.l"
+{ count(); return tFRAME; }
YY_BREAK
case 12:
YY_RULE_SETUP
-#line 59 "engines/director/lingo/lingo-lex.l"
-{ return tGLOBAL; }
+#line 72 "engines/director/lingo/lingo-lex.l"
+{ count(); return tGLOBAL; }
YY_BREAK
case 13:
YY_RULE_SETUP
-#line 60 "engines/director/lingo/lingo-lex.l"
-{ return tGO; }
+#line 73 "engines/director/lingo/lingo-lex.l"
+{ count(); return tGO; }
YY_BREAK
case 14:
YY_RULE_SETUP
-#line 61 "engines/director/lingo/lingo-lex.l"
-{ return tINTO; }
+#line 74 "engines/director/lingo/lingo-lex.l"
+{ count(); return tINTO; }
YY_BREAK
case 15:
YY_RULE_SETUP
-#line 62 "engines/director/lingo/lingo-lex.l"
-{ return tLOOP; }
+#line 75 "engines/director/lingo/lingo-lex.l"
+{ count(); return tLOOP; }
YY_BREAK
case 16:
YY_RULE_SETUP
-#line 63 "engines/director/lingo/lingo-lex.l"
-{ return tMACRO; }
+#line 76 "engines/director/lingo/lingo-lex.l"
+{ count(); return tMACRO; }
YY_BREAK
case 17:
YY_RULE_SETUP
-#line 64 "engines/director/lingo/lingo-lex.l"
-{ return tMCI; }
+#line 77 "engines/director/lingo/lingo-lex.l"
+{ count(); return tMCI; }
YY_BREAK
case 18:
YY_RULE_SETUP
-#line 65 "engines/director/lingo/lingo-lex.l"
-{ return tMCIWAIT; }
+#line 78 "engines/director/lingo/lingo-lex.l"
+{ count(); return tMCIWAIT; }
YY_BREAK
case 19:
YY_RULE_SETUP
-#line 66 "engines/director/lingo/lingo-lex.l"
-{ return tMOVIE; }
+#line 79 "engines/director/lingo/lingo-lex.l"
+{ count(); return tMOVIE; }
YY_BREAK
case 20:
YY_RULE_SETUP
-#line 67 "engines/director/lingo/lingo-lex.l"
-{ return tNEXT; }
+#line 80 "engines/director/lingo/lingo-lex.l"
+{ count(); return tNEXT; }
YY_BREAK
case 21:
YY_RULE_SETUP
-#line 68 "engines/director/lingo/lingo-lex.l"
-{ return tOF; }
+#line 81 "engines/director/lingo/lingo-lex.l"
+{ count(); return tOF; }
YY_BREAK
case 22:
YY_RULE_SETUP
-#line 69 "engines/director/lingo/lingo-lex.l"
-{ return tPREVIOUS; }
+#line 82 "engines/director/lingo/lingo-lex.l"
+{ count(); return tPREVIOUS; }
YY_BREAK
case 23:
YY_RULE_SETUP
-#line 70 "engines/director/lingo/lingo-lex.l"
-{ return tPUT; }
+#line 83 "engines/director/lingo/lingo-lex.l"
+{ count(); return tPUT; }
YY_BREAK
case 24:
YY_RULE_SETUP
-#line 71 "engines/director/lingo/lingo-lex.l"
-{ return tREPEAT; }
+#line 84 "engines/director/lingo/lingo-lex.l"
+{ count(); return tREPEAT; }
YY_BREAK
case 25:
YY_RULE_SETUP
-#line 72 "engines/director/lingo/lingo-lex.l"
-{ return tSET; }
+#line 85 "engines/director/lingo/lingo-lex.l"
+{ count(); return tSET; }
YY_BREAK
case 26:
YY_RULE_SETUP
-#line 73 "engines/director/lingo/lingo-lex.l"
-{ return tTHEN; }
+#line 86 "engines/director/lingo/lingo-lex.l"
+{ count(); return tTHEN; }
YY_BREAK
case 27:
YY_RULE_SETUP
-#line 74 "engines/director/lingo/lingo-lex.l"
-{ return tTO; }
+#line 87 "engines/director/lingo/lingo-lex.l"
+{ count(); return tTO; }
YY_BREAK
case 28:
YY_RULE_SETUP
-#line 75 "engines/director/lingo/lingo-lex.l"
-{ return tWITH; }
+#line 88 "engines/director/lingo/lingo-lex.l"
+{ count(); return tWITH; }
YY_BREAK
case 29:
YY_RULE_SETUP
-#line 76 "engines/director/lingo/lingo-lex.l"
-{ return tWHILE; }
+#line 89 "engines/director/lingo/lingo-lex.l"
+{ count(); return tWHILE; }
YY_BREAK
case 30:
YY_RULE_SETUP
-#line 78 "engines/director/lingo/lingo-lex.l"
-{ return tNEQ; }
+#line 91 "engines/director/lingo/lingo-lex.l"
+{ count(); return tNEQ; }
YY_BREAK
case 31:
YY_RULE_SETUP
-#line 79 "engines/director/lingo/lingo-lex.l"
-{ return tGE; }
+#line 92 "engines/director/lingo/lingo-lex.l"
+{ count(); return tGE; }
YY_BREAK
case 32:
YY_RULE_SETUP
-#line 80 "engines/director/lingo/lingo-lex.l"
-{ return tLE; }
+#line 93 "engines/director/lingo/lingo-lex.l"
+{ count(); return tLE; }
YY_BREAK
case 33:
YY_RULE_SETUP
-#line 82 "engines/director/lingo/lingo-lex.l"
+#line 95 "engines/director/lingo/lingo-lex.l"
{
+ count();
yylval.s = new Common::String(yytext);
if (Director::g_lingo->_builtins.contains(yytext))
@@ -1057,41 +1071,41 @@ YY_RULE_SETUP
YY_BREAK
case 34:
YY_RULE_SETUP
-#line 90 "engines/director/lingo/lingo-lex.l"
-{ yylval.f = atof(yytext); return FLOAT; }
+#line 104 "engines/director/lingo/lingo-lex.l"
+{ count(); yylval.f = atof(yytext); return FLOAT; }
YY_BREAK
case 35:
YY_RULE_SETUP
-#line 91 "engines/director/lingo/lingo-lex.l"
-{ yylval.i = strtol(yytext, NULL, 10); return INT; }
+#line 105 "engines/director/lingo/lingo-lex.l"
+{ count(); yylval.i = strtol(yytext, NULL, 10); return INT; }
YY_BREAK
case 36:
YY_RULE_SETUP
-#line 92 "engines/director/lingo/lingo-lex.l"
-{ return *yytext; }
+#line 106 "engines/director/lingo/lingo-lex.l"
+{ count(); return *yytext; }
YY_BREAK
case 37:
/* rule 37 can match eol */
YY_RULE_SETUP
-#line 93 "engines/director/lingo/lingo-lex.l"
+#line 107 "engines/director/lingo/lingo-lex.l"
{ return '\n'; }
YY_BREAK
case 38:
YY_RULE_SETUP
-#line 94 "engines/director/lingo/lingo-lex.l"
-{ yylval.s = new Common::String(&yytext[1]); yylval.s->deleteLastChar(); return STRING; }
+#line 108 "engines/director/lingo/lingo-lex.l"
+{ count(); yylval.s = new Common::String(&yytext[1]); yylval.s->deleteLastChar(); return STRING; }
YY_BREAK
case 39:
YY_RULE_SETUP
-#line 95 "engines/director/lingo/lingo-lex.l"
+#line 109 "engines/director/lingo/lingo-lex.l"
YY_BREAK
case 40:
YY_RULE_SETUP
-#line 97 "engines/director/lingo/lingo-lex.l"
+#line 111 "engines/director/lingo/lingo-lex.l"
ECHO;
YY_BREAK
-#line 1095 "engines/director/lingo/lingo-lex.cpp"
+#line 1109 "engines/director/lingo/lingo-lex.cpp"
case YY_STATE_EOF(INITIAL):
yyterminate();
@@ -2091,7 +2105,7 @@ void yyfree (void * ptr )
#define YYTABLES_NAME "yytables"
-#line 97 "engines/director/lingo/lingo-lex.l"
+#line 111 "engines/director/lingo/lingo-lex.l"
diff --git a/engines/director/lingo/lingo-lex.l b/engines/director/lingo/lingo-lex.l
index c340bd69bc..43b25f7c96 100644
--- a/engines/director/lingo/lingo-lex.l
+++ b/engines/director/lingo/lingo-lex.l
@@ -31,6 +31,19 @@
#include "director/lingo/lingo-gr.h"
int yyparse();
+static void count() {
+ Director::g_lingo->_colnumber += strlen(yytext);
+}
+
+static void countnl() {
+ char *p = yytext;
+
+ while(*p == '\n' || *p == '\r')
+ p++;
+
+ Director::g_lingo->_linenumber++;
+ Director::g_lingo->_colnumber = strlen(p);
+}
%}
@@ -45,41 +58,42 @@ whitespace [\t ]
%%
--[^\r\n]*
-^{whitespace}+
-[\t]+ { return ' '; }
-
-(?i:down) { return tDOWN; }
-(?i:if) { return tIF; }
-(?i:[\n\r]+[\t ]+else[\t ]+if) { return tNLELSIF; }
-(?i:[\n\r]+[\t ]+else) { return tNLELSE; }
-(?i:else) { return tELSE; }
-(?i:end) { return tEND; }
-(?i:exit) { return tEXIT; }
-(?i:frame) { return tFRAME; }
-(?i:global) { return tGLOBAL; }
-(?i:go) { return tGO; }
-(?i:into) { return tINTO; }
-(?i:loop) { return tLOOP; }
-(?i:macro) { return tMACRO; }
-(?i:mci) { return tMCI; }
-(?i:mciwait) { return tMCIWAIT; }
-(?i:movie) { return tMOVIE; }
-(?i:next) { return tNEXT; }
-(?i:of) { return tOF; }
-(?i:previous) { return tPREVIOUS; }
-(?i:put) { return tPUT; }
-(?i:repeat) { return tREPEAT; }
-(?i:set) { return tSET; }
-(?i:then) { return tTHEN; }
-(?i:to) { return tTO; }
-(?i:with) { return tWITH; }
-(?i:while) { return tWHILE; }
-
-[!][=] { return tNEQ; }
-[>][=] { return tGE; }
-[<][=] { return tLE; }
+^{whitespace}+ { count(); }
+[\t]+ { count(); return ' '; }
+
+(?i:down) { count(); return tDOWN; }
+(?i:if) { count(); return tIF; }
+(?i:[\n\r]+[\t ]+else[\t ]+if) { countnl(); return tNLELSIF; }
+(?i:[\n\r]+[\t ]+else) { countnl(); return tNLELSE; }
+(?i:else) { count(); return tELSE; }
+(?i:end) { count(); return tEND; }
+(?i:exit) { count(); return tEXIT; }
+(?i:frame) { count(); return tFRAME; }
+(?i:global) { count(); return tGLOBAL; }
+(?i:go) { count(); return tGO; }
+(?i:into) { count(); return tINTO; }
+(?i:loop) { count(); return tLOOP; }
+(?i:macro) { count(); return tMACRO; }
+(?i:mci) { count(); return tMCI; }
+(?i:mciwait) { count(); return tMCIWAIT; }
+(?i:movie) { count(); return tMOVIE; }
+(?i:next) { count(); return tNEXT; }
+(?i:of) { count(); return tOF; }
+(?i:previous) { count(); return tPREVIOUS; }
+(?i:put) { count(); return tPUT; }
+(?i:repeat) { count(); return tREPEAT; }
+(?i:set) { count(); return tSET; }
+(?i:then) { count(); return tTHEN; }
+(?i:to) { count(); return tTO; }
+(?i:with) { count(); return tWITH; }
+(?i:while) { count(); return tWHILE; }
+
+[!][=] { count(); return tNEQ; }
+[>][=] { count(); return tGE; }
+[<][=] { count(); return tLE; }
{identifier} {
+ count();
yylval.s = new Common::String(yytext);
if (Director::g_lingo->_builtins.contains(yytext))
@@ -87,11 +101,11 @@ whitespace [\t ]
return ID;
}
-{constfloat} { yylval.f = atof(yytext); return FLOAT; }
-{constinteger} { yylval.i = strtol(yytext, NULL, 10); return INT; }
-{operator} { return *yytext; }
+{constfloat} { count(); yylval.f = atof(yytext); return FLOAT; }
+{constinteger} { count(); yylval.i = strtol(yytext, NULL, 10); return INT; }
+{operator} { count(); return *yytext; }
{newline} { return '\n'; }
-{conststring} { yylval.s = new Common::String(&yytext[1]); yylval.s->deleteLastChar(); return STRING; }
+{conststring} { count(); yylval.s = new Common::String(&yytext[1]); yylval.s->deleteLastChar(); return STRING; }
.
%%
diff --git a/engines/director/lingo/lingo.cpp b/engines/director/lingo/lingo.cpp
index b1befd9f02..1ab0e89dd6 100644
--- a/engines/director/lingo/lingo.cpp
+++ b/engines/director/lingo/lingo.cpp
@@ -89,6 +89,8 @@ Lingo::Lingo(DirectorEngine *vm) : _vm(vm) {
_returning = false;
_indef = false;
+ _linenumber = _colnumber = 0;
+
warning("Lingo Inited");
}
@@ -108,6 +110,8 @@ void Lingo::addCode(Common::String code, ScriptType type, uint16 id) {
_currentScriptType = type;
_scripts[type][id] = _currentScript;
+ _linenumber = _colnumber = 1;
+
// macros have conflicting grammar. Thus we ease life for the parser.
if (code.contains("\nmacro ")) {
const char *begin = strstr(code.c_str(), "\nmacro ") + 1;
diff --git a/engines/director/lingo/lingo.h b/engines/director/lingo/lingo.h
index de3847c188..d88f7053a7 100644
--- a/engines/director/lingo/lingo.h
+++ b/engines/director/lingo/lingo.h
@@ -242,6 +242,9 @@ public:
BuiltinHash _builtins;
Common::Array<int> _labelstack;
+ int _linenumber;
+ int _colnumber;
+
private:
int parse(const char *code);
void push(Datum d);