diff options
author | David Walter Seikel | 2012-01-30 20:00:47 +1000 |
---|---|---|
committer | David Walter Seikel | 2012-01-30 20:00:47 +1000 |
commit | 0f7b840c25d2c787f912f2c3cb7bef8790076007 (patch) | |
tree | a8e213f3fe3d28b1ab2dd76032d00305734acab4 /LuaSL/src | |
parent | No longer storing blocks as leaves. This one required a whole heap of functi... (diff) | |
download | SledjHamr-0f7b840c25d2c787f912f2c3cb7bef8790076007.zip SledjHamr-0f7b840c25d2c787f912f2c3cb7bef8790076007.tar.gz SledjHamr-0f7b840c25d2c787f912f2c3cb7bef8790076007.tar.bz2 SledjHamr-0f7b840c25d2c787f912f2c3cb7bef8790076007.tar.xz |
Don't go outputting duplicate ignorables for function calls and variable references.
Diffstat (limited to 'LuaSL/src')
-rw-r--r-- | LuaSL/src/LuaSL_compile.c | 32 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_lemon_yaccer.y | 2 |
2 files changed, 29 insertions, 5 deletions
diff --git a/LuaSL/src/LuaSL_compile.c b/LuaSL/src/LuaSL_compile.c index a9cc733..772f01a 100644 --- a/LuaSL/src/LuaSL_compile.c +++ b/LuaSL/src/LuaSL_compile.c | |||
@@ -117,6 +117,7 @@ LSL_Token LSL_Tokens[] = | |||
117 | // Then the rest of the syntax tokens. | 117 | // Then the rest of the syntax tokens. |
118 | {LSL_FUNCTION_CALL, ST_NONE, "funccall", LSL_NONE, outputFunctionCallToken, NULL}, | 118 | {LSL_FUNCTION_CALL, ST_NONE, "funccall", LSL_NONE, outputFunctionCallToken, NULL}, |
119 | {LSL_IDENTIFIER, ST_NONE, "identifier", LSL_NONE, outputIdentifierToken, NULL}, | 119 | {LSL_IDENTIFIER, ST_NONE, "identifier", LSL_NONE, outputIdentifierToken, NULL}, |
120 | {LSL_VARIABLE, ST_NONE, "variable", LSL_NONE, outputIdentifierToken, NULL}, | ||
120 | 121 | ||
121 | {LSL_LABEL, ST_NONE, "@", LSL_NONE, NULL, NULL}, | 122 | {LSL_LABEL, ST_NONE, "@", LSL_NONE, NULL, NULL}, |
122 | 123 | ||
@@ -470,6 +471,7 @@ LSL_Leaf *addParameter(LuaSL_compiler *compiler, LSL_Leaf *type, LSL_Leaf *ident | |||
470 | { | 471 | { |
471 | result->name.text = identifier->value.stringValue; | 472 | result->name.text = identifier->value.stringValue; |
472 | result->name.ignorableText = identifier->ignorableText; | 473 | result->name.ignorableText = identifier->ignorableText; |
474 | identifier->ignorableText = NULL; | ||
473 | result->value.toKen = tokens[LSL_UNKNOWN - lowestToken]; | 475 | result->value.toKen = tokens[LSL_UNKNOWN - lowestToken]; |
474 | identifier->value.identifierValue = result; | 476 | identifier->value.identifierValue = result; |
475 | identifier->toKen = tokens[LSL_PARAMETER - lowestToken]; | 477 | identifier->toKen = tokens[LSL_PARAMETER - lowestToken]; |
@@ -537,12 +539,14 @@ LSL_Leaf *addFunction(LuaSL_compiler *compiler, LSL_Leaf *type, LSL_Leaf *identi | |||
537 | { | 539 | { |
538 | func->name.text = identifier->value.stringValue; | 540 | func->name.text = identifier->value.stringValue; |
539 | func->name.ignorableText = identifier->ignorableText; | 541 | func->name.ignorableText = identifier->ignorableText; |
542 | identifier->ignorableText = NULL; | ||
540 | identifier->toKen = tokens[LSL_FUNCTION - lowestToken]; | 543 | identifier->toKen = tokens[LSL_FUNCTION - lowestToken]; |
541 | identifier->value.functionValue = func; | 544 | identifier->value.functionValue = func; |
542 | if (type) | 545 | if (type) |
543 | { | 546 | { |
544 | func->type.text = type->toKen->toKen; | 547 | func->type.text = type->toKen->toKen; |
545 | func->type.ignorableText = type->ignorableText; | 548 | func->type.ignorableText = type->ignorableText; |
549 | type->ignorableText = NULL; | ||
546 | identifier->basicType = type->basicType; | 550 | identifier->basicType = type->basicType; |
547 | } | 551 | } |
548 | else | 552 | else |
@@ -638,6 +642,7 @@ LSL_Leaf *addState(LuaSL_compiler *compiler, LSL_Leaf *state, LSL_Leaf *identifi | |||
638 | { | 642 | { |
639 | result->name.text = identifier->value.stringValue; | 643 | result->name.text = identifier->value.stringValue; |
640 | result->name.ignorableText = identifier->ignorableText; | 644 | result->name.ignorableText = identifier->ignorableText; |
645 | identifier->ignorableText = NULL; | ||
641 | result->block = block->value.blockValue; | 646 | result->block = block->value.blockValue; |
642 | if (state) | 647 | if (state) |
643 | { | 648 | { |
@@ -725,6 +730,10 @@ LSL_Leaf *addStatement(LuaSL_compiler *compiler, LSL_Leaf *lval, LSL_Type type, | |||
725 | { | 730 | { |
726 | break; | 731 | break; |
727 | } | 732 | } |
733 | case LSL_VARIABLE : | ||
734 | { | ||
735 | break; | ||
736 | } | ||
728 | default : | 737 | default : |
729 | { | 738 | { |
730 | PE("Should not be here %d.", type); | 739 | PE("Should not be here %d.", type); |
@@ -792,8 +801,10 @@ LSL_Leaf *addVariable(LuaSL_compiler *compiler, LSL_Leaf *type, LSL_Leaf *identi | |||
792 | { | 801 | { |
793 | result->name.text = identifier->value.stringValue; | 802 | result->name.text = identifier->value.stringValue; |
794 | result->name.ignorableText = identifier->ignorableText; | 803 | result->name.ignorableText = identifier->ignorableText; |
804 | identifier->ignorableText = NULL; | ||
795 | result->value.toKen = tokens[LSL_UNKNOWN - lowestToken]; | 805 | result->value.toKen = tokens[LSL_UNKNOWN - lowestToken]; |
796 | identifier->value.identifierValue = result; | 806 | identifier->value.identifierValue = result; |
807 | identifier->toKen = tokens[LSL_VARIABLE - lowestToken]; | ||
797 | identifier->left = type; | 808 | identifier->left = type; |
798 | identifier->right = assignment; | 809 | identifier->right = assignment; |
799 | if (assignment) | 810 | if (assignment) |
@@ -1162,6 +1173,10 @@ static LSL_Leaf *evaluateStatementToken(LSL_Leaf *content, LSL_Leaf *left, LSL_L | |||
1162 | { | 1173 | { |
1163 | break; | 1174 | break; |
1164 | } | 1175 | } |
1176 | case LSL_VARIABLE : | ||
1177 | { | ||
1178 | break; | ||
1179 | } | ||
1165 | default : | 1180 | default : |
1166 | { | 1181 | { |
1167 | // PE("Should not be here %d.", type); | 1182 | // PE("Should not be here %d.", type); |
@@ -1310,6 +1325,10 @@ static void outputRawStatement(FILE *file, outputMode mode, LSL_Statement *state | |||
1310 | { | 1325 | { |
1311 | break; | 1326 | break; |
1312 | } | 1327 | } |
1328 | case LSL_VARIABLE : | ||
1329 | { | ||
1330 | break; | ||
1331 | } | ||
1313 | default : | 1332 | default : |
1314 | { | 1333 | { |
1315 | fprintf(file, "@@Should not be here %s.@@", tokens[statement->type - lowestToken]->toKen); | 1334 | fprintf(file, "@@Should not be here %s.@@", tokens[statement->type - lowestToken]->toKen); |
@@ -1386,8 +1405,9 @@ static void outputFunctionCallToken(FILE *file, outputMode mode, LSL_Leaf *conte | |||
1386 | if (content) | 1405 | if (content) |
1387 | { | 1406 | { |
1388 | LSL_FunctionCall *call = content->value.functionCallValue; | 1407 | LSL_FunctionCall *call = content->value.functionCallValue; |
1389 | LSL_Function *func = call->function; | 1408 | |
1390 | outputText(file, &(func->name), !(LSL_NOIGNORE & content->toKen->flags)); | 1409 | // TODO - should output it's own ignorable here. |
1410 | outputText(file, &(call->function->name), FALSE); // Don't output the function definitions ignorable. | ||
1391 | fprintf(file, "("); | 1411 | fprintf(file, "("); |
1392 | // TODO - print params here. | 1412 | // TODO - print params here. |
1393 | fprintf(file, ")"); | 1413 | fprintf(file, ")"); |
@@ -1403,7 +1423,12 @@ static void outputIntegerToken(FILE *file, outputMode mode, LSL_Leaf *content) | |||
1403 | static void outputIdentifierToken(FILE *file, outputMode mode, LSL_Leaf *content) | 1423 | static void outputIdentifierToken(FILE *file, outputMode mode, LSL_Leaf *content) |
1404 | { | 1424 | { |
1405 | if (content) | 1425 | if (content) |
1406 | outputText(file, &(content->value.identifierValue->name), !(LSL_NOIGNORE & content->toKen->flags)); | 1426 | { |
1427 | if (LSL_IDENTIFIER == content->toKen->type) | ||
1428 | outputText(file, &(content->value.identifierValue->name), FALSE); | ||
1429 | else | ||
1430 | outputText(file, &(content->value.identifierValue->name), !(LSL_NOIGNORE & content->toKen->flags)); | ||
1431 | } | ||
1407 | } | 1432 | } |
1408 | 1433 | ||
1409 | static void outputParameterListToken(FILE *file, outputMode mode, LSL_Leaf *content) | 1434 | static void outputParameterListToken(FILE *file, outputMode mode, LSL_Leaf *content) |
@@ -1434,7 +1459,6 @@ static void outputStateToken(FILE *file, outputMode mode, LSL_Leaf *content) | |||
1434 | } | 1459 | } |
1435 | } | 1460 | } |
1436 | 1461 | ||
1437 | |||
1438 | static void outputStatementToken(FILE *file, outputMode mode, LSL_Leaf *content) | 1462 | static void outputStatementToken(FILE *file, outputMode mode, LSL_Leaf *content) |
1439 | { | 1463 | { |
1440 | if (content) | 1464 | if (content) |
diff --git a/LuaSL/src/LuaSL_lemon_yaccer.y b/LuaSL/src/LuaSL_lemon_yaccer.y index b6eac2e..ab22201 100644 --- a/LuaSL/src/LuaSL_lemon_yaccer.y +++ b/LuaSL/src/LuaSL_lemon_yaccer.y | |||
@@ -180,7 +180,7 @@ expr(A) ::= identifier(B) LSL_ASSIGNMENT_PLAIN(C) expr(D). { A = addOperation(c | |||
180 | statement(A) ::= type(T) LSL_IDENTIFIER(I) LSL_ASSIGNMENT_PLAIN(D) expr(E) LSL_STATEMENT(S). { A = addStatement(compiler, S, LSL_IDENTIFIER, NULL, addVariable(compiler, T, I, D, E), NULL, NULL, I); } | 180 | statement(A) ::= type(T) LSL_IDENTIFIER(I) LSL_ASSIGNMENT_PLAIN(D) expr(E) LSL_STATEMENT(S). { A = addStatement(compiler, S, LSL_IDENTIFIER, NULL, addVariable(compiler, T, I, D, E), NULL, NULL, I); } |
181 | statement(A) ::= type(T) LSL_IDENTIFIER(I) LSL_STATEMENT(S). { A = addStatement(compiler, S, LSL_IDENTIFIER, NULL, addVariable(compiler, T, I, NULL, NULL), NULL, NULL, I); } | 181 | statement(A) ::= type(T) LSL_IDENTIFIER(I) LSL_STATEMENT(S). { A = addStatement(compiler, S, LSL_IDENTIFIER, NULL, addVariable(compiler, T, I, NULL, NULL), NULL, NULL, I); } |
182 | 182 | ||
183 | %right LSL_DOT LSL_IDENTIFIER LSL_FUNCTION_CALL. | 183 | %right LSL_DOT LSL_IDENTIFIER LSL_FUNCTION_CALL LSL_VARIABLE. |
184 | identifier(A) ::= identifier LSL_DOT LSL_IDENTIFIER(B). { A = checkVariable(compiler, B); A->basicType = OT_float; } // Just a stub to get it to work for now. | 184 | identifier(A) ::= identifier LSL_DOT LSL_IDENTIFIER(B). { A = checkVariable(compiler, B); A->basicType = OT_float; } // Just a stub to get it to work for now. |
185 | identifier(A) ::= LSL_IDENTIFIER(B). { A = checkVariable(compiler, B); } | 185 | identifier(A) ::= LSL_IDENTIFIER(B). { A = checkVariable(compiler, B); } |
186 | 186 | ||