diff options
author | Teddy <[email protected]> | 2013-08-12 09:51:08 +0800 |
---|---|---|
committer | Teddy <[email protected]> | 2013-08-12 09:51:08 +0800 |
commit | c5364249b2600f25155f4c7ac206b3d6ca0e5b06 (patch) | |
tree | d00c85150a826c9d131790fa877d49a53cf80be4 /main.cpp | |
parent | 88b91db506969f3ed7752bfe9e1e916f5e098942 (diff) |
rectified a bug in `modulo`
Diffstat (limited to 'main.cpp')
-rw-r--r-- | main.cpp | 46 |
1 files changed, 43 insertions, 3 deletions
@@ -5,22 +5,62 @@ #include "exc.h" #include <cstdio> -int main() { +int main(int argc, char **argv) { //freopen("in.scm", "r", stdin); Tokenizor *tk = new Tokenizor(); ASTGenerator *ast = new ASTGenerator(); Evaluator *eval = new Evaluator(); + bool interactive = false; + bool preload = false; + char *fname; + int rcnt = 0; + for (int i = 1; i < argc; i++) + if (strcmp(argv[i], "-i") == 0) + interactive = true; + else if (strcmp(argv[i], "-l") == 0 && i < argc - 1) + { + preload = true; + fname = argv[i + 1]; + } + + if (preload) + { + FILE *f = fopen(fname, "r"); + if (!f) + { + printf("Can not open file: %s\n", fname); + return 0; + } + tk->set_stream(f); + while (1) + { + try + { + Pair *tree = ast->absorb(tk); + if (!tree) break; + eval->run_expr(tree)->ext_repr().c_str(); + } + catch (GeneralError &e) + { + fprintf(stderr, "An error occured: %s\n", e.get_msg().c_str()); + } + } + interactive = true; + } + tk->set_stream(stdin); while (1) { + if (interactive) fprintf(stderr, "Sonsi> "); try { Pair *tree = ast->absorb(tk); if (!tree) break; - fprintf(stderr, "Ret> $%d = %s\n", rcnt++, - eval->run_expr(tree)->ext_repr().c_str()); + string output = eval->run_expr(tree)->ext_repr(); + if (interactive) + fprintf(stderr, "Ret> $%d = %s\n", rcnt++, output.c_str()); } catch (GeneralError &e) { |