Diff for /rpl/src/optimisation.c between versions 1.49 and 1.75

version 1.49, 2013/03/21 11:30:31 version 1.75, 2017/07/10 14:47:59
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.13    RPL/2 (R) version 4.1.27
   Copyright (C) 1989-2013 Dr. BERTRAND Joël    Copyright (C) 1989-2017 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 36 Line 36
 */  */
   
 logical1  logical1
 sequenceur_optimise(struct_processus *s_etat_processus)  sequenceur_optimise(struct_processus *s_etat_processus, struct_liste_chainee
           *l_bibliotheques)
 {  {
     integer8                    adresse_point_entree;      integer8                    adresse_point_entree;
     integer8                    i;      integer8                    i;
       integer8                    j;
     integer8                    nb_variables;      integer8                    nb_variables;
     integer8                    point_entree;      integer8                    point_entree;
   
     logical1                    erreur;      logical1                    erreur;
   
       struct_liste_chainee        *l_bibliotheque_courante;
       struct_liste_chainee        *l_nouvelle_bibliotheque;
   
     struct_objet                *programme_principal;      struct_objet                *programme_principal;
   
     struct_tableau_variables    *tableau;      struct_tableau_variables    *tableau;
Line 97  sequenceur_optimise(struct_processus *s_ Line 102  sequenceur_optimise(struct_processus *s_
         return(d_erreur);          return(d_erreur);
     }      }
   
     liste_variables(s_etat_processus, tableau);      nb_variables = liste_variables(s_etat_processus, tableau);
   
     for(i = 0; i < nb_variables; i++)      for(i = 0; i < nb_variables; i++)
     {      {
Line 136  sequenceur_optimise(struct_processus *s_ Line 141  sequenceur_optimise(struct_processus *s_
                     printf("+++Fatal : Compilation failed\n");                      printf("+++Fatal : Compilation failed\n");
                 }                  }
   
                   for(j = 0; j < nb_variables; j++)
                   {
                       if (tableau[j].mutex != NULL)
                       {
                           pthread_mutex_unlock(tableau[j].mutex);
                       }
                   }
   
                 free(tableau);                  free(tableau);
                 return(d_erreur);                  return(d_erreur);
             }              }
Line 147  sequenceur_optimise(struct_processus *s_ Line 160  sequenceur_optimise(struct_processus *s_
   
             registre = (*s_etat_processus).autorisation_nom_implicite;              registre = (*s_etat_processus).autorisation_nom_implicite;
             (*s_etat_processus).autorisation_nom_implicite = 'Y';              (*s_etat_processus).autorisation_nom_implicite = 'Y';
               (*s_etat_processus).type_en_cours = NON;
             recherche_type(s_etat_processus);              recherche_type(s_etat_processus);
             (*s_etat_processus).autorisation_nom_implicite = registre;              (*s_etat_processus).autorisation_nom_implicite = registre;
   
Line 194  sequenceur_optimise(struct_processus *s_ Line 208  sequenceur_optimise(struct_processus *s_
                     printf("+++Fatal : Compilation failed\n");                      printf("+++Fatal : Compilation failed\n");
                 }                  }
   
                   for(j = 0; j < nb_variables; j++)
                   {
                       if (tableau[j].mutex != NULL)
                       {
                           pthread_mutex_unlock(tableau[j].mutex);
                       }
                   }
   
                 free(tableau);                  free(tableau);
                 return(d_erreur);                  return(d_erreur);
             }              }
Line 213  sequenceur_optimise(struct_processus *s_ Line 235  sequenceur_optimise(struct_processus *s_
                     printf("+++Fatal : Compilation failed\n");                      printf("+++Fatal : Compilation failed\n");
                 }                  }
   
                   for(j = 0; j < nb_variables; j++)
                   {
                       if (tableau[j].mutex != NULL)
                       {
                           pthread_mutex_unlock(tableau[j].mutex);
                       }
                   }
   
                 free(tableau);                  free(tableau);
                 return(d_erreur);                  return(d_erreur);
             }              }
Line 232  sequenceur_optimise(struct_processus *s_ Line 262  sequenceur_optimise(struct_processus *s_
                     printf("+++Fatal : Compilation failed\n");                      printf("+++Fatal : Compilation failed\n");
                 }                  }
   
                   for(j = 0; j < nb_variables; j++)
                   {
                       if (tableau[j].mutex != NULL)
                       {
                           pthread_mutex_unlock(tableau[j].mutex);
                       }
                   }
   
                 free(tableau);                  free(tableau);
                 return(d_erreur);                  return(d_erreur);
             }              }
Line 258  sequenceur_optimise(struct_processus *s_ Line 296  sequenceur_optimise(struct_processus *s_
             printf("+++Fatal : Compilation failed\n");              printf("+++Fatal : Compilation failed\n");
         }          }
   
           for(j = 0; j < nb_variables; j++)
           {
               if (tableau[j].mutex != NULL)
               {
                   pthread_mutex_unlock(tableau[j].mutex);
               }
           }
   
         free(tableau);          free(tableau);
         return(d_erreur);          return(d_erreur);
     }      }
Line 299  sequenceur_optimise(struct_processus *s_ Line 345  sequenceur_optimise(struct_processus *s_
             printf("+++Fatal : Compilation failed\n");              printf("+++Fatal : Compilation failed\n");
         }          }
   
           for(j = 0; j < nb_variables; j++)
           {
               if (tableau[j].mutex != NULL)
               {
                   pthread_mutex_unlock(tableau[j].mutex);
               }
           }
   
         free(tableau);          free(tableau);
         return(d_erreur);          return(d_erreur);
     }      }
Line 323  sequenceur_optimise(struct_processus *s_ Line 377  sequenceur_optimise(struct_processus *s_
             printf("+++System : Not enough memory\n");              printf("+++System : Not enough memory\n");
         }          }
   
           for(j = 0; j < nb_variables; j++)
           {
               if (tableau[j].mutex != NULL)
               {
                   pthread_mutex_unlock(tableau[j].mutex);
               }
           }
   
         free(tableau);          free(tableau);
         return(d_erreur);          return(d_erreur);
     }      }
   
       for(j = 0; j < nb_variables; j++)
       {
           if (tableau[j].mutex != NULL)
           {
               pthread_mutex_unlock(tableau[j].mutex);
           }
       }
   
     free(tableau);      free(tableau);
   
   
       // Libération des bibliothèques
   
       l_bibliotheque_courante = l_bibliotheques;
   
       while(l_bibliotheque_courante != NULL)
       {
           if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                   (*l_bibliotheque_courante).donnee) == d_erreur)
           {
               if ((*s_etat_processus).langue == 'F')
               {
                   printf("+++Système : Mémoire insuffisante\n");
               }
               else
               {
                   printf("+++System : Not enough memory\n");
               }
   
               return(d_erreur);
           }
   
           affichage_rplso = d_faux;
           instruction_remove(s_etat_processus);
           affichage_rplso = d_vrai;
   
           l_nouvelle_bibliotheque =
                   (*l_bibliotheque_courante).suivant;
           free(l_bibliotheque_courante);
           l_bibliotheque_courante =
                   l_nouvelle_bibliotheque;
       }
   
     erreur = evaluation(s_etat_processus, programme_principal, 'E');      erreur = evaluation(s_etat_processus, programme_principal, 'E');
   
     if ((*s_etat_processus).profilage == d_vrai)      if ((*s_etat_processus).profilage == d_vrai)

Removed from v.1.49  
changed lines
  Added in v.1.75


CVSweb interface <joel.bertrand@systella.fr>