From 9083582a5d3bfc8fae859b2ce124d86ad7420dcc Mon Sep 17 00:00:00 2001 From: Preston Pan Date: Fri, 6 Jan 2023 11:44:20 -0800 Subject: recursion works now --- src/main.c | 15 ++++++++------- src/visitor.c | 13 ++++++++----- 2 files changed, 16 insertions(+), 12 deletions(-) (limited to 'src') diff --git a/src/main.c b/src/main.c index b111ec5..73885ad 100644 --- a/src/main.c +++ b/src/main.c @@ -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; } -- cgit