diff options
author | Preston Pan <preston@nullring.xyz> | 2023-01-06 11:44:20 -0800 |
---|---|---|
committer | Preston Pan <preston@nullring.xyz> | 2023-01-06 11:44:20 -0800 |
commit | 9083582a5d3bfc8fae859b2ce124d86ad7420dcc (patch) | |
tree | 8f5d9ccdb2c96e938205503697a288382bfe0126 /src | |
parent | 30f12dfc1f32688f377913c52b131aa78d7830b5 (diff) |
recursion works now
Diffstat (limited to 'src')
-rw-r--r-- | src/main.c | 15 | ||||
-rw-r--r-- | src/visitor.c | 13 |
2 files changed, 16 insertions, 12 deletions
@@ -85,13 +85,14 @@ int main(int argc, char **argv) { /* print_root(root); */ /* TODO: TEST RECURSION */ - /* lexer_t *lexer = init_lexer("(bind factorial (lambda (x) (if (<= x 0) 1 (* - * x" */ - /* "(factorial (- x 1)))))) (factorial 3)"); */ - /* parser_t *parser = init_parser(lexer); */ - /* visitor_t *visitor = init_visitor(parser); */ - /* ast_t *root = eval(visitor); */ - /* print_root(root); */ + /* char *expr = "(if (= 0 0) 1 2)"; */ + char *expr = "(bind factorial (lambda (n) (if (= n 0) 1 (* n (factorial (- n " + "1)))))) (factorial 3)"; + lexer_t *lexer = init_lexer(expr); + parser_t *parser = init_parser(lexer); + visitor_t *visitor = init_visitor(parser); + ast_t *root = eval(visitor); + print_root(root); /* lexer_t *lexer = init_lexer("((lambda (x y) (+ x y)) (+ 3 4) 4) (+ 3 * 4)"); */ diff --git a/src/visitor.c b/src/visitor.c index 5e58952..10782c8 100644 --- a/src/visitor.c +++ b/src/visitor.c @@ -67,7 +67,6 @@ bool is_built_in(ast_t *e) { * =, equal (for strings), input */ ast_t *eval_symbol(visitor_t *v, ast_t *e) { /* hash_table_t *lmao = stack_peek(v->stack_frame); */ - printf("symbol\n"); printf("%s\n", e->string_value); hash_table_t *h = stack_peek(v->stack_frame); if (is_built_in(e)) @@ -88,6 +87,7 @@ ast_t *eval_symbol(visitor_t *v, ast_t *e) { hash_table_add(v->eval_table, e->string_value, eval); return eval; } else { + printf("symbol error\n"); eval_error(v, e); return NULL; } @@ -294,13 +294,14 @@ ast_t *eval_list(visitor_t *v, ast_t *e) { eval_error(v, e); ast_t *arg1 = eval_expr(v, args->car); - ast_t *arg2 = eval_expr(v, args->cdr->car); - ast_t *arg3 = eval_expr(v, args->cdr->cdr->car); if (arg1->type == AST_BOOL) { - if (arg1->bool_value) + if (arg1->bool_value) { + ast_t *arg2 = eval_expr(v, args->cdr->car); return arg2; - else + } else { + ast_t *arg3 = eval_expr(v, args->cdr->cdr->car); return arg3; + } } else eval_error(v, e); } else if (strcmp(function->string_value, "<") == 0) { @@ -432,6 +433,7 @@ ast_t *eval_list(visitor_t *v, ast_t *e) { } ast_t *eval_expr(visitor_t *v, ast_t *e) { + ast_type_print(e); if (is_self_evaluating(e)) return e; else if (e->type == AST_PAIR && is_proper_list(e)) @@ -439,6 +441,7 @@ ast_t *eval_expr(visitor_t *v, ast_t *e) { else if (e->type == AST_SYMBOL) return eval_symbol(v, e); else { + printf("eval error\n"); eval_error(v, e); return NULL; } |