X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=lexer%2Fsyntactic_analyzer.c;h=b9787df6976e51eccc1a8d9a1dd7baae08e43e8c;hb=dfbc1df9a95408687918ecc2bc6774d4646dd4f9;hp=ddef90b12707dc5f09009e2d62f182a46899cd0c;hpb=8aa14fa6392221f27472350490ebd334738f8ac2;p=TP_AL_C.git
diff --git a/lexer/syntactic_analyzer.c b/lexer/syntactic_analyzer.c
index ddef90b..b9787df 100644
--- a/lexer/syntactic_analyzer.c
+++ b/lexer/syntactic_analyzer.c
@@ -1,14 +1,13 @@
/* Syntactic analyzer */
#include
-#include
#include
#include "global_vars.h"
#include "lexical_analyzer.h"
#include "print_helper.h"
-#define PRINT_TOKEN 0
+#define PRINT_TOKEN 1
/* Syntactic analyzer functions implementation */
@@ -19,16 +18,14 @@ static void analyze_TEXT() {
fprintf(stdout, "entering %s\n", __func__);
#endif
if (tokenType == MOT) {
- scanner();
+ #if PRINT_TOKEN
+ wprint_ctoken(stdout);
+ #endif
if (target != NULL) {
- fputws((const wchar_t*)token[tokenFound].value, target);
+ fputws((const wchar_t*)tokenValue, target);
fputws(L" ", target);
}
- #if PRINT_TOKEN
- wprint_token(stdout);
- #endif
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
+ scanner();
analyze_TEXT();
} else if (tokenType != MOTCLE && tokenType != NPARA && tokenType != SECTION && \
tokenType != SSECTION && tokenType != FIN) {
@@ -46,39 +43,23 @@ static void analyze_P() {
fprintf(stdout, "entering %s\n", __func__);
#endif
if (tokenType == NPARA) {
- scanner();
#if PRINT_TOKEN
- wprint_token(stdout);
- #endif
+ wprint_ctoken(stdout);
+ #endif /* PRINT_TOKEN */
if (target != NULL) {
fputws(L"\n", target);
- fputws((const wchar_t*)token[tokenFound].value, target);
- fputws(L" ", target);
}
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
- if (tokenType == MOT) {
- scanner();
- #if PRINT_TOKEN
- wprint_token(stdout);
- #endif
- if (target != NULL) {
- fputws((const wchar_t*)token[tokenFound].value, target);
- fputws(L" ", target);
- }
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
- analyze_TEXT();
- if (target != NULL) {
- fputws(L"\n
\n", target);
- }
- analyze_P();
+ scanner();
+ analyze_TEXT();
+ if (target != NULL) {
+ fputws(L"\n
\n", target);
+ }
+ analyze_P();
} else if (tokenType != SECTION && tokenType != SSECTION && tokenType != FIN) {
fprintf(stderr, "%s follows error on %s\n", __func__, tokenTypestr[tokenType]);
fflush(stderr);
exit(EXIT_FAILURE);
}
- }
#if DEBUG
fprintf(stdout, "leaving %s\n", __func__);
#endif
@@ -88,32 +69,24 @@ static void analyze_HEAD() {
#if DEBUG
fprintf(stdout, "entering %s\n", __func__);
#endif
- if (tokenType == MOTCLE) {
- scanner();
- #if PRINT_TOKEN
- wprint_token(stdout);
- #endif /* PRINT_TOKEN */
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
- //FIXME: Check if the MOTCLE token value is set to >Titre
+ if (tokenType == MOTCLE && wcscmp(L">Titre", (const wchar_t*)tokenValue) == 0) {
if (target != NULL) {
fputws(L"\n", target);
- fputws((const wchar_t*)token[tokenFound].value, target);
fputws(L" ", target);
}
+ scanner();
analyze_TEXT();
if (target != NULL) {
fputws(L"\n\n", target);
}
- if (tokenType == MOTCLE) {
- scanner();
+ if (tokenType == MOTCLE && wcscmp(L">Auteur", (const wchar_t*)tokenValue) == 0) {
#if PRINT_TOKEN
- wprint_token(stdout);
+ wprint_ctoken(stdout);
#endif /* PRINT_TOKEN */
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
- //The text contain the author
+ fputws(L"", target);
} else if (tokenType != NPARA && tokenType != SECTION && tokenType != FIN) {
fprintf(stderr, "%s follows error on %s\n", __func__, tokenTypestr[tokenType]);
fflush(stderr);
@@ -130,21 +103,21 @@ static void analyze_H1() {
fprintf(stdout, "entering %s\n", __func__);
#endif
if (tokenType == SECTION) {
- scanner();
#if PRINT_TOKEN
- wprint_token(stdout);
+ wprint_ctoken(stdout);
#endif /* PRINT_TOKEN */
if (target != NULL) {
fputws(L"\n", target);
- fputws((const wchar_t*)token[tokenFound].value, target);
- fputws(L" ", target);
}
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
+ scanner();
analyze_TEXT();
if (target != NULL) {
fputws(L"\n
\n", target);
}
+ } else {
+ fprintf(stderr, "%s error\n", __func__);
+ fflush(stderr);
+ exit(EXIT_FAILURE);
}
#if DEBUG
fprintf(stdout, "leaving %s\n", __func__);
@@ -156,17 +129,13 @@ static void analyze_H2() {
fprintf(stdout, "entering %s\n", __func__);
#endif
if (tokenType == SSECTION) {
- scanner();
#if PRINT_TOKEN
- wprint_token(stdout);
+ wprint_ctoken(stdout);
#endif /* PRINT_TOKEN */
if (target != NULL) {
fputws(L"\n", target);
- fputws((const wchar_t*)token[tokenFound].value, target);
- fputws(L" ", target);
}
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
+ scanner();
analyze_TEXT();
if (target != NULL) {
fputws(L"\n
\n", target);
@@ -181,7 +150,6 @@ static void analyze_S2() {
#if DEBUG
fprintf(stdout, "entering %s\n", __func__);
#endif
- //FIXME: This test is probably useless
if (tokenType == SSECTION) {
analyze_H2();
analyze_P();
@@ -200,7 +168,6 @@ static void analyze_S1() {
#if DEBUG
fprintf(stdout, "entering %s\n", __func__);
#endif
- //FIXME: This test is probably useless
if (tokenType == SECTION) {
analyze_H1();
analyze_P();
@@ -231,13 +198,10 @@ void analyze_AXIOME() {
#if DEBUG
fprintf(stdout, "entering %s\n", __func__);
#endif
- scanner();
/* print the lexical analysis result */
#if PRINT_TOKEN
- wprint_token(stdout);
+ wprint_ctoken(stdout);
#endif /* PRINT_TOKEN */
- token[tokenFound].type = tokenTypestr[tokenType];
- tokenFound++;
if (target != NULL) {
fputws(L"\n", target);
}
@@ -252,6 +216,9 @@ void analyze_AXIOME() {
if (target != NULL) {
fputws(L"\n\n", target);
}
+ #if PRINT_TOKEN
+ wprint_ctoken(stdout);
+ #endif /* PRINT_TOKEN */
if (tokenType != FIN) {
fprintf(stderr, "%s follows error on %s\n", __func__, tokenTypestr[tokenType]);
fflush(stderr);