X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=lexer%2Fmain.c;h=40550f5a85d0b2d8935fa00a1b83d3b32e1411a3;hb=1ab4c5024b4891186f14abaa77e00c02338f624c;hp=d3f086ec00fa41b4d6c096273c2e7efe0b764fcb;hpb=224a9916c711eb5a0fe0c2065fdb62a0cf40afaf;p=TP_AL_C.git diff --git a/lexer/main.c b/lexer/main.c index d3f086e..40550f5 100644 --- a/lexer/main.c +++ b/lexer/main.c @@ -13,31 +13,30 @@ void do_lexical_analysis() { c = fgetwc(source); // lecture du premier caractere do { scanner(); - if (tokenType == MOT || tokenType == MOTCLE) { - fwprintf(target, L"%20s: %ls\n", tokenTypestr[tokenType], token[tokenFound].value); - } else { - fwprintf(target, L"%20s\n", tokenTypestr[tokenType]); - } + wprint_token(target); token[tokenFound].type = tokenTypestr[tokenType]; tokenFound++; } while (tokenType != FIN); // tant que la fin du fichier n'est pas atteinte } void do_syntactic_analysis() { + fputws(L"\n\n", + target); c = fgetwc(source); // lecture du premier caractere - do { - analyze_AXIOME(); - } while (tokenType != FIN); + scanner(); + analyze_AXIOME(); + fputws(L"\n", target); } void print_usage(const char* name) { fprintf(stdout,"Usage: %s [options]\n" "Where [options] are:\n" - " -h, --help: display this help text\n" + " -h, --help: display this help message\n" " -l, --lexical-only: do only the lexical analysis\n" " -i, --input: use as input file instead of standard input\n" " -o, --output: use as output file instead of standard output\n", name); + fflush(stdout); } int main(int argc, char **argv) { @@ -86,13 +85,15 @@ int main(int argc, char **argv) { case ':': /* missing option argument */ pr_error("%s: option '-%c' requires an argument\n", - argv[0], optopt); + argv[0], optopt); break; case '?': default: /* invalid option */ pr_error("%s: option '-%c' is invalid: ignored\n", - argv[0], optopt); + argv[0], optopt); + /* print the help message for invalid options */ + hflag = 1; break; } } @@ -122,7 +123,7 @@ int main(int argc, char **argv) { if (hflag) { print_usage(argv[0]); - } else if (lflag){ + } else if (lflag) { do_lexical_analysis(); } else { do_syntactic_analysis();