Diff for /rpl/src/instructions_e2.c between versions 1.12 and 1.76

version 1.12, 2010/07/14 14:19:36 version 1.76, 2020/01/10 11:15:45
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.18    RPL/2 (R) version 4.1.32
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2020 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 20 Line 20
 */  */
   
   
 #include "rpl.conv.h"  #include "rpl-conv.h"
   
   
 /*  /*
Line 623  instruction_errm(struct_processus *s_eta Line 623  instruction_errm(struct_processus *s_eta
 {  {
     struct_objet            *s_objet_resultat;      struct_objet            *s_objet_resultat;
   
     unsigned int            registre_erreur_execution;      int                     registre_erreur_execution;
     unsigned int            registre_erreur_systeme;      int                     registre_erreur_systeme;
     unsigned int            registre_exception;      int                     registre_exception;
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
   
Line 721  void Line 721  void
 instruction_edit(struct_processus *s_etat_processus)  instruction_edit(struct_processus *s_etat_processus)
 {  {
 #   ifdef VIM_SUPPORT  #   ifdef VIM_SUPPORT
 #   include "vim.conv.h"  #   include "vim-conv.h"
   
     file                    *fichier;      file                    *fichier;
   
Line 1018  instruction_externals(struct_processus * Line 1018  instruction_externals(struct_processus *
 {  {
     logical1                ambiguite;      logical1                ambiguite;
   
     unsigned long           i;      integer8                i;
   
     struct_liste_chainee    *l_element_courant;      struct_liste_chainee    *l_element_courant;
   
Line 1132  instruction_externals(struct_processus * Line 1132  instruction_externals(struct_processus *
   
             strcpy((unsigned char *) (*(*l_element_courant).donnee).objet,              strcpy((unsigned char *) (*(*l_element_courant).donnee).objet,
                     (*s_etat_processus).s_instructions_externes[i].nom);                      (*s_etat_processus).s_instructions_externes[i].nom);
   
               if ((*s_etat_processus).s_instructions_externes[i].position_fleche
                       >= 0)
               {
                   memcpy((unsigned char *) (*(*l_element_courant).donnee).objet
                           + (*s_etat_processus).s_instructions_externes[i]
                           .position_fleche - (strlen((*s_etat_processus)
                           .s_instructions_externes[i].nom_bibliotheque) + 1),
                           "->", 2);
               }
         }          }
         else          else
         {          {
Line 1148  instruction_externals(struct_processus * Line 1158  instruction_externals(struct_processus *
                     "%s$%s", (*s_etat_processus).s_instructions_externes[i]                      "%s$%s", (*s_etat_processus).s_instructions_externes[i]
                     .nom_bibliotheque, (*s_etat_processus)                      .nom_bibliotheque, (*s_etat_processus)
                     .s_instructions_externes[i].nom);                      .s_instructions_externes[i].nom);
   
               if ((*s_etat_processus).s_instructions_externes[i].position_fleche
                       >= 0)
               {
                   memcpy((unsigned char *) (*(*l_element_courant).donnee).objet
                           + (*s_etat_processus).s_instructions_externes[i]
                           .position_fleche, "->", 2);
               }
         }          }
     }      }
   
Line 1187  instruction_exit(struct_processus *s_eta Line 1205  instruction_exit(struct_processus *s_eta
     unsigned char                   *instruction_majuscule;      unsigned char                   *instruction_majuscule;
     unsigned char                   *tampon;      unsigned char                   *tampon;
   
     unsigned long                   niveau;      integer8                        niveau;
   
     void                            (*fonction)();      void                            (*fonction)();
   
Line 1214  instruction_exit(struct_processus *s_eta Line 1232  instruction_exit(struct_processus *s_eta
         printf("        (expression 2)\n");          printf("        (expression 2)\n");
         printf("    NEXT/STEP\n\n");          printf("    NEXT/STEP\n\n");
   
           printf("    FORALL\n");
           printf("        (expression 1)\n");
           printf("        EXIT\n");
           printf("        (expression 2)\n");
           printf("    NEXT\n\n");
   
         printf("    DO\n");          printf("    DO\n");
         printf("        (expression 1)\n");          printf("        (expression 1)\n");
         printf("        EXIT\n");          printf("        EXIT\n");
Line 1253  instruction_exit(struct_processus *s_eta Line 1277  instruction_exit(struct_processus *s_eta
     while((l_element_pile_systeme != NULL) && (presence_boucle == d_faux))      while((l_element_pile_systeme != NULL) && (presence_boucle == d_faux))
     {      {
         if (((*l_element_pile_systeme).type_cloture == 'S') ||          if (((*l_element_pile_systeme).type_cloture == 'S') ||
                 ((*l_element_pile_systeme).type_cloture == 'F'))                  ((*l_element_pile_systeme).type_cloture == 'F') ||
                   ((*l_element_pile_systeme).type_cloture == 'A'))
         {          {
             presence_boucle = d_vrai;              presence_boucle = d_vrai;
             drapeau_boucle_definie = d_vrai;              drapeau_boucle_definie = d_vrai;
Line 1280  instruction_exit(struct_processus *s_eta Line 1305  instruction_exit(struct_processus *s_eta
         tampon = (*s_etat_processus).instruction_courante;          tampon = (*s_etat_processus).instruction_courante;
         niveau = 1;          niveau = 1;
   
         instruction_majuscule = conversion_majuscule("");          instruction_majuscule = conversion_majuscule(s_etat_processus, "");
   
         if (drapeau_boucle_definie == d_vrai)          if (drapeau_boucle_definie == d_vrai)
         {          {
Line 1297  instruction_exit(struct_processus *s_eta Line 1322  instruction_exit(struct_processus *s_eta
                     return;                      return;
                 }                  }
   
                 if (recherche_variable(s_etat_processus,                  (*s_etat_processus).erreur_systeme = d_es;
                         (*s_etat_processus).instruction_courante) == d_vrai)                  instruction_majuscule = conversion_majuscule(s_etat_processus,
                           (*s_etat_processus).instruction_courante);
   
                   if (instruction_majuscule == NULL)
                 {                  {
                     instruction_majuscule = conversion_majuscule("");                      return;
                   }
   
                     if ((*s_etat_processus).s_liste_variables                  /*
                             [(*s_etat_processus).position_variable_courante]                   * Traitement de la pile système par les
                             .objet == NULL)                   * différentes instructions.
                    */
   
                   if ((strcmp(instruction_majuscule, "IF") == 0) ||
                           (strcmp(instruction_majuscule, "IFERR") == 0) ||
                           (strcmp(instruction_majuscule, "DO") == 0) ||
                           (strcmp(instruction_majuscule, "WHILE") == 0) ||
                           (strcmp(instruction_majuscule, "FOR") == 0) ||
                           (strcmp(instruction_majuscule, "FORALL") == 0) ||
                           (strcmp(instruction_majuscule, "START") == 0) ||
                           (strcmp(instruction_majuscule, "SELECT") == 0)
                           || (strcmp(instruction_majuscule, "CRITICAL") == 0)
                           || (strcmp(instruction_majuscule, "CASE") == 0)
                           || (strcmp(instruction_majuscule, "<<") == 0))
                   {
                       if (strcmp(instruction_majuscule, "<<") == 0)
                     {                      {
                         if (pthread_mutex_lock(&((*(*s_etat_processus)                          analyse(s_etat_processus, NULL);
                                 .s_liste_variables_partagees).mutex)) != 0)  
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_processus;  
                             return;  
                         }  
   
                         if (recherche_variable_partagee(s_etat_processus,  
                                 (*s_etat_processus).s_liste_variables  
                                 [(*s_etat_processus).position_variable_courante]  
                                 .nom, (*s_etat_processus).s_liste_variables  
                                 [(*s_etat_processus).position_variable_courante]  
                                 .variable_partagee,  
                                 (*s_etat_processus).s_liste_variables  
                                 [(*s_etat_processus).position_variable_courante]  
                                 .origine) == d_vrai)  
                         {  
                             if ((*((*s_etat_processus).s_liste_variables  
                                     [(*s_etat_processus)  
                                     .position_variable_courante]).objet).type  
                                     == ADR)  
                             {  
                                 empilement_pile_systeme(s_etat_processus);  
   
                                 if ((*s_etat_processus).erreur_systeme != d_es)  
                                 {  
                                     if (pthread_mutex_unlock(  
                                             &((*(*s_etat_processus)  
                                             .s_liste_variables_partagees)  
                                             .mutex)) != 0)  
                                     {  
                                         (*s_etat_processus).erreur_systeme =  
                                                 d_es_processus;  
                                         return;  
                                     }  
   
                                     return;  
                                 }  
   
                                 (*(*s_etat_processus).l_base_pile_systeme)  
                                         .adresse_retour =  
                                         (*s_etat_processus).position_courante;  
   
                                 (*(*s_etat_processus).l_base_pile_systeme)  
                                         .retour_definition = 'Y';  
                                 (*(*s_etat_processus).l_base_pile_systeme)  
                                         .niveau_courant =  
                                         (*s_etat_processus).niveau_courant;  
   
                                 (*s_etat_processus).position_courante =  
                                         (*((unsigned long *)  
                                         ((*((*s_etat_processus)  
                                         .s_liste_variables[(*s_etat_processus)  
                                         .position_variable_courante].objet))  
                                         .objet)));  
   
                                 (*s_etat_processus)  
                                         .autorisation_empilement_programme  
                                         = 'N';  
                             }  
                         }  
                         else  
                         {  
                             (*s_etat_processus).erreur_systeme = d_es;  
                         }  
   
                         if (pthread_mutex_unlock(&((*(*s_etat_processus)  
                                 .s_liste_variables_partagees).mutex)) != 0)  
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_processus;  
                             return;  
                         }  
                     }                      }
                     else                      else
                     {                      {
                         if ((*((*s_etat_processus).s_liste_variables                          if ((strcmp(instruction_majuscule, "FOR") == 0) ||
                                 [(*s_etat_processus)                                  (strcmp(instruction_majuscule, "FORALL") == 0)
                                 .position_variable_courante]).objet).type                                  || (strcmp(instruction_majuscule, "START")
                                 == ADR)                                  == 0))
                         {                          {
                             empilement_pile_systeme(s_etat_processus);                              niveau++;
                           }
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                          empilement_pile_systeme(s_etat_processus);
                             {  
                                 return;  
                             }  
   
                             (*(*s_etat_processus).l_base_pile_systeme)                          if ((*s_etat_processus).erreur_systeme != d_es)
                                     .adresse_retour =                          {
                                     (*s_etat_processus).position_courante;                              return;
   
                             (*(*s_etat_processus).l_base_pile_systeme)  
                                     .retour_definition = 'Y';  
                             (*(*s_etat_processus).l_base_pile_systeme)  
                                     .niveau_courant =  
                                     (*s_etat_processus).niveau_courant;  
   
                             (*s_etat_processus).position_courante =  
                                     (*((unsigned long *) ((*((*s_etat_processus)  
                                     .s_liste_variables[(*s_etat_processus)  
                                     .position_variable_courante].objet))  
                                     .objet)));  
   
                             (*s_etat_processus)  
                                     .autorisation_empilement_programme  
                                     = 'N';  
                         }                          }
                     }                      }
                 }                  }
                 else                  else if ((strcmp(instruction_majuscule, "END") == 0) ||
                           (strcmp(instruction_majuscule, "NEXT") == 0) ||
                           (strcmp(instruction_majuscule, "STEP") == 0) ||
                           (strcmp(instruction_majuscule, ">>") == 0))
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es;                      if (strcmp(instruction_majuscule, ">>") == 0)
                     instruction_majuscule = conversion_majuscule(  
                             (*s_etat_processus).instruction_courante);  
   
                     if (instruction_majuscule == NULL)  
                     {                      {
                         return;                          analyse(s_etat_processus, NULL);
                     }  
   
                     /*                          if ((*s_etat_processus).retour_routine_evaluation
                      * Traitement de la pile système par les                                  == 'Y')
                      * différentes instructions.  
                      */  
   
                     if ((strcmp(instruction_majuscule, "IF") == 0) ||  
                             (strcmp(instruction_majuscule, "IFERR") == 0) ||  
                             (strcmp(instruction_majuscule, "DO") == 0) ||  
                             (strcmp(instruction_majuscule, "WHILE") == 0) ||  
                             (strcmp(instruction_majuscule, "FOR") == 0) ||  
                             (strcmp(instruction_majuscule, "START") == 0) ||  
                             (strcmp(instruction_majuscule, "SELECT") == 0)  
                             || (strcmp(instruction_majuscule, "CASE") == 0)  
                             || (strcmp(instruction_majuscule, "<<") == 0))  
                     {  
                         if (strcmp(instruction_majuscule, "<<") == 0)  
                         {  
                             analyse(s_etat_processus, NULL);  
                         }  
                         else  
                         {                          {
                             if ((strcmp(instruction_majuscule, "FOR") == 0) ||                              drapeau_presence_fin_boucle = d_faux;
                                     (strcmp(instruction_majuscule, "START")                              free((*s_etat_processus).instruction_courante);
                                     == 0))  
                             {  
                                 niveau++;  
                             }  
   
                             empilement_pile_systeme(s_etat_processus);  
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                              break;
                             {  
                                 return;  
                             }  
                         }                          }
                     }                      }
                     else if ((strcmp(instruction_majuscule, "END") == 0) ||                      else
                             (strcmp(instruction_majuscule, "NEXT") == 0) ||  
                             (strcmp(instruction_majuscule, "STEP") == 0) ||  
                             (strcmp(instruction_majuscule, ">>") == 0))  
                     {                      {
                         if (strcmp(instruction_majuscule, ">>") == 0)                          if ((strcmp(instruction_majuscule, "NEXT") == 0) ||
                                   (strcmp(instruction_majuscule, "STEP")
                                   == 0))
                         {                          {
                             analyse(s_etat_processus, NULL);                              niveau--;
   
                             if ((*s_etat_processus).retour_routine_evaluation                              if (niveau != 0)
                                     == 'Y')  
                             {                              {
                                 drapeau_presence_fin_boucle = d_faux;                                  depilement_pile_systeme(s_etat_processus);
                                 free((*s_etat_processus).instruction_courante);  
   
                                 break;  
                             }                              }
                         }                          }
                         else                          else
                         {                          {
                             if ((strcmp(instruction_majuscule, "NEXT") == 0) ||                              if ((*s_etat_processus).l_base_pile_systeme == NULL)
                                     (strcmp(instruction_majuscule, "STEP")  
                                     == 0))  
                             {                              {
                                 niveau--;                                  (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
   
                                 if (niveau != 0)                              if ((*(*s_etat_processus).l_base_pile_systeme)
                                       .type_cloture == 'Q')
                               {
                                   if (pthread_mutex_unlock(
                                           &mutex_sections_critiques) != 0)
                                 {                                  {
                                     depilement_pile_systeme(s_etat_processus);                                      (*s_etat_processus).erreur_systeme =
                                               d_es_processus;
                                       return;
                                 }                                  }
                             }  
                             else  
                             {  
                                 depilement_pile_systeme(s_etat_processus);  
                             }  
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                                  (*s_etat_processus).sections_critiques--;
                             {  
                                 return;  
                             }                              }
   
                               depilement_pile_systeme(s_etat_processus);
                           }
   
                           if ((*s_etat_processus).erreur_systeme != d_es)
                           {
                               return;
                         }                          }
                     }                      }
                 }                  }
Line 1525  instruction_exit(struct_processus *s_eta Line 1451  instruction_exit(struct_processus *s_eta
                     return;                      return;
                 }                  }
   
                 if (recherche_variable(s_etat_processus,                  instruction_majuscule = conversion_majuscule(s_etat_processus,
                         (*s_etat_processus).instruction_courante) == d_vrai)                          (*s_etat_processus).instruction_courante);
   
                   if (instruction_majuscule == NULL)
                 {                  {
                     instruction_majuscule = conversion_majuscule("");                      return;
                   }
   
                     if ((*s_etat_processus).s_liste_variables                  /*
                             [(*s_etat_processus).position_variable_courante]                   * Traitement de la pile système par les
                             .objet == NULL)                   * différentes instructions.
                    */
   
                   if ((strcmp(instruction_majuscule, "IF") == 0) ||
                           (strcmp(instruction_majuscule, "IFERR") == 0) ||
                           (strcmp(instruction_majuscule, "DO") == 0) ||
                           (strcmp(instruction_majuscule, "WHILE") == 0) ||
                           (strcmp(instruction_majuscule, "FOR") == 0) ||
                           (strcmp(instruction_majuscule, "FORALL") == 0) ||
                           (strcmp(instruction_majuscule, "START") == 0) ||
                           (strcmp(instruction_majuscule, "SELECT") == 0)
                           || (strcmp(instruction_majuscule, "CRITICAL") == 0)
                           || (strcmp(instruction_majuscule, "CASE") == 0)
                           || (strcmp(instruction_majuscule, "<<") == 0))
                   {
                       if (strcmp(instruction_majuscule, "<<") == 0)
                     {                      {
                         if (pthread_mutex_lock(&((*(*s_etat_processus)                          analyse(s_etat_processus, NULL);
                                 .s_liste_variables_partagees).mutex)) != 0)  
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_processus;  
                             return;  
                         }  
   
                         if (recherche_variable_partagee(s_etat_processus,  
                                 (*s_etat_processus).s_liste_variables  
                                 [(*s_etat_processus).position_variable_courante]  
                                 .nom, (*s_etat_processus).s_liste_variables  
                                 [(*s_etat_processus).position_variable_courante]  
                                 .variable_partagee,  
                                 (*s_etat_processus).s_liste_variables  
                                 [(*s_etat_processus).position_variable_courante]  
                                 .origine) == d_vrai)  
                         {  
                             if ((*((*s_etat_processus).s_liste_variables  
                                     [(*s_etat_processus)  
                                     .position_variable_courante]).objet).type  
                                     == ADR)  
                             {  
                                 empilement_pile_systeme(s_etat_processus);  
   
                                 if ((*s_etat_processus).erreur_systeme != d_es)  
                                 {  
                                     if (pthread_mutex_unlock(  
                                             &((*(*s_etat_processus)  
                                             .s_liste_variables_partagees)  
                                             .mutex)) != 0)  
                                     {  
                                         (*s_etat_processus).erreur_systeme =  
                                                 d_es_processus;  
                                         return;  
                                     }  
   
                                     return;  
                                 }  
   
                                 (*(*s_etat_processus).l_base_pile_systeme)  
                                         .adresse_retour =  
                                         (*s_etat_processus).position_courante;  
   
                                 (*(*s_etat_processus).l_base_pile_systeme)  
                                         .retour_definition = 'Y';  
                                 (*(*s_etat_processus).l_base_pile_systeme)  
                                         .niveau_courant =  
                                         (*s_etat_processus).niveau_courant;  
   
                                 (*s_etat_processus).position_courante =  
                                         (*((unsigned long *)  
                                         ((*((*s_etat_processus)  
                                         .s_liste_variables[(*s_etat_processus)  
                                         .position_variable_courante].objet))  
                                         .objet)));  
   
                                 (*s_etat_processus)  
                                         .autorisation_empilement_programme  
                                         = 'N';  
                             }  
                         }  
                         else  
                         {  
                             (*s_etat_processus).erreur_systeme = d_es;  
                         }  
   
                         if (pthread_mutex_unlock(&((*(*s_etat_processus)  
                                 .s_liste_variables_partagees).mutex)) != 0)  
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_processus;  
                             return;  
                         }  
                     }                      }
                     else                      else
                     {                      {
                         if ((*((*s_etat_processus).s_liste_variables                          if ((strcmp(instruction_majuscule, "DO") == 0) ||
                                 [(*s_etat_processus)                                  (strcmp(instruction_majuscule, "WHILE")
                                 .position_variable_courante]).objet).type                                  == 0))
                                 == ADR)  
                         {                          {
                             empilement_pile_systeme(s_etat_processus);                              niveau++;
                           }
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                          empilement_pile_systeme(s_etat_processus);
                             {  
                                 return;  
                             }  
   
                             (*(*s_etat_processus).l_base_pile_systeme)                          if ((*s_etat_processus).erreur_systeme != d_es)
                                     .adresse_retour =                          {
                                     (*s_etat_processus).position_courante;                              return;
   
                             (*(*s_etat_processus).l_base_pile_systeme)  
                                     .retour_definition = 'Y';  
                             (*(*s_etat_processus).l_base_pile_systeme)  
                                     .niveau_courant =  
                                     (*s_etat_processus).niveau_courant;  
   
                             (*s_etat_processus).position_courante =  
                                     (*((unsigned long *) ((*((*s_etat_processus)  
                                     .s_liste_variables[(*s_etat_processus)  
                                     .position_variable_courante].objet))  
                                     .objet)));  
   
                             (*s_etat_processus)  
                                     .autorisation_empilement_programme  
                                     = 'N';  
                         }                          }
                     }                      }
                 }                  }
                 else                  else if ((strcmp(instruction_majuscule, "END") == 0) ||
                           (strcmp(instruction_majuscule, "NEXT") == 0) ||
                           (strcmp(instruction_majuscule, "STEP") == 0) ||
                           (strcmp(instruction_majuscule, ">>") == 0))
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es;                      if (strcmp(instruction_majuscule, ">>") == 0)
                     instruction_majuscule = conversion_majuscule(  
                             (*s_etat_processus).instruction_courante);  
   
                     if (instruction_majuscule == NULL)  
                     {                      {
                         return;                          analyse(s_etat_processus, NULL);
                     }  
   
                     /*                          if ((*s_etat_processus).retour_routine_evaluation
                      * Traitement de la pile système par les                                  == 'Y')
                      * différentes instructions.  
                      */  
   
                     if ((strcmp(instruction_majuscule, "IF") == 0) ||  
                             (strcmp(instruction_majuscule, "IFERR") == 0) ||  
                             (strcmp(instruction_majuscule, "DO") == 0) ||  
                             (strcmp(instruction_majuscule, "WHILE") == 0) ||  
                             (strcmp(instruction_majuscule, "FOR") == 0) ||  
                             (strcmp(instruction_majuscule, "START") == 0) ||  
                             (strcmp(instruction_majuscule, "SELECT") == 0)  
                             || (strcmp(instruction_majuscule, "CASE") == 0)  
                             || (strcmp(instruction_majuscule, "<<") == 0))  
                     {  
                         if (strcmp(instruction_majuscule, "<<") == 0)  
                         {                          {
                             analyse(s_etat_processus, NULL);                              drapeau_presence_fin_boucle = d_faux;
                         }                              free((*s_etat_processus).instruction_courante);
                         else  
                         {  
                             if ((strcmp(instruction_majuscule, "DO") == 0) ||  
                                     (strcmp(instruction_majuscule, "WHILE")  
                                     == 0))  
                             {  
                                 niveau++;  
                             }  
   
                             empilement_pile_systeme(s_etat_processus);  
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                              break;
                             {  
                                 return;  
                             }  
                         }                          }
                     }                      }
                     else if ((strcmp(instruction_majuscule, "END") == 0) ||                      else
                             (strcmp(instruction_majuscule, "NEXT") == 0) ||  
                             (strcmp(instruction_majuscule, "STEP") == 0) ||  
                             (strcmp(instruction_majuscule, ">>") == 0))  
                     {                      {
                         if (strcmp(instruction_majuscule, ">>") == 0)                          if (strcmp(instruction_majuscule, "END") == 0)
                         {                          {
                             analyse(s_etat_processus, NULL);                              if (((*(*s_etat_processus).l_base_pile_systeme)
                                       .type_cloture == 'D') ||
                             if ((*s_etat_processus).retour_routine_evaluation                                      ((*(*s_etat_processus)
                                     == 'Y')                                      .l_base_pile_systeme).type_cloture
                                       == 'W'))
                             {                              {
                                 drapeau_presence_fin_boucle = d_faux;                                  niveau--;
                                 free((*s_etat_processus).instruction_courante);  
   
                                 break;  
                             }                              }
   
                               depilement_pile_systeme(s_etat_processus);
                         }                          }
                         else                          else
                         {                          {
                             if (strcmp(instruction_majuscule, "END") == 0)                              if ((*s_etat_processus).l_base_pile_systeme == NULL)
                             {                              {
                                 if (((*(*s_etat_processus).l_base_pile_systeme)                                  (*s_etat_processus).erreur_systeme =
                                         .type_cloture == 'D') ||                                          d_es_processus;
                                         ((*(*s_etat_processus)                                  return;
                                         .l_base_pile_systeme).type_cloture                              }
                                         == 'W'))  
                               if ((*(*s_etat_processus).l_base_pile_systeme)
                                       .type_cloture == 'Q')
                               {
                                   if (pthread_mutex_unlock(
                                           &mutex_sections_critiques) != 0)
                                 {                                  {
                                     niveau--;                                      (*s_etat_processus).erreur_systeme =
                                               d_es_processus;
                                       return;
                                 }                                  }
   
                                 depilement_pile_systeme(s_etat_processus);                                  (*s_etat_processus).sections_critiques--;
                             }  
                             else  
                             {  
                                 depilement_pile_systeme(s_etat_processus);  
                             }                              }
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                              depilement_pile_systeme(s_etat_processus);
                             {                          }
                                 return;  
                             }                          if ((*s_etat_processus).erreur_systeme != d_es)
                           {
                               return;
                         }                          }
                     }                      }
                 }                  }
Line 1788  instruction_exit(struct_processus *s_eta Line 1613  instruction_exit(struct_processus *s_eta
                         (fonction == instruction_do) ||                          (fonction == instruction_do) ||
                         (fonction == instruction_while) ||                          (fonction == instruction_while) ||
                         (fonction == instruction_for) ||                          (fonction == instruction_for) ||
                           (fonction == instruction_forall) ||
                         (fonction == instruction_start) ||                          (fonction == instruction_start) ||
                         (fonction == instruction_select) ||                          (fonction == instruction_select) ||
                         (fonction == instruction_case) ||                          (fonction == instruction_case) ||
                           (fonction == instruction_critical) ||
                         (fonction == instruction_vers_niveau_superieur))                          (fonction == instruction_vers_niveau_superieur))
                 {                  {
                     if (fonction == instruction_vers_niveau_superieur)                      if (fonction == instruction_vers_niveau_superieur)
Line 1801  instruction_exit(struct_processus *s_eta Line 1628  instruction_exit(struct_processus *s_eta
                     else                      else
                     {                      {
                         if ((fonction == instruction_for) ||                          if ((fonction == instruction_for) ||
                                   (fonction == instruction_forall) ||
                                 (fonction == instruction_start))                                  (fonction == instruction_start))
                         {                          {
                             niveau++;                              niveau++;
Line 1849  instruction_exit(struct_processus *s_eta Line 1677  instruction_exit(struct_processus *s_eta
                         }                          }
                         else                          else
                         {                          {
                               if ((*s_etat_processus).l_base_pile_systeme == NULL)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
   
                               if ((*(*s_etat_processus).l_base_pile_systeme)
                                       .type_cloture == 'Q')
                               {
                                   if (pthread_mutex_unlock(
                                           &mutex_sections_critiques) != 0)
                                   {
                                       (*s_etat_processus).erreur_systeme =
                                               d_es_processus;
                                       return;
                                   }
   
                                   (*s_etat_processus).sections_critiques--;
                               }
   
                             depilement_pile_systeme(s_etat_processus);                              depilement_pile_systeme(s_etat_processus);
                         }                          }
   
Line 1889  instruction_exit(struct_processus *s_eta Line 1738  instruction_exit(struct_processus *s_eta
                         (fonction == instruction_do) ||                          (fonction == instruction_do) ||
                         (fonction == instruction_while) ||                          (fonction == instruction_while) ||
                         (fonction == instruction_for) ||                          (fonction == instruction_for) ||
                           (fonction == instruction_forall) ||
                         (fonction == instruction_start) ||                          (fonction == instruction_start) ||
                         (fonction == instruction_select) ||                          (fonction == instruction_select) ||
                           (fonction == instruction_critical) ||
                         (fonction == instruction_case) ||                          (fonction == instruction_case) ||
                         (fonction == instruction_vers_niveau_superieur))                          (fonction == instruction_vers_niveau_superieur))
                 {                  {
Line 1947  instruction_exit(struct_processus *s_eta Line 1798  instruction_exit(struct_processus *s_eta
                         }                          }
                         else                          else
                         {                          {
                               if ((*s_etat_processus).l_base_pile_systeme == NULL)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
   
                               if ((*(*s_etat_processus).l_base_pile_systeme)
                                       .type_cloture == 'Q')
                               {
                                   if (pthread_mutex_unlock(
                                           &mutex_sections_critiques) != 0)
                                   {
                                       (*s_etat_processus).erreur_systeme =
                                               d_es_processus;
                                       return;
                                   }
   
                                   (*s_etat_processus).sections_critiques--;
                               }
   
                             depilement_pile_systeme(s_etat_processus);                              depilement_pile_systeme(s_etat_processus);
                         }                          }
   
Line 1975  instruction_exit(struct_processus *s_eta Line 1847  instruction_exit(struct_processus *s_eta
     if ((drapeau_boucle_definie == d_vrai) &&      if ((drapeau_boucle_definie == d_vrai) &&
             (drapeau_presence_fin_boucle == d_vrai))              (drapeau_presence_fin_boucle == d_vrai))
     {      {
         presence_compteur = ((*(*s_etat_processus).l_base_pile_systeme)          presence_compteur = (((*(*s_etat_processus).l_base_pile_systeme)
                 .type_cloture == 'F') ? d_vrai : d_faux;                  .type_cloture == 'F') || ((*(*s_etat_processus)
                   .l_base_pile_systeme).type_cloture == 'A')) ? d_vrai : d_faux;
   
         if (((*(*s_etat_processus).l_base_pile_systeme).type_cloture != 'S')          if (((*(*s_etat_processus).l_base_pile_systeme).type_cloture != 'S')
                 && (presence_compteur == d_faux))                  && (presence_compteur == d_faux))
Line 1998  instruction_exit(struct_processus *s_eta Line 1871  instruction_exit(struct_processus *s_eta
             (*(*s_etat_processus).l_base_pile_systeme).indice_boucle = NULL;              (*(*s_etat_processus).l_base_pile_systeme).indice_boucle = NULL;
             (*s_etat_processus).niveau_courant--;              (*s_etat_processus).niveau_courant--;
   
             if (retrait_variable_par_niveau(s_etat_processus) == d_erreur)              if (retrait_variables_par_niveau(s_etat_processus) == d_erreur)
             {              {
                 return;                  return;
             }              }

Removed from v.1.12  
changed lines
  Added in v.1.76


CVSweb interface <joel.bertrand@systella.fr>