diff options
author | A404M <ahmadmahmoudiprogrammer@gmail.com> | 2025-03-27 19:07:45 +0330 |
---|---|---|
committer | A404M <ahmadmahmoudiprogrammer@gmail.com> | 2025-03-27 19:07:45 +0330 |
commit | ef3346297dc292ea2f2b25368cd671136c529415 (patch) | |
tree | f9bcb84d16b01a877a041e11aa459687a0ab7ab0 /src/runner | |
parent | 8ed01c4ca2d2356f008b40d8498173009f71d295 (diff) |
fix bug in multiple left value dereference
Diffstat (limited to 'src/runner')
-rw-r--r-- | src/runner/runner.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/src/runner/runner.c b/src/runner/runner.c index 4966893..7d36b67 100644 --- a/src/runner/runner.c +++ b/src/runner/runner.c @@ -185,15 +185,13 @@ AstTree *runExpression(AstTree *expr, bool *shouldRet) { AstTreeVariable *left; if (metadata->left.token == AST_TREE_TOKEN_VARIABLE) { left = metadata->left.metadata; - } else if (metadata->left.token == AST_TREE_TOKEN_OPERATOR_DEREFERENCE) { + } else { AstTree *left_metadata = metadata->left.metadata; - if (left_metadata->token != AST_TREE_TOKEN_VARIABLE) { + AstTree *var = runExpression(left_metadata, shouldRet); + if (var->token != AST_TREE_TOKEN_VARIABLE) { UNREACHABLE; } - left = left_metadata->metadata; - left = left->value->metadata; - } else { - UNREACHABLE; + left = var->metadata; } runnerVariableSetValue(left, runExpression(&metadata->right, shouldRet)); return copyAstTree(left->value); |