diff options
-rw-r--r-- | LuaSL/src/LuaSL_LSL_tree.h | 1 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_compile.c | 32 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_lemon_yaccer.y | 3 |
3 files changed, 29 insertions, 7 deletions
diff --git a/LuaSL/src/LuaSL_LSL_tree.h b/LuaSL/src/LuaSL_LSL_tree.h index ca91ff0..00094b1 100644 --- a/LuaSL/src/LuaSL_LSL_tree.h +++ b/LuaSL/src/LuaSL_LSL_tree.h | |||
@@ -310,6 +310,7 @@ struct _LSL_Script | |||
310 | Eina_Hash *functions; | 310 | Eina_Hash *functions; |
311 | Eina_Hash *states; | 311 | Eina_Hash *states; |
312 | Eina_Hash *variables; | 312 | Eina_Hash *variables; |
313 | int bugCount, warningCount; | ||
313 | }; | 314 | }; |
314 | 315 | ||
315 | /* Tracking variables. | 316 | /* Tracking variables. |
diff --git a/LuaSL/src/LuaSL_compile.c b/LuaSL/src/LuaSL_compile.c index d32a44f..a63c6ca 100644 --- a/LuaSL/src/LuaSL_compile.c +++ b/LuaSL/src/LuaSL_compile.c | |||
@@ -341,8 +341,11 @@ LSL_Leaf *checkVariable(LuaSL_compiler *compiler, LSL_Leaf *identifier, LSL_Leaf | |||
341 | } | 341 | } |
342 | } | 342 | } |
343 | } | 343 | } |
344 | else | 344 | else |
345 | { | ||
346 | compiler->script.bugCount++; | ||
345 | PE("NOT found %s @ line %d, column %d!", identifier->value.stringValue, identifier->line, identifier->column); | 347 | PE("NOT found %s @ line %d, column %d!", identifier->value.stringValue, identifier->line, identifier->column); |
348 | } | ||
346 | } | 349 | } |
347 | 350 | ||
348 | return identifier; | 351 | return identifier; |
@@ -384,6 +387,7 @@ LSL_Leaf *addOperation(LuaSL_compiler *compiler, LSL_Leaf *left, LSL_Leaf *lval, | |||
384 | lType = left->basicType; | 387 | lType = left->basicType; |
385 | if (OT_undeclared == lType) | 388 | if (OT_undeclared == lType) |
386 | { | 389 | { |
390 | compiler->script.warningCount++; | ||
387 | PW("Undeclared identifier issue, deferring this until the second pass. @ line %d, column %d.", lval->line, lval->column); | 391 | PW("Undeclared identifier issue, deferring this until the second pass. @ line %d, column %d.", lval->line, lval->column); |
388 | lval->basicType = OT_undeclared; | 392 | lval->basicType = OT_undeclared; |
389 | return lval; | 393 | return lval; |
@@ -411,6 +415,7 @@ LSL_Leaf *addOperation(LuaSL_compiler *compiler, LSL_Leaf *left, LSL_Leaf *lval, | |||
411 | rType = right->basicType; | 415 | rType = right->basicType; |
412 | if (OT_undeclared == rType) | 416 | if (OT_undeclared == rType) |
413 | { | 417 | { |
418 | compiler->script.warningCount++; | ||
414 | PW("Undeclared identifier issue, deferring this until the second pass. @ line %d, column %d.", lval->line, lval->column); | 419 | PW("Undeclared identifier issue, deferring this until the second pass. @ line %d, column %d.", lval->line, lval->column); |
415 | lval->basicType = OT_undeclared; | 420 | lval->basicType = OT_undeclared; |
416 | return lval; | 421 | return lval; |
@@ -479,6 +484,7 @@ LSL_Leaf *addOperation(LuaSL_compiler *compiler, LSL_Leaf *left, LSL_Leaf *lval, | |||
479 | rightType = allowed[right->basicType].name; | 484 | rightType = allowed[right->basicType].name; |
480 | } | 485 | } |
481 | 486 | ||
487 | compiler->script.bugCount++; | ||
482 | PE("Invalid operation [%s(%s) %s %s(%s)] @ line %d, column %d!", leftType, leftToken, lval->toKen->toKen, rightType, rightToken, lval->line, lval->column); | 488 | PE("Invalid operation [%s(%s) %s %s(%s)] @ line %d, column %d!", leftType, leftToken, lval->toKen->toKen, rightType, rightToken, lval->line, lval->column); |
483 | } | 489 | } |
484 | } | 490 | } |
@@ -949,6 +955,7 @@ LSL_Leaf *addStatement(LuaSL_compiler *compiler, LSL_Leaf *lval, LSL_Leaf *flow, | |||
949 | } | 955 | } |
950 | default : | 956 | default : |
951 | { | 957 | { |
958 | compiler->script.bugCount++; | ||
952 | PE("Should not be here %d.", stat->type); | 959 | PE("Should not be here %d.", stat->type); |
953 | break; | 960 | break; |
954 | } | 961 | } |
@@ -1925,18 +1932,18 @@ static boolean doneParsing(LuaSL_compiler *compiler) | |||
1925 | if (out) | 1932 | if (out) |
1926 | { | 1933 | { |
1927 | char diffName[PATH_MAX]; | 1934 | char diffName[PATH_MAX]; |
1928 | int count; | 1935 | // int count; |
1929 | 1936 | ||
1930 | strcpy(diffName, compiler->fileName); | 1937 | strcpy(diffName, compiler->fileName); |
1931 | strcat(diffName, ".diff"); | 1938 | strcat(diffName, ".diff"); |
1932 | outputLeaf(out, OM_LSL, compiler->ast); | 1939 | outputLeaf(out, OM_LSL, compiler->ast); |
1933 | fclose(out); | 1940 | fclose(out); |
1934 | sprintf(buffer, "diff -u \"%s\" \"%s\" > \"%s\"", compiler->fileName, outName, diffName); | 1941 | sprintf(buffer, "diff -u \"%s\" \"%s\" > \"%s\"", compiler->fileName, outName, diffName); |
1935 | count = system(buffer); | 1942 | // count = system(buffer); |
1936 | if (0 != count) | 1943 | // if (0 != count) |
1937 | PE("LSL output file is different - %s!", outName); | 1944 | // PE("LSL output file is different - %s!", outName); |
1938 | else | 1945 | // else |
1939 | result = TRUE; | 1946 | // result = TRUE; |
1940 | } | 1947 | } |
1941 | else | 1948 | else |
1942 | PC("Unable to open file %s for writing!", outName); | 1949 | PC("Unable to open file %s for writing!", outName); |
@@ -1953,6 +1960,17 @@ static boolean doneParsing(LuaSL_compiler *compiler) | |||
1953 | PC("Unable to open file %s for writing!", luaName); | 1960 | PC("Unable to open file %s for writing!", luaName); |
1954 | } | 1961 | } |
1955 | 1962 | ||
1963 | if (compiler->script.bugCount) | ||
1964 | PE("%d errors and %d warnings in %s", compiler->script.bugCount, compiler->script.warningCount, compiler->fileName); | ||
1965 | else | ||
1966 | { | ||
1967 | if (compiler->script.warningCount) | ||
1968 | PW("%d errors and %d warnings in %s", compiler->script.bugCount, compiler->script.warningCount, compiler->fileName); | ||
1969 | else | ||
1970 | PI("%d errors and %d warnings in %s", compiler->script.bugCount, compiler->script.warningCount, compiler->fileName); | ||
1971 | result = TRUE; | ||
1972 | } | ||
1973 | |||
1956 | return result; | 1974 | return result; |
1957 | } | 1975 | } |
1958 | 1976 | ||
diff --git a/LuaSL/src/LuaSL_lemon_yaccer.y b/LuaSL/src/LuaSL_lemon_yaccer.y index c225b26..9199699 100644 --- a/LuaSL/src/LuaSL_lemon_yaccer.y +++ b/LuaSL/src/LuaSL_lemon_yaccer.y | |||
@@ -223,6 +223,7 @@ expr(A) ::= LSL_STRING(B). { B->basicType = OT_string; A = B; } | |||
223 | { | 223 | { |
224 | gameGlobals *game = compiler->game; | 224 | gameGlobals *game = compiler->game; |
225 | 225 | ||
226 | compiler->script.bugCount++; | ||
226 | PE("Giving up. Parser is hopelessly lost!"); | 227 | PE("Giving up. Parser is hopelessly lost!"); |
227 | } | 228 | } |
228 | 229 | ||
@@ -230,6 +231,7 @@ expr(A) ::= LSL_STRING(B). { B->basicType = OT_string; A = B; } | |||
230 | { | 231 | { |
231 | gameGlobals *game = compiler->game; | 232 | gameGlobals *game = compiler->game; |
232 | 233 | ||
234 | compiler->script.bugCount++; | ||
233 | PE("Giving up. Parser stack overflow @ line %d, column %d!", yypMinor->yy0->line, yypMinor->yy0->column); // Gotta love consistancy, if it ever happens. | 235 | PE("Giving up. Parser stack overflow @ line %d, column %d!", yypMinor->yy0->line, yypMinor->yy0->column); // Gotta love consistancy, if it ever happens. |
234 | } | 236 | } |
235 | 237 | ||
@@ -237,6 +239,7 @@ expr(A) ::= LSL_STRING(B). { B->basicType = OT_string; A = B; } | |||
237 | { | 239 | { |
238 | gameGlobals *game = compiler->game; | 240 | gameGlobals *game = compiler->game; |
239 | 241 | ||
242 | compiler->script.bugCount++; | ||
240 | PE("Syntax error @ line %d, column %d!", yyminor.yy0->line, yyminor.yy0->column); | 243 | PE("Syntax error @ line %d, column %d!", yyminor.yy0->line, yyminor.yy0->column); |
241 | } | 244 | } |
242 | 245 | ||