aboutsummaryrefslogtreecommitdiff
path: root/src/main.c
diff options
context:
space:
mode:
authorkartofen <mladenovnasko0@gmail.com>2023-06-17 23:42:31 +0300
committerkartofen <mladenovnasko0@gmail.com>2023-06-17 23:42:31 +0300
commitbcac686c1bf6a5c1dec2324269e2766babdc0fde (patch)
tree6483461015705efa8290a1ab05482a641739c1dd /src/main.c
lexer - done
Diffstat (limited to 'src/main.c')
-rw-r--r--src/main.c77
1 files changed, 77 insertions, 0 deletions
diff --git a/src/main.c b/src/main.c
new file mode 100644
index 0000000..992e594
--- /dev/null
+++ b/src/main.c
@@ -0,0 +1,77 @@
+#include <stdio.h>
+#include <string.h>
+#include <errno.h>
+
+#include "common.h"
+#include "lexer.h"
+// #include "ast.h"
+// #include "eval.h"
+
+#define READ_BUF_CAP 512
+#define DEFAULT_TOKENS_CAP 8192 // make it a command line arg
+
+lexer_t lexer = NULL;
+// ast_t root = NULL;
+// eval_t evaluator = NULL;
+
+int main(void)
+{
+ int ret = 1;
+
+ char *filename = "files/test1.lisp";
+
+ lexer = lexer_create(DEFAULT_TOKENS_CAP);
+ if(!lexer) {
+ err("lexer_create: failed");
+ goto fail;
+ }
+
+ // tokenize input
+ FILE *fp = fopen(filename, "r");
+ if(!fp) {
+ err("fopen: %s: %s", filename, strerror(errno));
+ goto fail;
+ }
+
+ char buf[READ_BUF_CAP]; size_t bytes = 0;
+ while((bytes = fread(buf, sizeof(char), READ_BUF_CAP, fp))) {
+ if(lexer_tokenize(lexer, buf, bytes)) {
+ fclose(fp); goto fail;
+ }
+
+ if(bytes < READ_BUF_CAP) break;
+ }
+
+ fclose(fp);
+ lexer_print_tokens(lexer);
+ // --------------
+
+// ast = ast_create();
+// if(!ast) {
+// err("ast_create: failed");
+// goto fail;
+// }
+
+// if(ast_parse_lexer(ast, lexer)) {
+// err("ast_parse_lexer: failed");
+// goto fail;
+// }
+
+// evaluator = evaluator_create();
+// if(!evaluator) {
+// err("evaluator_create: failed");
+// goto fail;
+// }
+
+// if(evaluator_eval_ast(evaluator, ast)) {
+// err("evaluator_eval_ast: failed");
+// goto fail;
+// }
+
+ ret = 0;
+fail:
+// evaluator_destroy(eval);
+// ast_destroy(ast);
+ lexer_destroy(lexer);
+ return ret;
+}