summaryrefslogtreecommitdiff
path: root/src/main.c
diff options
context:
space:
mode:
authorLLLL Colonq <llll@colonq>2026-02-24 18:53:54 -0500
committerLLLL Colonq <llll@colonq>2026-02-24 18:53:54 -0500
commita525fadf516bc5aae2c0ec648d3b8c22e9f86293 (patch)
tree79f585f2ab2130c001529fbf46d88f9196336b25 /src/main.c
parent2b47c650a161fe2c2c4c7f4d74a19c2c6fe6021e (diff)
Add PIT_DEFAULT_MAIN
Diffstat (limited to 'src/main.c')
-rw-r--r--src/main.c44
1 files changed, 1 insertions, 43 deletions
diff --git a/src/main.c b/src/main.c
index 0b9a336..086f647 100644
--- a/src/main.c
+++ b/src/main.c
@@ -14,47 +14,5 @@ int main(int argc, char **argv) {
pit_install_library_plist(rt);
pit_install_library_alist(rt);
pit_install_library_bytestring(rt);
- if (argc < 2) { /* run repl */
- char buf[1024] = {0};
- i64 len = 0;
- pit_runtime_freeze(rt);
- if (pit_runtime_print_error(rt)) { exit(1); }
- setbuf(stdout, NULL);
- printf("> ");
- while (len < (i64) sizeof(buf) && (buf[len++] = (char) getchar()) != EOF) {
- if (buf[len - 1] == '\n') {
- pit_value bs, prog, res;
- buf[len - 1] = 0;
- bs = pit_bytes_new_cstr(rt, buf);
- prog = pit_read_bytes(rt, bs);
- res = pit_eval(rt, prog);
- if (pit_runtime_print_error(rt)) {
- rt->error = PIT_NIL;
- printf("> ");
- } else {
- char dumpbuf[1024] = {0};
- pit_dump(rt, dumpbuf, sizeof(dumpbuf) - 1, res, true);
- printf("%s\n> ", dumpbuf);
- }
- len = 0;
- }
- }
- } else { /* run file */
- pit_value bs = pit_bytes_new_file(rt, argv[1]);
- pit_lexer lex;
- pit_parser parse;
- bool eof = false;
- pit_value p = PIT_NIL;
- if (!pit_lexer_from_bytes(rt, &lex, bs)) {
- pit_error(rt, "failed to initialize lexer");
- }
- pit_parser_from_lexer(&parse, &lex);
- while (p = pit_parse(rt, &parse, &eof), !eof) {
- if (pit_runtime_print_error(rt)) exit(1);
- pit_eval(rt, p);
- if (pit_runtime_print_error(rt)) exit(1);
- }
- if (pit_runtime_print_error(rt)) exit(1);
- }
- return 0;
+ PIT_DEFAULT_MAIN(rt);
}