diff options
Diffstat (limited to 'LuaSL')
-rw-r--r-- | LuaSL/src/LuaSL_LSL_tree.c | 132 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_LSL_tree.h | 88 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_lexer.l | 172 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_yaccer.y | 65 | ||||
-rw-r--r-- | LuaSL/test.lsl | 3 |
5 files changed, 249 insertions, 211 deletions
diff --git a/LuaSL/src/LuaSL_LSL_tree.c b/LuaSL/src/LuaSL_LSL_tree.c index 76dd433..ff7da8b 100644 --- a/LuaSL/src/LuaSL_LSL_tree.c +++ b/LuaSL/src/LuaSL_LSL_tree.c | |||
@@ -149,20 +149,42 @@ static void burnAST(LSL_AST *ast) | |||
149 | 149 | ||
150 | burnAST(ast->left); | 150 | burnAST(ast->left); |
151 | burnAST(ast->right); | 151 | burnAST(ast->right); |
152 | free(ast->content.ignorableText); | ||
152 | free(ast); | 153 | free(ast); |
153 | } | 154 | } |
154 | 155 | ||
155 | LSL_AST *addInteger(int value) | 156 | static LSL_AST *checkAndAddIgnorable(LSL_AST *root) |
157 | { | ||
158 | if (root) | ||
159 | { | ||
160 | if (root->content.ignorableText) | ||
161 | { | ||
162 | LSL_AST *ast = newAST(LSL_SPACE, NULL, root); | ||
163 | |||
164 | if (ast) | ||
165 | { | ||
166 | ast->content.value.spaceValue = root->content.ignorableText; | ||
167 | return ast; | ||
168 | } | ||
169 | } | ||
170 | } | ||
171 | return root; | ||
172 | } | ||
173 | |||
174 | LSL_AST *addInteger(LSL_Leaf *lval, int value) | ||
156 | { | 175 | { |
157 | LSL_AST *ast = newAST(LSL_INTEGER, NULL, NULL); | 176 | LSL_AST *ast = newAST(LSL_INTEGER, NULL, NULL); |
158 | 177 | ||
159 | if (ast) | 178 | if (ast) |
160 | ast->content.integerValue = value; | 179 | { |
180 | ast->content.value.integerValue = value; | ||
181 | ast->content.ignorableText = lval->ignorableText; | ||
182 | } | ||
161 | 183 | ||
162 | return ast; | 184 | return checkAndAddIgnorable(ast); |
163 | } | 185 | } |
164 | 186 | ||
165 | LSL_AST *addOperation(LSL_Type type, LSL_AST *left, LSL_AST *right) | 187 | LSL_AST *addOperation(LSL_Leaf *lval, LSL_Type type, LSL_AST *left, LSL_AST *right) |
166 | { | 188 | { |
167 | LSL_AST *ast = newAST(type, left, right); | 189 | LSL_AST *ast = newAST(type, left, right); |
168 | 190 | ||
@@ -170,24 +192,30 @@ LSL_AST *addOperation(LSL_Type type, LSL_AST *left, LSL_AST *right) | |||
170 | { | 192 | { |
171 | if (LSL_EXPRESSION == type) | 193 | if (LSL_EXPRESSION == type) |
172 | { | 194 | { |
173 | ast->content.expressionValue = right; | 195 | ast->content.value.expressionValue = right; |
174 | ast->left = NULL; | 196 | ast->left = NULL; |
175 | } | 197 | } |
176 | else | 198 | else |
177 | ast->content.operationValue = type; | 199 | { |
200 | ast->content.value.operationValue = type; | ||
201 | ast->content.ignorableText = lval->ignorableText; | ||
202 | } | ||
178 | } | 203 | } |
179 | 204 | ||
180 | return ast; | 205 | return checkAndAddIgnorable(ast); |
181 | } | 206 | } |
182 | 207 | ||
183 | LSL_AST *addParenthesis(LSL_AST *expr) | 208 | LSL_AST *addParenthesis(LSL_Leaf *lval, LSL_AST *expr) |
184 | { | 209 | { |
185 | LSL_AST *ast = newAST(LSL_PARENTHESIS_OPEN, NULL, expr); | 210 | LSL_AST *ast = newAST(LSL_PARENTHESIS_OPEN, NULL, expr); |
186 | 211 | ||
187 | if (ast) | 212 | if (ast) |
213 | { | ||
188 | ast = newAST(LSL_PARENTHESIS_CLOSE, ast, NULL); | 214 | ast = newAST(LSL_PARENTHESIS_CLOSE, ast, NULL); |
215 | ast->content.ignorableText = lval->ignorableText; | ||
216 | } | ||
189 | 217 | ||
190 | return ast; | 218 | return checkAndAddIgnorable(ast); |
191 | } | 219 | } |
192 | 220 | ||
193 | LSL_Statement *createStatement(LSL_Type type, LSL_AST *expr) | 221 | LSL_Statement *createStatement(LSL_Type type, LSL_AST *expr) |
@@ -202,24 +230,14 @@ LSL_Statement *createStatement(LSL_Type type, LSL_AST *expr) | |||
202 | return stat; | 230 | return stat; |
203 | } | 231 | } |
204 | 232 | ||
205 | LSL_AST *addSpace(char *text, LSL_AST *root) | ||
206 | { | ||
207 | LSL_AST *ast = newAST(LSL_SPACE, root, NULL); | ||
208 | |||
209 | if (ast) | ||
210 | ast->content.spaceValue = text; | ||
211 | |||
212 | return ast; | ||
213 | } | ||
214 | |||
215 | LSL_AST *addStatement(LSL_Statement *statement, LSL_AST *root) | 233 | LSL_AST *addStatement(LSL_Statement *statement, LSL_AST *root) |
216 | { | 234 | { |
217 | LSL_AST *ast = newAST(LSL_STATEMENT, root, NULL); | 235 | LSL_AST *ast = newAST(LSL_STATEMENT, root, NULL); |
218 | 236 | ||
219 | if (ast) | 237 | if (ast) |
220 | ast->content.statementValue = statement; | 238 | ast->content.value.statementValue = statement; |
221 | 239 | ||
222 | return ast; | 240 | return checkAndAddIgnorable(ast); |
223 | } | 241 | } |
224 | 242 | ||
225 | static void evaluateAST(LSL_AST *ast, LSL_Value *left, LSL_Value *right) | 243 | static void evaluateAST(LSL_AST *ast, LSL_Value *left, LSL_Value *right) |
@@ -259,7 +277,7 @@ static void evaluateAST(LSL_AST *ast, LSL_Value *left, LSL_Value *right) | |||
259 | else | 277 | else |
260 | { | 278 | { |
261 | #ifdef LUASL_DEBUG | 279 | #ifdef LUASL_DEBUG |
262 | printf(" eval <%s %d %d %d %d> ", ast->token->token, left->content.integerValue, right->content.integerValue, lresult.content.integerValue, rresult.content.integerValue); | 280 | printf(" eval <%s %d %d %d %d> ", ast->token->token, left->content.value.integerValue, right->content.value.integerValue, lresult.content.value.integerValue, rresult.content.value.integerValue); |
263 | #endif | 281 | #endif |
264 | memcpy(left, &rresult, sizeof(LSL_Value)); | 282 | memcpy(left, &rresult, sizeof(LSL_Value)); |
265 | } | 283 | } |
@@ -271,9 +289,9 @@ static void evaluateIntegerToken(LSL_Leaf *content, LSL_Value *left, LSL_Value * | |||
271 | if (content) | 289 | if (content) |
272 | { | 290 | { |
273 | #ifdef LUASL_DEBUG | 291 | #ifdef LUASL_DEBUG |
274 | printf(" <%d> ", content->integerValue); | 292 | printf(" <%d> ", content->value.integerValue); |
275 | #endif | 293 | #endif |
276 | left->content.integerValue = content->integerValue; | 294 | left->content.value.integerValue = content->value.integerValue; |
277 | left->type = LSL_INTEGER; | 295 | left->type = LSL_INTEGER; |
278 | } | 296 | } |
279 | } | 297 | } |
@@ -284,13 +302,13 @@ static void evaluateNoToken(LSL_Leaf *content, LSL_Value *left, LSL_Value *right | |||
284 | 302 | ||
285 | static void evaluateOperationToken(LSL_Leaf *content, LSL_Value *left, LSL_Value *right) | 303 | static void evaluateOperationToken(LSL_Leaf *content, LSL_Value *left, LSL_Value *right) |
286 | { | 304 | { |
287 | if ((content) && (content->operationValue)) | 305 | if ((content) && (content->value.operationValue)) |
288 | { | 306 | { |
289 | #ifdef LUASL_DEBUG | 307 | #ifdef LUASL_DEBUG |
290 | printf(" [%s] ", tokens[content->operationValue - lowestToken]->token); | 308 | printf(" [%s] ", tokens[content->value.operationValue - lowestToken]->token); |
291 | #endif | 309 | #endif |
292 | 310 | ||
293 | switch (content->operationValue) | 311 | switch (content->value.operationValue) |
294 | { | 312 | { |
295 | case LSL_COMMA : | 313 | case LSL_COMMA : |
296 | case LSL_INCREMENT_PRE : | 314 | case LSL_INCREMENT_PRE : |
@@ -314,33 +332,33 @@ static void evaluateOperationToken(LSL_Leaf *content, LSL_Value *left, LSL_Value | |||
314 | // case LSL_TYPECAST_OPEN : | 332 | // case LSL_TYPECAST_OPEN : |
315 | // case LSL_TYPECAST_CLOSE : | 333 | // case LSL_TYPECAST_CLOSE : |
316 | break; | 334 | break; |
317 | case LSL_BIT_NOT : left->content.integerValue = ~ right->content.integerValue; break; | 335 | case LSL_BIT_NOT : left->content.value.integerValue = ~ right->content.value.integerValue; break; |
318 | case LSL_BOOL_NOT : left->content.integerValue = ! right->content.integerValue; break; | 336 | case LSL_BOOL_NOT : left->content.value.integerValue = ! right->content.value.integerValue; break; |
319 | case LSL_NEGATION : left->content.integerValue = 0 - right->content.integerValue; break; | 337 | case LSL_NEGATION : left->content.value.integerValue = 0 - right->content.value.integerValue; break; |
320 | case LSL_DIVIDE : left->content.integerValue = left->content.integerValue / right->content.integerValue; break; | 338 | case LSL_DIVIDE : left->content.value.integerValue = left->content.value.integerValue / right->content.value.integerValue; break; |
321 | case LSL_MODULO : left->content.integerValue = left->content.integerValue % right->content.integerValue; break; | 339 | case LSL_MODULO : left->content.value.integerValue = left->content.value.integerValue % right->content.value.integerValue; break; |
322 | case LSL_MULTIPLY : left->content.integerValue = left->content.integerValue * right->content.integerValue; break; | 340 | case LSL_MULTIPLY : left->content.value.integerValue = left->content.value.integerValue * right->content.value.integerValue; break; |
323 | // case LSL_DOT_PRODUCT : break; | 341 | // case LSL_DOT_PRODUCT : break; |
324 | // case LSL_CROSS_PRODUCT : break; | 342 | // case LSL_CROSS_PRODUCT : break; |
325 | case LSL_SUBTRACT : left->content.integerValue = left->content.integerValue - right->content.integerValue; break; | 343 | case LSL_SUBTRACT : left->content.value.integerValue = left->content.value.integerValue - right->content.value.integerValue; break; |
326 | case LSL_ADD : left->content.integerValue = left->content.integerValue + right->content.integerValue; break; | 344 | case LSL_ADD : left->content.value.integerValue = left->content.value.integerValue + right->content.value.integerValue; break; |
327 | // case LSL_CONCATENATE : break; | 345 | // case LSL_CONCATENATE : break; |
328 | case LSL_LEFT_SHIFT : left->content.integerValue = left->content.integerValue << right->content.integerValue; break; | 346 | case LSL_LEFT_SHIFT : left->content.value.integerValue = left->content.value.integerValue << right->content.value.integerValue; break; |
329 | case LSL_RIGHT_SHIFT : left->content.integerValue = left->content.integerValue >> right->content.integerValue; break; | 347 | case LSL_RIGHT_SHIFT : left->content.value.integerValue = left->content.value.integerValue >> right->content.value.integerValue; break; |
330 | case LSL_LESS_THAN : left->content.integerValue = left->content.integerValue < right->content.integerValue; break; | 348 | case LSL_LESS_THAN : left->content.value.integerValue = left->content.value.integerValue < right->content.value.integerValue; break; |
331 | case LSL_GREATER_THAN : left->content.integerValue = left->content.integerValue > right->content.integerValue; break; | 349 | case LSL_GREATER_THAN : left->content.value.integerValue = left->content.value.integerValue > right->content.value.integerValue; break; |
332 | case LSL_LESS_EQUAL : left->content.integerValue = left->content.integerValue <= right->content.integerValue; break; | 350 | case LSL_LESS_EQUAL : left->content.value.integerValue = left->content.value.integerValue <= right->content.value.integerValue; break; |
333 | case LSL_GREATER_EQUAL : left->content.integerValue = left->content.integerValue >= right->content.integerValue; break; | 351 | case LSL_GREATER_EQUAL : left->content.value.integerValue = left->content.value.integerValue >= right->content.value.integerValue; break; |
334 | case LSL_EQUAL : left->content.integerValue = left->content.integerValue == right->content.integerValue; break; | 352 | case LSL_EQUAL : left->content.value.integerValue = left->content.value.integerValue == right->content.value.integerValue; break; |
335 | case LSL_NOT_EQUAL : left->content.integerValue = left->content.integerValue != right->content.integerValue; break; | 353 | case LSL_NOT_EQUAL : left->content.value.integerValue = left->content.value.integerValue != right->content.value.integerValue; break; |
336 | case LSL_BIT_AND : left->content.integerValue = left->content.integerValue & right->content.integerValue; break; | 354 | case LSL_BIT_AND : left->content.value.integerValue = left->content.value.integerValue & right->content.value.integerValue; break; |
337 | case LSL_BIT_XOR : left->content.integerValue = left->content.integerValue ^ right->content.integerValue; break; | 355 | case LSL_BIT_XOR : left->content.value.integerValue = left->content.value.integerValue ^ right->content.value.integerValue; break; |
338 | case LSL_BIT_OR : left->content.integerValue = left->content.integerValue | right->content.integerValue; break; | 356 | case LSL_BIT_OR : left->content.value.integerValue = left->content.value.integerValue | right->content.value.integerValue; break; |
339 | case LSL_BOOL_OR : left->content.integerValue = left->content.integerValue || right->content.integerValue; break; | 357 | case LSL_BOOL_OR : left->content.value.integerValue = left->content.value.integerValue || right->content.value.integerValue; break; |
340 | case LSL_BOOL_AND : left->content.integerValue = left->content.integerValue && right->content.integerValue; break; | 358 | case LSL_BOOL_AND : left->content.value.integerValue = left->content.value.integerValue && right->content.value.integerValue; break; |
341 | } | 359 | } |
342 | #ifdef LUASL_DEBUG | 360 | #ifdef LUASL_DEBUG |
343 | printf(" (=%d) ", left->content.integerValue); | 361 | printf(" (=%d) ", left->content.value.integerValue); |
344 | #endif | 362 | #endif |
345 | } | 363 | } |
346 | } | 364 | } |
@@ -348,7 +366,7 @@ static void evaluateOperationToken(LSL_Leaf *content, LSL_Value *left, LSL_Value | |||
348 | static void evaluateStatementToken(LSL_Leaf *content, LSL_Value *left, LSL_Value *right) | 366 | static void evaluateStatementToken(LSL_Leaf *content, LSL_Value *left, LSL_Value *right) |
349 | { | 367 | { |
350 | if (content) | 368 | if (content) |
351 | evaluateAST(content->statementValue->expression, left, right); | 369 | evaluateAST(content->value.statementValue->expression, left, right); |
352 | } | 370 | } |
353 | 371 | ||
354 | static void outputAST(LSL_AST *ast) | 372 | static void outputAST(LSL_AST *ast) |
@@ -367,26 +385,26 @@ static void outputAST(LSL_AST *ast) | |||
367 | static void outputIntegerToken(LSL_Leaf *content) | 385 | static void outputIntegerToken(LSL_Leaf *content) |
368 | { | 386 | { |
369 | if (content) | 387 | if (content) |
370 | printf("%d", content->integerValue); | 388 | printf("%d", content->value.integerValue); |
371 | } | 389 | } |
372 | 390 | ||
373 | static void outputOperationToken(LSL_Leaf *content) | 391 | static void outputOperationToken(LSL_Leaf *content) |
374 | { | 392 | { |
375 | if (content) | 393 | if (content) |
376 | printf("%s", tokens[content->operationValue - lowestToken]->token); | 394 | printf("%s", tokens[content->value.operationValue - lowestToken]->token); |
377 | } | 395 | } |
378 | 396 | ||
379 | static void outputStatementToken(LSL_Leaf *content) | 397 | static void outputStatementToken(LSL_Leaf *content) |
380 | { | 398 | { |
381 | if (content) | 399 | if (content) |
382 | outputAST(content->statementValue->expression); | 400 | outputAST(content->value.statementValue->expression); |
383 | printf(";"); | 401 | printf(";"); |
384 | } | 402 | } |
385 | 403 | ||
386 | static void outputSpaceToken(LSL_Leaf *content) | 404 | static void outputSpaceToken(LSL_Leaf *content) |
387 | { | 405 | { |
388 | if (content) | 406 | if (content) |
389 | printf("%s", content->spaceValue); | 407 | printf("%s", content->value.spaceValue); |
390 | } | 408 | } |
391 | 409 | ||
392 | static void convertAST2Lua(LSL_AST *ast) | 410 | static void convertAST2Lua(LSL_AST *ast) |
@@ -523,9 +541,9 @@ int main(int argc, char **argv) | |||
523 | { | 541 | { |
524 | LSL_Value left, right; | 542 | LSL_Value left, right; |
525 | 543 | ||
526 | left.content.integerValue = 0; | 544 | left.content.value.integerValue = 0; |
527 | left.type = LSL_INTEGER; | 545 | left.type = LSL_INTEGER; |
528 | right.content.integerValue = 0; | 546 | right.content.value.integerValue = 0; |
529 | right.type = LSL_INTEGER; | 547 | right.type = LSL_INTEGER; |
530 | evaluateAST(ast, &left, &right); | 548 | evaluateAST(ast, &left, &right); |
531 | 549 | ||
@@ -535,7 +553,7 @@ int main(int argc, char **argv) | |||
535 | printf("Result of -\n"); | 553 | printf("Result of -\n"); |
536 | outputAST(ast); | 554 | outputAST(ast); |
537 | printf("\n"); | 555 | printf("\n"); |
538 | printf("is %d %d. And converted to Lua it is -\n", left.content.integerValue, right.content.integerValue); | 556 | printf("is %d %d. And converted to Lua it is -\n", left.content.value.integerValue, right.content.value.integerValue); |
539 | convertAST2Lua(ast); | 557 | convertAST2Lua(ast); |
540 | printf("\n"); | 558 | printf("\n"); |
541 | burnAST(ast); | 559 | burnAST(ast); |
diff --git a/LuaSL/src/LuaSL_LSL_tree.h b/LuaSL/src/LuaSL_LSL_tree.h index adefa07..fe56c29 100644 --- a/LuaSL/src/LuaSL_LSL_tree.h +++ b/LuaSL/src/LuaSL_LSL_tree.h | |||
@@ -20,7 +20,7 @@ extern int yydebug; | |||
20 | // http://w-hat.com/stackdepth is a useful discussion about some aspects of the LL parser. | 20 | // http://w-hat.com/stackdepth is a useful discussion about some aspects of the LL parser. |
21 | 21 | ||
22 | 22 | ||
23 | typedef union _LSL_Leaf LSL_Leaf; | 23 | typedef struct _LSL_Leaf LSL_Leaf; |
24 | typedef struct _LSL_Value LSL_Value; | 24 | typedef struct _LSL_Value LSL_Value; |
25 | typedef struct _LSL_Identifier LSL_Identifier; | 25 | typedef struct _LSL_Identifier LSL_Identifier; |
26 | typedef struct _LSL_Statement LSL_Statement; | 26 | typedef struct _LSL_Statement LSL_Statement; |
@@ -65,43 +65,48 @@ typedef struct | |||
65 | evaluateToken evaluate; | 65 | evaluateToken evaluate; |
66 | } LSL_Token; | 66 | } LSL_Token; |
67 | 67 | ||
68 | union _LSL_Leaf | 68 | struct _LSL_Leaf |
69 | { | 69 | { |
70 | char *commentValue; | 70 | union |
71 | char *spaceValue; | 71 | { |
72 | 72 | char *commentValue; | |
73 | LSL_Type operationValue; | 73 | char *spaceValue; |
74 | LSL_AST *expressionValue; | 74 | |
75 | 75 | LSL_Type operationValue; | |
76 | float floatValue; | 76 | LSL_AST *expressionValue; |
77 | int integerValue; | 77 | |
78 | char *keyValue; | 78 | float floatValue; |
79 | LSL_Leaf *listValue; | 79 | int integerValue; |
80 | char *stringValue; | 80 | char *keyValue; |
81 | float vectorValue[3]; | 81 | LSL_Leaf *listValue; |
82 | float rotationValue[4]; | 82 | char *stringValue; |
83 | 83 | float vectorValue[3]; | |
84 | LSL_Identifier *variableValue; | 84 | float rotationValue[4]; |
85 | 85 | ||
86 | char *labelValue; | 86 | LSL_Identifier *variableValue; |
87 | LSL_Statement *doValue; | 87 | |
88 | LSL_Statement *forValue; | 88 | char *labelValue; |
89 | LSL_Statement *elseIfValue; | 89 | LSL_Statement *doValue; |
90 | LSL_Statement *elseValue; | 90 | LSL_Statement *forValue; |
91 | LSL_Statement *ifValue; | 91 | LSL_Statement *elseIfValue; |
92 | char *jumpValue; | 92 | LSL_Statement *elseValue; |
93 | LSL_Statement *returnValue; | 93 | LSL_Statement *ifValue; |
94 | char *stateChangeValue; | 94 | char *jumpValue; |
95 | LSL_Statement *whileValue; | 95 | LSL_Statement *returnValue; |
96 | LSL_Statement *statementValue; | 96 | char *stateChangeValue; |
97 | 97 | LSL_Statement *whileValue; | |
98 | LSL_Block *blockValue; | 98 | LSL_Statement *statementValue; |
99 | LSL_Identifier *parameterValue; | 99 | |
100 | LSL_Function *functionValue; | 100 | LSL_Block *blockValue; |
101 | LSL_State *stateValue; | 101 | LSL_Identifier *parameterValue; |
102 | LSL_Script *scriptValue; | 102 | LSL_Function *functionValue; |
103 | 103 | LSL_State *stateValue; | |
104 | char *unknownValue; | 104 | LSL_Script *scriptValue; |
105 | |||
106 | char *unknownValue; | ||
107 | } value; | ||
108 | char *ignorableText; | ||
109 | int line, column; | ||
105 | }; | 110 | }; |
106 | 111 | ||
107 | struct _LSL_Value | 112 | struct _LSL_Value |
@@ -176,7 +181,7 @@ typedef struct | |||
176 | } LuaSL_yyparseParam; | 181 | } LuaSL_yyparseParam; |
177 | 182 | ||
178 | // the parameter name (of the reentrant 'yyparse' function) | 183 | // the parameter name (of the reentrant 'yyparse' function) |
179 | // data is a pointer to a 'SParserParam' structure | 184 | // data is a pointer to a 'yyparseParam' structure |
180 | #define YYPARSE_PARAM data | 185 | #define YYPARSE_PARAM data |
181 | 186 | ||
182 | // the argument for the 'yylex' function | 187 | // the argument for the 'yylex' function |
@@ -184,12 +189,11 @@ typedef struct | |||
184 | 189 | ||
185 | 190 | ||
186 | LSL_AST *addExpression(LSL_AST *exp); | 191 | LSL_AST *addExpression(LSL_AST *exp); |
187 | LSL_AST *addInteger(int value); | 192 | LSL_AST *addInteger(LSL_Leaf *lval, int value); |
188 | LSL_AST *addOperation(LSL_Type type, LSL_AST *left, LSL_AST *right); | 193 | LSL_AST *addOperation(LSL_Leaf *lval, LSL_Type type, LSL_AST *left, LSL_AST *right); |
189 | LSL_AST *addParenthesis(LSL_AST *expr); | 194 | LSL_AST *addParenthesis(LSL_Leaf *lval, LSL_AST *expr); |
190 | LSL_Statement *createStatement(LSL_Type type, LSL_AST *root); | 195 | LSL_Statement *createStatement(LSL_Type type, LSL_AST *root); |
191 | LSL_AST *addStatement(LSL_Statement *statement, LSL_AST *root); | 196 | LSL_AST *addStatement(LSL_Statement *statement, LSL_AST *root); |
192 | LSL_AST *addSpace(char *text, LSL_AST *root); | ||
193 | 197 | ||
194 | int yyerror(const char *msg); | 198 | int yyerror(const char *msg); |
195 | int yyparse(void *param); | 199 | int yyparse(void *param); |
diff --git a/LuaSL/src/LuaSL_lexer.l b/LuaSL/src/LuaSL_lexer.l index 3728ab9..08a68ef 100644 --- a/LuaSL/src/LuaSL_lexer.l +++ b/LuaSL/src/LuaSL_lexer.l | |||
@@ -5,15 +5,8 @@ | |||
5 | #include <stdio.h> | 5 | #include <stdio.h> |
6 | 6 | ||
7 | void comment(yyscan_t yyscanner); | 7 | void comment(yyscan_t yyscanner); |
8 | void count(char *text); | 8 | void common(YYSTYPE *lval, char *text, boolean checkIgnorable); |
9 | 9 | void ignorable(char *text); | |
10 | #ifdef LUASL_DEBUG | ||
11 | #undef ECHO | ||
12 | #define ECHO count(yytext); printf ("[%s]\n", yytext) | ||
13 | #else | ||
14 | #undef ECHO | ||
15 | #define ECHO count(yytext) | ||
16 | #endif | ||
17 | 10 | ||
18 | %} | 11 | %} |
19 | 12 | ||
@@ -35,85 +28,84 @@ NAME [[:alpha:]](_|[[:alpha:]]|[[:digit:]])* | |||
35 | 28 | ||
36 | /* The order here is important, in mysterious ways. The more specific the lower in case of ambiguities like "floats contain integers". I think, not tested that well yet. */ | 29 | /* The order here is important, in mysterious ways. The more specific the lower in case of ambiguities like "floats contain integers". I think, not tested that well yet. */ |
37 | 30 | ||
38 | /* White space. */ | 31 | /* Ignorables. */ |
39 | [[:space:]]+ %{ ECHO; /* yylval->spaceValue = strdup(yytext); return LSL_SPACE; */ %} | 32 | [[:space:]]+ %{ common(yylval, yytext, FALSE); ignorable(yytext); %} |
40 | "/*" %{ ECHO; comment(yyscanner); %} | 33 | /* Yes I know this will have problems with huge comments, just being simple to get it to work for now. */ |
41 | "//"[^\n]* %{ ECHO; /* consume //-comment */ %} | 34 | "/*"([^"*/"]*)"*/" %{ common(yylval, yytext, FALSE); ignorable(yytext); %} |
35 | "//"[^\n]* %{ common(yylval, yytext, FALSE); ignorable(yytext); %} | ||
42 | 36 | ||
43 | /* Operations. */ | 37 | /* Operations. */ |
44 | "&&" { ECHO; return LSL_BOOL_AND; } | 38 | "&&" { common(yylval, yytext, TRUE); return LSL_BOOL_AND; } |
45 | "||" { ECHO; return LSL_BOOL_OR; } | 39 | "||" { common(yylval, yytext, TRUE); return LSL_BOOL_OR; } |
46 | "|" { ECHO; return LSL_BIT_OR; } | 40 | "|" { common(yylval, yytext, TRUE); return LSL_BIT_OR; } |
47 | "^" { ECHO; return LSL_BIT_XOR; } | 41 | "^" { common(yylval, yytext, TRUE); return LSL_BIT_XOR; } |
48 | "&" { ECHO; return LSL_BIT_AND; } | 42 | "&" { common(yylval, yytext, TRUE); return LSL_BIT_AND; } |
49 | "!=" { ECHO; return LSL_NOT_EQUAL; } | 43 | "!=" { common(yylval, yytext, TRUE); return LSL_NOT_EQUAL; } |
50 | "==" { ECHO; return LSL_EQUAL; } | 44 | "==" { common(yylval, yytext, TRUE); return LSL_EQUAL; } |
51 | ">=" { ECHO; return LSL_GREATER_EQUAL; } | 45 | ">=" { common(yylval, yytext, TRUE); return LSL_GREATER_EQUAL; } |
52 | "<=" { ECHO; return LSL_LESS_EQUAL; } | 46 | "<=" { common(yylval, yytext, TRUE); return LSL_LESS_EQUAL; } |
53 | ">" { ECHO; return LSL_GREATER_THAN; } | 47 | ">" { common(yylval, yytext, TRUE); return LSL_GREATER_THAN; } |
54 | "<" { ECHO; return LSL_LESS_THAN; } | 48 | "<" { common(yylval, yytext, TRUE); return LSL_LESS_THAN; } |
55 | ">>" { ECHO; return LSL_RIGHT_SHIFT; } | 49 | ">>" { common(yylval, yytext, TRUE); return LSL_RIGHT_SHIFT; } |
56 | "<<" { ECHO; return LSL_LEFT_SHIFT; } | 50 | "<<" { common(yylval, yytext, TRUE); return LSL_LEFT_SHIFT; } |
57 | "+" { ECHO; return LSL_ADD; } | 51 | "+" { common(yylval, yytext, TRUE); return LSL_ADD; } |
58 | "-" { ECHO; return LSL_SUBTRACT; } | 52 | "-" { common(yylval, yytext, TRUE); return LSL_SUBTRACT; } |
59 | "*" { ECHO; return LSL_MULTIPLY; } | 53 | "*" { common(yylval, yytext, TRUE); return LSL_MULTIPLY; } |
60 | "%" { ECHO; return LSL_MODULO; } | 54 | "%" { common(yylval, yytext, TRUE); return LSL_MODULO; } |
61 | "/" { ECHO; return LSL_DIVIDE; } | 55 | "/" { common(yylval, yytext, TRUE); return LSL_DIVIDE; } |
62 | "!" { ECHO; return LSL_BOOL_NOT; } | 56 | "!" { common(yylval, yytext, TRUE); return LSL_BOOL_NOT; } |
63 | "~" { ECHO; return LSL_BIT_NOT; } | 57 | "~" { common(yylval, yytext, TRUE); return LSL_BIT_NOT; } |
64 | /* "<" { ECHO; return LSL_ANGLE_OPEN; } */ | 58 | "[" { common(yylval, yytext, TRUE); return LSL_BRACKET_OPEN; } |
65 | /* ">" { ECHO; return LSL_ANGLE_CLOSE; } */ | 59 | "]" { common(yylval, yytext, TRUE); return LSL_BRACKET_CLOSE; } |
66 | "[" { ECHO; return LSL_BRACKET_OPEN; } | 60 | "(" { common(yylval, yytext, TRUE); return LSL_PARENTHESIS_OPEN; } |
67 | "]" { ECHO; return LSL_BRACKET_CLOSE; } | 61 | ")" { common(yylval, yytext, TRUE); return LSL_PARENTHESIS_CLOSE; } |
68 | "(" { ECHO; return LSL_PARENTHESIS_OPEN; } | 62 | "+=" { common(yylval, yytext, TRUE); return LSL_ASSIGNMENT_ADD; } |
69 | ")" { ECHO; return LSL_PARENTHESIS_CLOSE; } | 63 | "-=" { common(yylval, yytext, TRUE); return LSL_ASSIGNMENT_SUBTRACT; } |
70 | "+=" { ECHO; return LSL_ASSIGNMENT_ADD; } | 64 | "*=" { common(yylval, yytext, TRUE); return LSL_ASSIGNMENT_MULTIPLY; } |
71 | "-=" { ECHO; return LSL_ASSIGNMENT_SUBTRACT; } | 65 | "%=" { common(yylval, yytext, TRUE); return LSL_ASSIGNMENT_MODULO; } |
72 | "*=" { ECHO; return LSL_ASSIGNMENT_MULTIPLY; } | 66 | "/=" { common(yylval, yytext, TRUE); return LSL_ASSIGNMENT_DIVIDE; } |
73 | "%=" { ECHO; return LSL_ASSIGNMENT_MODULO; } | 67 | "=" { common(yylval, yytext, TRUE); return LSL_ASSIGNMENT_PLAIN; } |
74 | "/=" { ECHO; return LSL_ASSIGNMENT_DIVIDE; } | 68 | "." { common(yylval, yytext, TRUE); return LSL_DOT; } |
75 | "=" { ECHO; return LSL_ASSIGNMENT_PLAIN; } | 69 | "--" { common(yylval, yytext, TRUE); return LSL_DECREMENT_PRE; } |
76 | "." { ECHO; return LSL_DOT; } | 70 | "++" { common(yylval, yytext, TRUE); return LSL_INCREMENT_PRE; } |
77 | "--" { ECHO; return LSL_DECREMENT_PRE; } | 71 | "," { common(yylval, yytext, TRUE); return LSL_COMMA; } |
78 | "++" { ECHO; return LSL_INCREMENT_PRE; } | ||
79 | "," { ECHO; return LSL_COMMA; } | ||
80 | 72 | ||
81 | /* Types. */ | 73 | /* Types. */ |
82 | {INTEGER} %{ ECHO; yylval->integerValue = atoi(yytext); return LSL_INTEGER; %} | 74 | {INTEGER} %{ common(yylval, yytext, TRUE); yylval->value.integerValue = atoi(yytext); return LSL_INTEGER; %} |
83 | {FLOAT} %{ ECHO; yylval->floatValue = atof(yytext); return LSL_FLOAT; %} | 75 | {FLOAT} %{ common(yylval, yytext, TRUE); yylval->value.floatValue = atof(yytext); return LSL_FLOAT; %} |
84 | 76 | ||
85 | /* Type keywords. */ | 77 | /* Type keywords. */ |
86 | "float" %{ ECHO; return LSL_TYPE_FLOAT; %} | 78 | "float" %{ common(yylval, yytext, TRUE); return LSL_TYPE_FLOAT; %} |
87 | "integer" %{ ECHO; return LSL_TYPE_INTEGER; %} | 79 | "integer" %{ common(yylval, yytext, TRUE); return LSL_TYPE_INTEGER; %} |
88 | "key" %{ ECHO; return LSL_TYPE_KEY; %} | 80 | "key" %{ common(yylval, yytext, TRUE); return LSL_TYPE_KEY; %} |
89 | "list" %{ ECHO; return LSL_TYPE_LIST; %} | 81 | "list" %{ common(yylval, yytext, TRUE); return LSL_TYPE_LIST; %} |
90 | "quaternion" %{ ECHO; return LSL_TYPE_ROTATION; %} | 82 | "quaternion" %{ common(yylval, yytext, TRUE); return LSL_TYPE_ROTATION; %} |
91 | "rotation" %{ ECHO; return LSL_TYPE_ROTATION; %} | 83 | "rotation" %{ common(yylval, yytext, TRUE); return LSL_TYPE_ROTATION; %} |
92 | "string" %{ ECHO; return LSL_TYPE_STRING; %} | 84 | "string" %{ common(yylval, yytext, TRUE); return LSL_TYPE_STRING; %} |
93 | "vector" %{ ECHO; return LSL_TYPE_VECTOR; %} | 85 | "vector" %{ common(yylval, yytext, TRUE); return LSL_TYPE_VECTOR; %} |
94 | 86 | ||
95 | /* Statement keywords. */ | 87 | /* Statement keywords. */ |
96 | "do" %{ ECHO; return LSL_DO; %} | 88 | "do" %{ common(yylval, yytext, TRUE); return LSL_DO; %} |
97 | "for" %{ ECHO; return LSL_FOR; %} | 89 | "for" %{ common(yylval, yytext, TRUE); return LSL_FOR; %} |
98 | "else" %{ ECHO; return LSL_ELSE; %} | 90 | "else" %{ common(yylval, yytext, TRUE); return LSL_ELSE; %} |
99 | "if" %{ ECHO; return LSL_IF; %} | 91 | "if" %{ common(yylval, yytext, TRUE); return LSL_IF; %} |
100 | "jump" %{ ECHO; return LSL_JUMP; %} | 92 | "jump" %{ common(yylval, yytext, TRUE); return LSL_JUMP; %} |
101 | "return" %{ ECHO; return LSL_RETURN; %} | 93 | "return" %{ common(yylval, yytext, TRUE); return LSL_RETURN; %} |
102 | "state" %{ ECHO; return LSL_STATE_CHANGE; %} | 94 | "state" %{ common(yylval, yytext, TRUE); return LSL_STATE_CHANGE; %} |
103 | "while" %{ ECHO; return LSL_WHILE; %} | 95 | "while" %{ common(yylval, yytext, TRUE); return LSL_WHILE; %} |
104 | 96 | ||
105 | {NAME} %{ ECHO; /* yylval->nameValue = strdup(yytext); return LSL_NAME; */ %} | 97 | {NAME} %{ common(yylval, yytext, TRUE); /* yylval->value.nameValue = strdup(yytext); return LSL_NAME; */ %} |
106 | 98 | ||
107 | /* Other symbols. */ | 99 | /* Other symbols. */ |
108 | "@" %{ ECHO; return LSL_LABEL; %} | 100 | "@" %{ common(yylval, yytext, TRUE); return LSL_LABEL; %} |
109 | "{" %{ ECHO; return LSL_BLOCK_OPEN; %} | 101 | "{" %{ common(yylval, yytext, TRUE); return LSL_BLOCK_OPEN; %} |
110 | "}" %{ ECHO; return LSL_BLOCK_CLOSE; %} | 102 | "}" %{ common(yylval, yytext, TRUE); return LSL_BLOCK_CLOSE; %} |
111 | ";" { ECHO; return LSL_STATEMENT; } | 103 | ";" %{ common(yylval, yytext, TRUE); return LSL_STATEMENT; %} |
112 | 104 | ||
113 | <<EOF>> { yyterminate(); } | 105 | <<EOF>> { yyterminate(); } |
114 | 106 | ||
115 | /* Everything else */ | 107 | /* Everything else */ |
116 | . %{ ECHO; printf(" unexpected character.\n"); %} | 108 | . %{ common(yylval, yytext, TRUE); printf(" unexpected character.\n"); %} |
117 | 109 | ||
118 | %% | 110 | %% |
119 | 111 | ||
@@ -130,10 +122,11 @@ void comment(yyscan_t yyscanner) | |||
130 | yyerror("unterminated comment"); | 122 | yyerror("unterminated comment"); |
131 | } | 123 | } |
132 | 124 | ||
133 | int column = 0; | 125 | static char *ignorableText = NULL; |
134 | int line = 0; | 126 | static int column = 0; |
127 | static int line = 0; | ||
135 | 128 | ||
136 | void count(char *text) | 129 | void common(YYSTYPE *lval, char *text, boolean checkIgnorable) |
137 | { | 130 | { |
138 | int i; | 131 | int i; |
139 | 132 | ||
@@ -147,6 +140,33 @@ void count(char *text) | |||
147 | column += 8 - (column % 8); | 140 | column += 8 - (column % 8); |
148 | else | 141 | else |
149 | column++; | 142 | column++; |
143 | |||
144 | lval->line = line; | ||
145 | lval->column = column; | ||
146 | |||
147 | if (checkIgnorable) | ||
148 | { | ||
149 | lval->ignorableText = ignorableText; | ||
150 | ignorableText = NULL; | ||
151 | } | ||
152 | |||
153 | #ifdef LUASL_DEBUG | ||
154 | printf ("%04d, %04d [%s]\n", line, column, text); | ||
155 | #endif | ||
156 | } | ||
157 | |||
158 | void ignorable(char *text) | ||
159 | { | ||
160 | if (ignorableText) | ||
161 | { | ||
162 | int lenI = strlen(ignorableText); | ||
163 | int lenT = strlen(text); | ||
164 | |||
165 | ignorableText = realloc(ignorableText, lenI + lenT + 1); | ||
166 | sprintf(&ignorableText[lenI], "%s", text); | ||
167 | } | ||
168 | else | ||
169 | ignorableText = strdup(text); | ||
150 | } | 170 | } |
151 | 171 | ||
152 | int yyerror(const char *msg) | 172 | int yyerror(const char *msg) |
diff --git a/LuaSL/src/LuaSL_yaccer.y b/LuaSL/src/LuaSL_yaccer.y index 4b456b1..ed69dd3 100644 --- a/LuaSL/src/LuaSL_yaccer.y +++ b/LuaSL/src/LuaSL_yaccer.y | |||
@@ -10,10 +10,9 @@ | |||
10 | %define api.pure | 10 | %define api.pure |
11 | 11 | ||
12 | 12 | ||
13 | %type <spaceValue> ignorable | 13 | %token <value.spaceValue> LSL_SPACE /* Never actually emitted, but we need it in the token table. */ |
14 | %token <spaceValue> LSL_SPACE | ||
15 | 14 | ||
16 | %type <expressionValue> expr | 15 | %type <value.expressionValue> expr |
17 | %left LSL_BOOL_AND | 16 | %left LSL_BOOL_AND |
18 | %left LSL_BOOL_OR | 17 | %left LSL_BOOL_OR |
19 | %left LSL_BIT_AND LSL_BIT_XOR LSL_BIT_OR | 18 | %left LSL_BIT_AND LSL_BIT_XOR LSL_BIT_OR |
@@ -31,8 +30,8 @@ | |||
31 | %right LSL_DECREMENT_PRE LSL_INCREMENT_PRE | 30 | %right LSL_DECREMENT_PRE LSL_INCREMENT_PRE |
32 | %token LSL_COMMA | 31 | %token LSL_COMMA |
33 | 32 | ||
34 | %token <floatValue> LSL_FLOAT | 33 | %token <value.floatValue> LSL_FLOAT |
35 | %token <integerValue> LSL_INTEGER | 34 | %token <value.integerValue> LSL_INTEGER |
36 | 35 | ||
37 | %nonassoc LSL_TYPE_FLOAT LSL_TYPE_INTEGER LSL_TYPE_KEY LSL_TYPE_LIST LSL_TYPE_ROTATION LSL_TYPE_STRING LSL_TYPE_VECTOR | 36 | %nonassoc LSL_TYPE_FLOAT LSL_TYPE_INTEGER LSL_TYPE_KEY LSL_TYPE_LIST LSL_TYPE_ROTATION LSL_TYPE_STRING LSL_TYPE_VECTOR |
38 | 37 | ||
@@ -42,47 +41,43 @@ | |||
42 | 41 | ||
43 | %nonassoc LSL_BLOCK_OPEN LSL_BLOCK_CLOSE | 42 | %nonassoc LSL_BLOCK_OPEN LSL_BLOCK_CLOSE |
44 | 43 | ||
45 | %type <statementValue> statement | 44 | %type <value.statementValue> statement |
46 | %nonassoc LSL_STATEMENT | 45 | %nonassoc LSL_STATEMENT |
47 | 46 | ||
48 | %type <scriptValue> script | 47 | %type <value.scriptValue> script |
49 | 48 | ||
50 | %% | 49 | %% |
51 | 50 | ||
52 | input : | 51 | input : |
53 | ignorable | 52 | expr { ((LuaSL_yyparseParam*)data)->ast = addOperation(&yylval, LSL_EXPRESSION, $1, $1); } |
54 | | expr { ((LuaSL_yyparseParam*)data)->ast = addOperation(LSL_EXPRESSION, $1, $1); } | ||
55 | | statement { ((LuaSL_yyparseParam*)data)->ast = addStatement($1, ((LuaSL_yyparseParam*)data)->ast); } | 53 | | statement { ((LuaSL_yyparseParam*)data)->ast = addStatement($1, ((LuaSL_yyparseParam*)data)->ast); } |
56 | | script | 54 | | script |
57 | ; | 55 | ; |
58 | 56 | ||
59 | ignorable : LSL_SPACE { ((LuaSL_yyparseParam*)data)->ast = addSpace($1, ((LuaSL_yyparseParam*)data)->ast); } | ||
60 | ; | ||
61 | |||
62 | expr : | 57 | expr : |
63 | expr LSL_BOOL_AND expr { $$ = addOperation( LSL_BOOL_AND, $1, $3 ); } | 58 | expr LSL_BOOL_AND expr { $$ = addOperation(&yylval, LSL_BOOL_AND, $1, $3); } |
64 | | expr LSL_BOOL_OR expr { $$ = addOperation( LSL_BOOL_OR, $1, $3 ); } | 59 | | expr LSL_BOOL_OR expr { $$ = addOperation(&yylval, LSL_BOOL_OR, $1, $3); } |
65 | | expr LSL_BIT_OR expr { $$ = addOperation( LSL_BIT_OR, $1, $3 ); } | 60 | | expr LSL_BIT_OR expr { $$ = addOperation(&yylval, LSL_BIT_OR, $1, $3); } |
66 | | expr LSL_BIT_XOR expr { $$ = addOperation( LSL_BIT_XOR, $1, $3 ); } | 61 | | expr LSL_BIT_XOR expr { $$ = addOperation(&yylval, LSL_BIT_XOR, $1, $3); } |
67 | | expr LSL_BIT_AND expr { $$ = addOperation( LSL_BIT_AND, $1, $3 ); } | 62 | | expr LSL_BIT_AND expr { $$ = addOperation(&yylval, LSL_BIT_AND, $1, $3); } |
68 | | expr LSL_NOT_EQUAL expr { $$ = addOperation( LSL_NOT_EQUAL, $1, $3 ); } | 63 | | expr LSL_NOT_EQUAL expr { $$ = addOperation(&yylval, LSL_NOT_EQUAL, $1, $3); } |
69 | | expr LSL_EQUAL expr { $$ = addOperation( LSL_EQUAL, $1, $3 ); } | 64 | | expr LSL_EQUAL expr { $$ = addOperation(&yylval, LSL_EQUAL, $1, $3); } |
70 | | expr LSL_GREATER_EQUAL expr { $$ = addOperation( LSL_GREATER_EQUAL, $1, $3 ); } | 65 | | expr LSL_GREATER_EQUAL expr { $$ = addOperation(&yylval, LSL_GREATER_EQUAL, $1, $3); } |
71 | | expr LSL_LESS_EQUAL expr { $$ = addOperation( LSL_LESS_EQUAL, $1, $3 ); } | 66 | | expr LSL_LESS_EQUAL expr { $$ = addOperation(&yylval, LSL_LESS_EQUAL, $1, $3); } |
72 | | expr LSL_GREATER_THAN expr { $$ = addOperation( LSL_GREATER_THAN, $1, $3 ); } | 67 | | expr LSL_GREATER_THAN expr { $$ = addOperation(&yylval, LSL_GREATER_THAN, $1, $3); } |
73 | | expr LSL_LESS_THAN expr { $$ = addOperation( LSL_LESS_THAN, $1, $3 ); } | 68 | | expr LSL_LESS_THAN expr { $$ = addOperation(&yylval, LSL_LESS_THAN, $1, $3); } |
74 | | expr LSL_RIGHT_SHIFT expr { $$ = addOperation( LSL_RIGHT_SHIFT, $1, $3 ); } | 69 | | expr LSL_RIGHT_SHIFT expr { $$ = addOperation(&yylval, LSL_RIGHT_SHIFT, $1, $3); } |
75 | | expr LSL_LEFT_SHIFT expr { $$ = addOperation( LSL_LEFT_SHIFT, $1, $3 ); } | 70 | | expr LSL_LEFT_SHIFT expr { $$ = addOperation(&yylval, LSL_LEFT_SHIFT, $1, $3); } |
76 | | expr LSL_ADD expr { $$ = addOperation( LSL_ADD, $1, $3 ); } | 71 | | expr LSL_ADD expr { $$ = addOperation(&yylval, LSL_ADD, $1, $3); } |
77 | | expr LSL_SUBTRACT expr { $$ = addOperation( LSL_SUBTRACT, $1, $3 ); } | 72 | | expr LSL_SUBTRACT expr { $$ = addOperation(&yylval, LSL_SUBTRACT, $1, $3); } |
78 | | expr LSL_MULTIPLY expr { $$ = addOperation( LSL_MULTIPLY, $1, $3 ); } | 73 | | expr LSL_MULTIPLY expr { $$ = addOperation(&yylval, LSL_MULTIPLY, $1, $3); } |
79 | | expr LSL_MODULO expr { $$ = addOperation( LSL_MODULO, $1, $3 ); } | 74 | | expr LSL_MODULO expr { $$ = addOperation(&yylval, LSL_MODULO, $1, $3); } |
80 | | expr LSL_DIVIDE expr { $$ = addOperation( LSL_DIVIDE, $1, $3 ); } | 75 | | expr LSL_DIVIDE expr { $$ = addOperation(&yylval, LSL_DIVIDE, $1, $3); } |
81 | | LSL_BIT_NOT expr { $$ = addOperation( LSL_BIT_NOT, NULL, $2 ); } | 76 | | LSL_BIT_NOT expr { $$ = addOperation(&yylval, LSL_BIT_NOT, NULL, $2); } |
82 | | LSL_BOOL_NOT expr { $$ = addOperation( LSL_BOOL_NOT, NULL, $2 ); } | 77 | | LSL_BOOL_NOT expr { $$ = addOperation(&yylval, LSL_BOOL_NOT, NULL, $2); } |
83 | | LSL_SUBTRACT expr { $$ = addOperation( LSL_NEGATION, NULL, $2 ); } %prec LSL_NEGATION | 78 | | LSL_SUBTRACT expr { $$ = addOperation(&yylval, LSL_NEGATION, NULL, $2); } %prec LSL_NEGATION |
84 | | LSL_PARENTHESIS_OPEN expr LSL_PARENTHESIS_CLOSE { $$ = addParenthesis($2); } | 79 | | LSL_PARENTHESIS_OPEN expr LSL_PARENTHESIS_CLOSE { $$ = addParenthesis(&yylval, $2); } |
85 | | LSL_INTEGER { $$ = addInteger($1); } | 80 | | LSL_INTEGER { $$ = addInteger(&yylval, $1); } |
86 | ; | 81 | ; |
87 | 82 | ||
88 | statement : expr LSL_STATEMENT { $$ = createStatement(LSL_EXPRESSION, $1); YYVALID; } | 83 | statement : expr LSL_STATEMENT { $$ = createStatement(LSL_EXPRESSION, $1); YYVALID; } |
diff --git a/LuaSL/test.lsl b/LuaSL/test.lsl index ddfa533..40d98b3 100644 --- a/LuaSL/test.lsl +++ b/LuaSL/test.lsl | |||
@@ -1,2 +1,3 @@ | |||
1 | 4 + 2 * 10 + 3 * (5 + 1); | 1 | 4 + /* c0 */ 2 /* c1 */ * /* c2 */ 10 /* c3 */ + /* c4 */ |
2 | 3 /* c5 */ * /* c6 */ (5 /* c7 */ + /* c8 */ 1); | ||
2 | 3 | ||