diff options
author | David Walter Seikel | 2012-01-21 13:44:20 +1000 |
---|---|---|
committer | David Walter Seikel | 2012-01-21 13:44:20 +1000 |
commit | 0fa706b49693daf582c643f3917b37b124f7b380 (patch) | |
tree | abe877c4da040f676bd6d9c0455185ebb85e7d42 | |
parent | More stuff for parsing blocks and their statement lists. (diff) | |
download | SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.zip SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.tar.gz SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.tar.bz2 SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.tar.xz |
Make typecast parse.
-rw-r--r-- | LuaSL/src/LuaSL_compile.c | 2 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_lemon_yaccer.y | 14 |
2 files changed, 8 insertions, 8 deletions
diff --git a/LuaSL/src/LuaSL_compile.c b/LuaSL/src/LuaSL_compile.c index b1efddd..0b15215 100644 --- a/LuaSL/src/LuaSL_compile.c +++ b/LuaSL/src/LuaSL_compile.c | |||
@@ -72,7 +72,7 @@ LSL_Token LSL_Tokens[] = | |||
72 | // exponentiation (^) | 72 | // exponentiation (^) |
73 | 73 | ||
74 | {LSL_TYPECAST_CLOSE, ST_NONE, ")", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateNoToken}, | 74 | {LSL_TYPECAST_CLOSE, ST_NONE, ")", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateNoToken}, |
75 | {LSL_TYPECAST_OPEN, ST_NONE, "(", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateOperationToken}, | 75 | {LSL_TYPECAST_OPEN, ST_NONE, "(", LSL_RIGHT2LEFT | LSL_UNARY, outputParenthesisToken, evaluateOperationToken}, |
76 | {LSL_ANGLE_CLOSE, ST_NONE, ">", LSL_LEFT2RIGHT | LSL_CREATION, NULL, evaluateNoToken}, | 76 | {LSL_ANGLE_CLOSE, ST_NONE, ">", LSL_LEFT2RIGHT | LSL_CREATION, NULL, evaluateNoToken}, |
77 | {LSL_ANGLE_OPEN, ST_NONE, "<", LSL_LEFT2RIGHT | LSL_CREATION, NULL, evaluateOperationToken}, | 77 | {LSL_ANGLE_OPEN, ST_NONE, "<", LSL_LEFT2RIGHT | LSL_CREATION, NULL, evaluateOperationToken}, |
78 | {LSL_BRACKET_CLOSE, ST_NONE, "]", LSL_INNER2OUTER | LSL_CREATION, NULL, evaluateNoToken}, | 78 | {LSL_BRACKET_CLOSE, ST_NONE, "]", LSL_INNER2OUTER | LSL_CREATION, NULL, evaluateNoToken}, |
diff --git a/LuaSL/src/LuaSL_lemon_yaccer.y b/LuaSL/src/LuaSL_lemon_yaccer.y index 881bdaf..af2423a 100644 --- a/LuaSL/src/LuaSL_lemon_yaccer.y +++ b/LuaSL/src/LuaSL_lemon_yaccer.y | |||
@@ -156,13 +156,13 @@ expr ::= LSL_IDENTIFIER LSL_PARENTHESIS_OPEN exprList LSL_PARENTHESIS_CLOSE. | |||
156 | expr(A) ::= identifier(B). { A = B; } | 156 | expr(A) ::= identifier(B). { A = B; } |
157 | 157 | ||
158 | %right LSL_ASSIGNMENT_CONCATENATE LSL_ASSIGNMENT_ADD LSL_ASSIGNMENT_SUBTRACT LSL_ASSIGNMENT_MULTIPLY LSL_ASSIGNMENT_MODULO LSL_ASSIGNMENT_DIVIDE LSL_ASSIGNMENT_PLAIN. | 158 | %right LSL_ASSIGNMENT_CONCATENATE LSL_ASSIGNMENT_ADD LSL_ASSIGNMENT_SUBTRACT LSL_ASSIGNMENT_MULTIPLY LSL_ASSIGNMENT_MODULO LSL_ASSIGNMENT_DIVIDE LSL_ASSIGNMENT_PLAIN. |
159 | expr ::= identifier LSL_ASSIGNMENT_CONCATENATE expr. | 159 | expr(A) ::= identifier LSL_ASSIGNMENT_CONCATENATE expr(B). { A = B; } |
160 | expr ::= identifier LSL_ASSIGNMENT_ADD expr. | 160 | expr(A) ::= identifier LSL_ASSIGNMENT_ADD expr(B). { A = B; } |
161 | expr ::= identifier LSL_ASSIGNMENT_SUBTRACT expr. | 161 | expr(A) ::= identifier LSL_ASSIGNMENT_SUBTRACT expr(B) . { A = B; } |
162 | expr ::= identifier LSL_ASSIGNMENT_MULTIPLY expr. | 162 | expr(A) ::= identifier LSL_ASSIGNMENT_MULTIPLY expr(B). { A = B; } |
163 | expr ::= identifier LSL_ASSIGNMENT_MODULO expr. | 163 | expr(A) ::= identifier LSL_ASSIGNMENT_MODULO expr(B). { A = B; } |
164 | expr ::= identifier LSL_ASSIGNMENT_DIVIDE expr. | 164 | expr(A) ::= identifier LSL_ASSIGNMENT_DIVIDE expr(B). { A = B; } |
165 | expr ::= identifier LSL_ASSIGNMENT_PLAIN expr. | 165 | expr(A) ::= identifier LSL_ASSIGNMENT_PLAIN expr(B). { A = B; } |
166 | 166 | ||
167 | // Hmm think this can have commas seperating the assignment parts, or is that only in C?. If so, best to separate them when converting to Lua, as it uses that syntax for something else. | 167 | // Hmm think this can have commas seperating the assignment parts, or is that only in C?. If so, best to separate them when converting to Lua, as it uses that syntax for something else. |
168 | statement(A) ::= type(B) LSL_IDENTIFIER(C) LSL_ASSIGNMENT_PLAIN(D) expr(E) LSL_STATEMENT(F). { A = addStatement(F, LSL_IDENTIFIER, addVariable(compiler, B, C, D, E)); } | 168 | statement(A) ::= type(B) LSL_IDENTIFIER(C) LSL_ASSIGNMENT_PLAIN(D) expr(E) LSL_STATEMENT(F). { A = addStatement(F, LSL_IDENTIFIER, addVariable(compiler, B, C, D, E)); } |