aboutsummaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorTeddy <ted.sybil@gmail.com>2014-03-25 05:26:09 +0800
committerTeddy <ted.sybil@gmail.com>2014-03-25 05:26:09 +0800
commit435a104dd5bc12c19e65001f2e8540eb30f1c4eb (patch)
tree5263ac1123c62430e9396b197e79e28dac8b5e5f /main.c
parent9e43ffed22d5ba25fe545a48ac732591c346aabb (diff)
lexical bugs
Diffstat (limited to 'main.c')
-rw-r--r--main.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/main.c b/main.c
index 181dde2..463d290 100644
--- a/main.c
+++ b/main.c
@@ -5,6 +5,7 @@
extern int yyparse();
extern FILE *yyin;
+char *fname;
int yywrap() {
return 1;
@@ -15,10 +16,17 @@ int yyerror(char *s) {
void print_ast() {
yyparse();
+ if (fname)
+ printf("AST for file: \"%s\"\n", fname);
+ else
+ printf("AST for stdin\n");
+
if (ast_root)
+ {
cnode_debug_print(ast_root, 1);
+ }
else
- fprintf(stderr, "Syntax Error\n");
+ fprintf(stdout, "Syntax Error\n");
}
void print_help() {
@@ -51,7 +59,8 @@ int main(int argc, char **argv) {
}
if (optind == argc - 1)
{
- yyin = fopen(argv[argc - 1], "r");
+ fname = argv[argc - 1];
+ yyin = fopen(fname, "r");
if (!yyin)
{
fprintf(stderr, "Error while opening file.");
@@ -59,7 +68,10 @@ int main(int argc, char **argv) {
}
}
else if (optind == argc)
+ {
+ fname = NULL;
yyin = stdin;
+ }
else
{
fprintf(stderr, "Only one source file is exepected.\n");