aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDavid Walter Seikel2012-01-21 13:44:20 +1000
committerDavid Walter Seikel2012-01-21 13:44:20 +1000
commit0fa706b49693daf582c643f3917b37b124f7b380 (patch)
treeabe877c4da040f676bd6d9c0455185ebb85e7d42
parentMore stuff for parsing blocks and their statement lists. (diff)
downloadSledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.zip
SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.tar.gz
SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.tar.bz2
SledjHamr-0fa706b49693daf582c643f3917b37b124f7b380.tar.xz
Make typecast parse.
-rw-r--r--LuaSL/src/LuaSL_compile.c2
-rw-r--r--LuaSL/src/LuaSL_lemon_yaccer.y14
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.
156expr(A) ::= identifier(B). { A = B; } 156expr(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.
159expr ::= identifier LSL_ASSIGNMENT_CONCATENATE expr. 159expr(A) ::= identifier LSL_ASSIGNMENT_CONCATENATE expr(B). { A = B; }
160expr ::= identifier LSL_ASSIGNMENT_ADD expr. 160expr(A) ::= identifier LSL_ASSIGNMENT_ADD expr(B). { A = B; }
161expr ::= identifier LSL_ASSIGNMENT_SUBTRACT expr. 161expr(A) ::= identifier LSL_ASSIGNMENT_SUBTRACT expr(B) . { A = B; }
162expr ::= identifier LSL_ASSIGNMENT_MULTIPLY expr. 162expr(A) ::= identifier LSL_ASSIGNMENT_MULTIPLY expr(B). { A = B; }
163expr ::= identifier LSL_ASSIGNMENT_MODULO expr. 163expr(A) ::= identifier LSL_ASSIGNMENT_MODULO expr(B). { A = B; }
164expr ::= identifier LSL_ASSIGNMENT_DIVIDE expr. 164expr(A) ::= identifier LSL_ASSIGNMENT_DIVIDE expr(B). { A = B; }
165expr ::= identifier LSL_ASSIGNMENT_PLAIN expr. 165expr(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.
168statement(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)); } 168statement(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)); }