X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=lexer%2Fmain.c;h=d1efb4b6743e5deb766207a327c429c9d4100b5f;hb=81b7738ff0f2949955e8277a9710e64ff7ef00b4;hp=9d49b77cb73e5d83f3f52a38b0b80e1d6dcf948b;hpb=f491c07a7575046b53f731639d01edd1f140a947;p=TP_AL_C.git diff --git a/lexer/main.c b/lexer/main.c index 9d49b77..d1efb4b 100644 --- a/lexer/main.c +++ b/lexer/main.c @@ -5,32 +5,30 @@ #include #include "global_vars.h" +#include "print_helper.h" #include "lexical_analyzer.h" #include "syntactic_analyzer.h" -#include "print_helper.h" -void do_lexical_analysis() { +static 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() { +static 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) { +static void print_usage(const char* name) { fprintf(stdout,"Usage: %s [options]\n" "Where [options] are:\n" " -h, --help: display this help message\n" @@ -38,6 +36,7 @@ void print_usage(const char* name) { " -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();