#include #include #include #include #include #include "ast.h" #include "parse.h" #include "compile.h" #include "types.h" int main(int argc, char *argv[]) { if (argc < 2) return 1; // register_printf_modifier(L"p"); if (register_printf_specifier('T', printf_type, printf_pointer_size)) errx(1, "Couldn't set printf specifier"); if (register_printf_specifier('W', printf_ast, printf_pointer_size)) errx(1, "Couldn't set printf specifier"); const char *autofmt = getenv("AUTOFMT"); if (!autofmt) autofmt = "indent -kr -l100 -nbbo -nut -sob"; file_t *f = load_file(argv[1]); ast_t *ast = parse_file(f, NULL); if (!ast) errx(1, "Could not compile!"); bool verbose = (getenv("VERBOSE") && strcmp(getenv("VERBOSE"), "1") == 0); if (verbose) { FILE *out = popen(heap_strf("bat -P --file-name='%s'", argv[1]), "w"); fputs(f->text, out); fclose(out); } if (verbose) { FILE *out = popen("bat -P --file-name=AST", "w"); fputs(ast_to_str(ast), out); fclose(out); } env_t env = {.bindings = new(table_t)}; CORD_appendf(&env.imports, "#include \"nextlang.h\"\n"); CORD_appendf(&env.staticdefs, "static bool USE_COLOR = true;\n"); // Main body: for (ast_list_t *stmt = Match(ast, Block)->statements; stmt; stmt = stmt->next) { CORD code = compile_statement(&env, stmt->ast); if (code) CORD_appendf(&env.main, "%r\n", code); } CORD program = CORD_asprintf( "#line 0 \"%s\"\n" // file "// Generated code:\n" "%r\n" // imports "%r\n" // typedefs "%r\n" // types "%r\n" // static defs "%r\n" // funcs "\n" "static void __load(void) {\n" "%r" // main "}\n" "\n" "int main(int argc, const char *argv[]) {\n" "(void)argc;\n" "(void)argv;\n" "GC_INIT();\n" "USE_COLOR = getenv(\"COLOR\") ? strcmp(getenv(\"COLOR\"), \"1\") == 0 : isatty(STDOUT_FILENO);\n" "__load();\n" "return 0;\n" "}\n", f->filename, env.imports, env.typedefs, env.types, env.staticdefs, env.funcs, env.main); if (verbose) { FILE *out = popen(heap_strf("%s | bat -P --file-name=program.c", autofmt), "w"); CORD_put(program, out); fclose(out); } const char *cflags = getenv("CFLAGS"); if (!cflags) cflags = "-std=c11 -fsanitize=signed-integer-overflow -fno-sanitize-recover"; const char *ldlibs = "-lgc -lcord -lm -L. -lnext"; if (getenv("LDLIBS")) ldlibs = heap_strf("%s %s", ldlibs, getenv("LDLIBS")); const char *ldflags = "-Wl,-rpath '-Wl,$ORIGIN'"; // const char *run = heap_strf("tcc -run %s %s %s -", cflags, ldflags, ldlibs); const char *run = heap_strf("gcc -x c %s %s %s - -o program && ./program", cflags, ldflags, ldlibs); FILE *cc = popen(run, "w"); CORD_put(program, cc); fclose(cc); return 0; } // vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0