diff options
author | David Walter Seikel | 2012-01-16 05:36:59 +1000 |
---|---|---|
committer | David Walter Seikel | 2012-01-16 05:36:59 +1000 |
commit | db420ae1d5147c32b1395d357ad40778efc400a8 (patch) | |
tree | abda3c85788eed29e0a266e12eab0e0e1cd27e57 | |
parent | We need an untyped function declaration, but it conflicts, so leave it commen... (diff) | |
download | SledjHamr-db420ae1d5147c32b1395d357ad40778efc400a8.zip SledjHamr-db420ae1d5147c32b1395d357ad40778efc400a8.tar.gz SledjHamr-db420ae1d5147c32b1395d357ad40778efc400a8.tar.bz2 SledjHamr-db420ae1d5147c32b1395d357ad40778efc400a8.tar.xz |
Make things more robust against a half arsed parser.
-rw-r--r-- | LuaSL/src/LuaSL_LSL_tree.c | 10 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_LSL_tree.h | 2 | ||||
-rw-r--r-- | LuaSL/src/LuaSL_lemon_yaccer.y | 6 |
3 files changed, 10 insertions, 8 deletions
diff --git a/LuaSL/src/LuaSL_LSL_tree.c b/LuaSL/src/LuaSL_LSL_tree.c index a0490c9..0f9013a 100644 --- a/LuaSL/src/LuaSL_LSL_tree.c +++ b/LuaSL/src/LuaSL_LSL_tree.c | |||
@@ -290,7 +290,8 @@ LSL_Leaf *addParenthesis(LSL_Leaf *lval, LSL_Leaf *expr, LSL_Leaf *rval) | |||
290 | if (lval) | 290 | if (lval) |
291 | { | 291 | { |
292 | lval->value.parenthesis = parens; | 292 | lval->value.parenthesis = parens; |
293 | lval->basicType = expr->basicType; | 293 | if (expr) |
294 | lval->basicType = expr->basicType; | ||
294 | } | 295 | } |
295 | } | 296 | } |
296 | return lval; | 297 | return lval; |
@@ -311,19 +312,20 @@ LSL_Leaf *addStatement(LSL_Leaf *lval, LSL_Type type, LSL_Leaf *expr) | |||
311 | return lval; | 312 | return lval; |
312 | } | 313 | } |
313 | 314 | ||
314 | LSL_Leaf *addTypecast(LSL_Leaf *lval, LSL_Leaf *type, LSL_Leaf *rval) | 315 | LSL_Leaf *addTypecast(LSL_Leaf *lval, LSL_Leaf *type, LSL_Leaf *rval, LSL_Leaf *expr) |
315 | { | 316 | { |
316 | LSL_Parenthesis *parens = malloc(sizeof(LSL_Parenthesis)); | 317 | LSL_Parenthesis *parens = malloc(sizeof(LSL_Parenthesis)); |
317 | 318 | ||
318 | if (parens) | 319 | if (parens) |
319 | { | 320 | { |
320 | parens->left = lval; | 321 | parens->left = lval; |
321 | parens->expression = type; | 322 | parens->expression = expr; |
322 | parens->right = rval; | 323 | parens->right = rval; |
323 | if (lval) | 324 | if (lval) |
324 | { | 325 | { |
325 | lval->value.parenthesis = parens; | 326 | lval->value.parenthesis = parens; |
326 | lval->basicType = type->basicType; | 327 | if (type) |
328 | lval->basicType = type->basicType; | ||
327 | lval->token = tokens[LSL_TYPECAST_OPEN - lowestToken]; | 329 | lval->token = tokens[LSL_TYPECAST_OPEN - lowestToken]; |
328 | } | 330 | } |
329 | if (rval) | 331 | if (rval) |
diff --git a/LuaSL/src/LuaSL_LSL_tree.h b/LuaSL/src/LuaSL_LSL_tree.h index e56e94c..1429393 100644 --- a/LuaSL/src/LuaSL_LSL_tree.h +++ b/LuaSL/src/LuaSL_LSL_tree.h | |||
@@ -289,7 +289,7 @@ LSL_Leaf *addExpression(LSL_Leaf *exp); | |||
289 | LSL_Leaf *addOperation(LSL_Leaf *left, LSL_Leaf *lval, LSL_Leaf *right); | 289 | LSL_Leaf *addOperation(LSL_Leaf *left, LSL_Leaf *lval, LSL_Leaf *right); |
290 | LSL_Leaf *addParenthesis(LSL_Leaf *lval, LSL_Leaf *expr, LSL_Leaf *rval); | 290 | LSL_Leaf *addParenthesis(LSL_Leaf *lval, LSL_Leaf *expr, LSL_Leaf *rval); |
291 | LSL_Leaf *addStatement(LSL_Leaf *lval, LSL_Type type, LSL_Leaf *expr); | 291 | LSL_Leaf *addStatement(LSL_Leaf *lval, LSL_Type type, LSL_Leaf *expr); |
292 | LSL_Leaf *addTypecast(LSL_Leaf *lval, LSL_Leaf *expr, LSL_Leaf *rval); | 292 | LSL_Leaf *addTypecast(LSL_Leaf *lval, LSL_Leaf *type, LSL_Leaf *rval, LSL_Leaf *expr); |
293 | 293 | ||
294 | void *ParseAlloc(void *(*mallocProc)(size_t)); | 294 | void *ParseAlloc(void *(*mallocProc)(size_t)); |
295 | void ParseTrace(FILE *TraceFILE, char *zTracePrompt); | 295 | void ParseTrace(FILE *TraceFILE, char *zTracePrompt); |
diff --git a/LuaSL/src/LuaSL_lemon_yaccer.y b/LuaSL/src/LuaSL_lemon_yaccer.y index a43885f..83aff23 100644 --- a/LuaSL/src/LuaSL_lemon_yaccer.y +++ b/LuaSL/src/LuaSL_lemon_yaccer.y | |||
@@ -11,7 +11,7 @@ | |||
11 | %token_destructor {burnLeaf($$);} | 11 | %token_destructor {burnLeaf($$);} |
12 | 12 | ||
13 | 13 | ||
14 | program ::= script LSL_SCRIPT(A). { A->left = param->ast; param->ast = A; } // Lemon does not like the start symbol to be on the RHS, so give it a dummy one. | 14 | program ::= script LSL_SCRIPT(A). { if (NULL != A) A->left = param->ast; param->ast = A; } // Lemon does not like the start symbol to be on the RHS, so give it a dummy one. |
15 | 15 | ||
16 | %right LSL_BOOL_AND. | 16 | %right LSL_BOOL_AND. |
17 | expr(A) ::= expr(B) LSL_BOOL_AND(C) expr(D). { A = addOperation(B, C, D); } | 17 | expr(A) ::= expr(B) LSL_BOOL_AND(C) expr(D). { A = addOperation(B, C, D); } |
@@ -68,7 +68,7 @@ exprList ::= expr. | |||
68 | exprList ::= . | 68 | exprList ::= . |
69 | expr ::= LSL_IDENTIFIER LSL_PARENTHESIS_OPEN exprList LSL_PARENTHESIS_CLOSE. | 69 | expr ::= LSL_IDENTIFIER LSL_PARENTHESIS_OPEN exprList LSL_PARENTHESIS_CLOSE. |
70 | expr(A) ::= LSL_PARENTHESIS_OPEN(B) expr(C) LSL_PARENTHESIS_CLOSE(D). { A = addParenthesis(B, C, D); } | 70 | expr(A) ::= LSL_PARENTHESIS_OPEN(B) expr(C) LSL_PARENTHESIS_CLOSE(D). { A = addParenthesis(B, C, D); } |
71 | expr(A) ::= LSL_PARENTHESIS_OPEN(B) type(C) LSL_PARENTHESIS_CLOSE(D). { A = addTypecast(B, C, D); } | 71 | expr(A) ::= LSL_PARENTHESIS_OPEN(B) type(C) LSL_PARENTHESIS_CLOSE(D) expr(E). { A = addTypecast(B, C, D, E); } |
72 | 72 | ||
73 | %right LSL_ASSIGNMENT_CONCATENATE LSL_ASSIGNMENT_ADD LSL_ASSIGNMENT_SUBTRACT LSL_ASSIGNMENT_MULTIPLY LSL_ASSIGNMENT_MODULO LSL_ASSIGNMENT_DIVIDE LSL_ASSIGNMENT_PLAIN. | 73 | %right LSL_ASSIGNMENT_CONCATENATE LSL_ASSIGNMENT_ADD LSL_ASSIGNMENT_SUBTRACT LSL_ASSIGNMENT_MULTIPLY LSL_ASSIGNMENT_MODULO LSL_ASSIGNMENT_DIVIDE LSL_ASSIGNMENT_PLAIN. |
74 | expr ::= LSL_IDENTIFIER LSL_ASSIGNMENT_CONCATENATE expr. | 74 | expr ::= LSL_IDENTIFIER LSL_ASSIGNMENT_CONCATENATE expr. |
@@ -151,7 +151,7 @@ state ::= LSL_IDENTIFIER stateBlock. | |||
151 | %nonassoc LSL_SCRIPT. | 151 | %nonassoc LSL_SCRIPT. |
152 | script ::= script state. | 152 | script ::= script state. |
153 | script ::= script function. | 153 | script ::= script function. |
154 | script ::= script statement(A). { A->left = param->ast; param->ast = A; } | 154 | script ::= script statement(A). { if (NULL != A) A->left = param->ast; param->ast = A; } |
155 | script ::= . | 155 | script ::= . |
156 | 156 | ||
157 | %nonassoc LSL_SPACE LSL_COMMENT LSL_COMMENT_LINE LSL_UNKNOWN. | 157 | %nonassoc LSL_SPACE LSL_COMMENT LSL_COMMENT_LINE LSL_UNKNOWN. |