--- rpl/src/instructions_e2.c 2020/01/10 11:15:45 1.76 +++ rpl/src/instructions_e2.c 2021/03/11 22:03:47 1.77 @@ -1283,7 +1283,7 @@ instruction_exit(struct_processus *s_eta presence_boucle = d_vrai; drapeau_boucle_definie = d_vrai; } - else if (((*l_element_pile_systeme).type_cloture == 'D') || + else if (((*l_element_pile_systeme).type_cloture == 'D') || ((*l_element_pile_systeme).type_cloture == 'W')) { presence_boucle = d_vrai; @@ -1301,6 +1301,7 @@ instruction_exit(struct_processus *s_eta if ((*s_etat_processus).mode_execution_programme == 'Y') { +uprintf("PROG\n"); drapeau_presence_fin_boucle = d_vrai; tampon = (*s_etat_processus).instruction_courante; niveau = 1; @@ -1325,6 +1326,7 @@ instruction_exit(struct_processus *s_eta (*s_etat_processus).erreur_systeme = d_es; instruction_majuscule = conversion_majuscule(s_etat_processus, (*s_etat_processus).instruction_courante); +uprintf("%s\n", instruction_majuscule); if (instruction_majuscule == NULL) { @@ -1482,14 +1484,20 @@ instruction_exit(struct_processus *s_eta } else { - if ((strcmp(instruction_majuscule, "DO") == 0) || - (strcmp(instruction_majuscule, "WHILE") - == 0)) + empilement_pile_systeme(s_etat_processus); + + if (strcmp(instruction_majuscule, "DO") == 0) { + (*(*s_etat_processus).l_base_pile_systeme) + .type_cloture = 'D'; + niveau++; + } + else if (strcmp(instruction_majuscule, "WHILE") == 0) + { + (*(*s_etat_processus).l_base_pile_systeme) + .type_cloture = 'W'; niveau++; } - - empilement_pile_systeme(s_etat_processus); if ((*s_etat_processus).erreur_systeme != d_es) { @@ -1752,13 +1760,20 @@ instruction_exit(struct_processus *s_eta } else { - if ((fonction == instruction_do) || - (fonction == instruction_while)) + empilement_pile_systeme(s_etat_processus); + + if (fonction == instruction_while) { + (*(*s_etat_processus).l_base_pile_systeme) + .type_cloture = 'W'; + niveau++; + } + else if (fonction == instruction_do) + { + (*(*s_etat_processus).l_base_pile_systeme) + .type_cloture = 'D'; niveau++; } - - empilement_pile_systeme(s_etat_processus); if ((*s_etat_processus).erreur_systeme != d_es) {