Diff for /rpl/src/sequenceur.c between versions 1.14 and 1.41

version 1.14, 2010/04/21 13:45:51 version 1.41, 2011/07/25 07:45:00
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.15    RPL/2 (R) version 4.1.2
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2011 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 199  sequenceur(struct_processus *s_etat_proc Line 199  sequenceur(struct_processus *s_etat_proc
                             (*s_etat_processus).localisation, d_locale))                              (*s_etat_processus).localisation, d_locale))
                             == NULL)                              == NULL)
                     {                      {
                           free((*s_etat_processus).instruction_courante);
                         return(d_erreur);                          return(d_erreur);
                     }                      }
   
Line 305  sequenceur(struct_processus *s_etat_proc Line 306  sequenceur(struct_processus *s_etat_proc
   
                         if ((message = messages(s_etat_processus)) == NULL)                          if ((message = messages(s_etat_processus)) == NULL)
                         {                          {
                               free((*s_etat_processus).instruction_courante);
                             return(d_erreur);                              return(d_erreur);
                         }                          }
   
Line 364  sequenceur(struct_processus *s_etat_proc Line 366  sequenceur(struct_processus *s_etat_proc
                                 if ((message = messages(s_etat_processus))                                  if ((message = messages(s_etat_processus))
                                         == NULL)                                          == NULL)
                                 {                                  {
                                       free((*s_etat_processus)
                                               .instruction_courante);
                                     return(d_erreur);                                      return(d_erreur);
                                 }                                  }
   
                                 printf("%s [%d]\n", message, (int) getpid());                                  printf("%s [%d]\n", message, (int) getpid());
                                 free(message);  
   
                                   free(message);
                                   free((*s_etat_processus).instruction_courante);
                                 return(d_erreur);                                  return(d_erreur);
                             }                              }
                             else if ((*s_etat_processus)                              else if ((*s_etat_processus)
Line 387  sequenceur(struct_processus *s_etat_proc Line 392  sequenceur(struct_processus *s_etat_proc
                                 if ((message = messages(s_etat_processus))                                  if ((message = messages(s_etat_processus))
                                         == NULL)                                          == NULL)
                                 {                                  {
                                       free((*s_etat_processus)
                                               .instruction_courante);
                                     return(d_erreur);                                      return(d_erreur);
                                 }                                  }
   
Line 452  sequenceur(struct_processus *s_etat_proc Line 459  sequenceur(struct_processus *s_etat_proc
   
                     if ((message = messages(s_etat_processus)) == NULL)                      if ((message = messages(s_etat_processus)) == NULL)
                     {                      {
                           free((*s_etat_processus).instruction_courante);
                         free(ligne);                          free(ligne);
                         return(d_erreur);                          return(d_erreur);
                     }                      }
Line 547  sequenceur(struct_processus *s_etat_proc Line 555  sequenceur(struct_processus *s_etat_proc
                         d_vrai) && ((*s_etat_processus)                          d_vrai) && ((*s_etat_processus)
                         .autorisation_evaluation_nom == 'Y'))                          .autorisation_evaluation_nom == 'Y'))
                 {                  {
                     if (((*s_etat_processus).s_liste_variables                      if ((*(*s_etat_processus).pointeur_variable_courante)
                             [(*s_etat_processus)                              .objet == NULL)
                             .position_variable_courante]).objet == NULL)  
                     {                      {
   
 /*  /*
Line 566  sequenceur(struct_processus *s_etat_proc Line 573  sequenceur(struct_processus *s_etat_proc
                             {                              {
                                 printf("[%d] Empilement de la variable "                                  printf("[%d] Empilement de la variable "
                                         "partagée %s de type %d\n",                                          "partagée %s de type %d\n",
                                         (int) getpid(),                                          (int) getpid(), (*s_etat_processus)
                                         (*s_etat_processus)  
                                         .instruction_courante,                                          .instruction_courante,
                                         (*((*s_etat_processus).s_liste_variables                                          (*(*(*s_etat_processus)
                                         [(*s_etat_processus)                                          .pointeur_variable_courante).objet)
                                         .position_variable_courante]).objet)  
                                         .type);                                          .type);
                             }                              }
                             else                              else
Line 580  sequenceur(struct_processus *s_etat_proc Line 585  sequenceur(struct_processus *s_etat_proc
                                         "variable \n", (int) getpid(),                                          "variable \n", (int) getpid(),
                                         (*s_etat_processus)                                          (*s_etat_processus)
                                         .instruction_courante,                                          .instruction_courante,
                                         (*((*s_etat_processus).s_liste_variables                                          (*(*(*s_etat_processus)
                                         [(*s_etat_processus)                                          .pointeur_variable_courante).objet)
                                         .position_variable_courante]).objet)  
                                         .type);                                          .type);
                             }                              }
   
Line 598  sequenceur(struct_processus *s_etat_proc Line 602  sequenceur(struct_processus *s_etat_proc
                         }                          }
   
                         if (recherche_variable_partagee(s_etat_processus,                          if (recherche_variable_partagee(s_etat_processus,
                                 ((*s_etat_processus).s_liste_variables                                  (*(*s_etat_processus)
                                 [(*s_etat_processus)                                  .pointeur_variable_courante).nom,
                                 .position_variable_courante]).nom,                                  (*(*s_etat_processus)
                                 ((*s_etat_processus).s_liste_variables                                  .pointeur_variable_courante).variable_partagee,
                                 [(*s_etat_processus)                                  'P') == d_vrai)
                                 .position_variable_courante])  
                                 .variable_partagee, 'P') == d_vrai)  
                         {                          {
                             // La variable existe.                              // La variable existe.
   
Line 664  sequenceur(struct_processus *s_etat_proc Line 666  sequenceur(struct_processus *s_etat_proc
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
 */  */
   
                     else if ((*((*s_etat_processus).s_liste_variables                      else if ((*(*(*s_etat_processus).pointeur_variable_courante)
                             [(*s_etat_processus).position_variable_courante])  
                             .objet).type == ADR)                              .objet).type == ADR)
                     {                      {
   
Line 734  sequenceur(struct_processus *s_etat_proc Line 735  sequenceur(struct_processus *s_etat_proc
   
                             (*s_etat_processus).position_courante =                              (*s_etat_processus).position_courante =
                                     (*((unsigned long *)                                      (*((unsigned long *)
                                     ((*((*s_etat_processus).s_liste_variables                                      ((*(*(*s_etat_processus)
                                     [(*s_etat_processus)                                      .pointeur_variable_courante)
                                     .position_variable_courante]                                      .objet).objet)));
                                     .objet)).objet)));  
   
                             drapeau_appel_definition = d_vrai;                              drapeau_appel_definition = d_vrai;
                         }                          }
Line 755  sequenceur(struct_processus *s_etat_proc Line 755  sequenceur(struct_processus *s_etat_proc
                                         (int) getpid(),                                          (int) getpid(),
                                         (*s_etat_processus)                                          (*s_etat_processus)
                                         .instruction_courante,                                          .instruction_courante,
                                         (*((*s_etat_processus).s_liste_variables                                          (*(*(*s_etat_processus)
                                         [(*s_etat_processus)                                          .pointeur_variable_courante).objet)
                                         .position_variable_courante]).objet)  
                                         .type);                                          .type);
                             }                              }
                             else                              else
Line 766  sequenceur(struct_processus *s_etat_proc Line 765  sequenceur(struct_processus *s_etat_proc
                                         "\n", (int) getpid(),                                          "\n", (int) getpid(),
                                         (*s_etat_processus)                                          (*s_etat_processus)
                                         .instruction_courante,                                          .instruction_courante,
                                         (*((*s_etat_processus).s_liste_variables                                          (*(*(*s_etat_processus)
                                         [(*s_etat_processus)                                          .pointeur_variable_courante).objet)
                                         .position_variable_courante]).objet)  
                                         .type);                                          .type);
                             }                              }
   
Line 776  sequenceur(struct_processus *s_etat_proc Line 774  sequenceur(struct_processus *s_etat_proc
                         }                          }
   
                         if ((s_objet = copie_objet(s_etat_processus,                          if ((s_objet = copie_objet(s_etat_processus,
                                 ((*s_etat_processus)                                  (*(*s_etat_processus)
                                 .s_liste_variables[(*s_etat_processus)                                  .pointeur_variable_courante).objet, 'P'))
                                 .position_variable_courante]).objet, 'P'))  
                                 == NULL)                                  == NULL)
                         {                          {
                             (*s_etat_processus).erreur_systeme =                              (*s_etat_processus).erreur_systeme =
Line 812  sequenceur(struct_processus *s_etat_proc Line 809  sequenceur(struct_processus *s_etat_proc
                     {                      {
                         if ((*s_etat_processus).l_base_pile == NULL)                          if ((*s_etat_processus).l_base_pile == NULL)
                         {                          {
                             (*s_etat_processus).erreur_execution =                              if ((*s_etat_processus).erreur_execution !=
                                     d_ex_manque_argument;                                      d_ex_nom_implicite)
                               {
                                   (*s_etat_processus).erreur_execution =
                                           d_ex_manque_argument;
                               }
                         }                          }
                         else if ((*(*(*s_etat_processus).l_base_pile).donnee)                          else if ((*(*(*s_etat_processus).l_base_pile).donnee)
                                 .type == NOM)                                  .type == NOM)
Line 848  sequenceur(struct_processus *s_etat_proc Line 849  sequenceur(struct_processus *s_etat_proc
                                 &((*s_etat_processus).l_base_pile),                                  &((*s_etat_processus).l_base_pile),
                                 &s_objet_evaluation) == d_erreur)                                  &s_objet_evaluation) == d_erreur)
                         {                          {
                               free((*s_etat_processus).instruction_courante);
                             (*s_etat_processus).erreur_execution =                              (*s_etat_processus).erreur_execution =
                                     d_ex_manque_argument;                                      d_ex_manque_argument;
 ////////////////////////////////////////////////////////////////////////////////  
                             return(d_erreur);                              return(d_erreur);
                         }                          }
   
                         if (evaluation(s_etat_processus, s_objet_evaluation,                          if (evaluation(s_etat_processus, s_objet_evaluation,
                                 'N') == d_erreur)                                  'N') == d_erreur)
                         {                          {
                               free((*s_etat_processus).instruction_courante);
                             liberation(s_etat_processus, s_objet_evaluation);                              liberation(s_etat_processus, s_objet_evaluation);
                             return(d_erreur);                              return(d_erreur);
                         }                          }
   
                         liberation(s_etat_processus, s_objet_evaluation);                          liberation(s_etat_processus, s_objet_evaluation);
                     }                      }
   
                       // Le séquenceur est appelé depuis la routine de
                       // recherche de type
   
                       else if ((*s_etat_processus).recherche_type == 'Y')
                       {
                           if ((*s_etat_processus).erreur_execution != d_ex)
                           {
                               free((*s_etat_processus).instruction_courante);
                               return(d_erreur);
                           }
                       }
                 }                  }
             }              }
             else if (((*s_etat_processus).test_instruction == 'Y') &&              else if (((*s_etat_processus).test_instruction == 'Y') &&
Line 970  sequenceur(struct_processus *s_etat_proc Line 984  sequenceur(struct_processus *s_etat_proc
   
             fflush(stdout);              fflush(stdout);
   
               free((*s_etat_processus).instruction_courante);
             return(d_erreur);              return(d_erreur);
         }          }
   
Line 1051  sequenceur(struct_processus *s_etat_proc Line 1066  sequenceur(struct_processus *s_etat_proc
   
             if ((message = messages(s_etat_processus)) == NULL)              if ((message = messages(s_etat_processus)) == NULL)
             {              {
                   free((*s_etat_processus).instruction_courante);
                 return(d_erreur);                  return(d_erreur);
             }              }
   
Line 1137  sequenceur(struct_processus *s_etat_proc Line 1153  sequenceur(struct_processus *s_etat_proc
   
                     if (erreur == d_erreur)                      if (erreur == d_erreur)
                     {                      {
                           free((*s_etat_processus).instruction_courante);
                         return(d_erreur);                          return(d_erreur);
                     }                      }
   
                     if (recherche_variable(s_etat_processus,                      if (recherche_variable(s_etat_processus,
                             (*s_etat_processus).instruction_courante) == d_vrai)                              (*s_etat_processus).instruction_courante) == d_vrai)
                     {                      {
                         if (((*s_etat_processus).s_liste_variables                          if ((*(*s_etat_processus).pointeur_variable_courante)
                                 [(*s_etat_processus)                                  .objet == NULL)
                                 .position_variable_courante]).objet == NULL)  
                         {                          {
                             // Variable partagée                              // Variable partagée
                         }                          }
                         else if ((*((*s_etat_processus).s_liste_variables                          else if ((*(*(*s_etat_processus)
                                 [(*s_etat_processus)                                  .pointeur_variable_courante).objet).type == ADR)
                                 .position_variable_courante]).objet).type ==  
                                 ADR)  
                         {                          {
                             empilement_pile_systeme(s_etat_processus);                              empilement_pile_systeme(s_etat_processus);
   
                             if ((*s_etat_processus).erreur_systeme != d_es)                              if ((*s_etat_processus).erreur_systeme != d_es)
                             {                              {
                                   free((*s_etat_processus).instruction_courante);
                                 return(d_erreur);                                  return(d_erreur);
                             }                              }
   
Line 1174  sequenceur(struct_processus *s_etat_proc Line 1189  sequenceur(struct_processus *s_etat_proc
   
                             (*s_etat_processus).position_courante =                              (*s_etat_processus).position_courante =
                                     (*((unsigned long *)                                      (*((unsigned long *)
                                     ((*((*s_etat_processus).s_liste_variables                                      ((*(*(*s_etat_processus)
                                     [(*s_etat_processus)                                      .pointeur_variable_courante)
                                     .position_variable_courante]                                      .objet).objet)));
                                     .objet)).objet)));  
   
                             (*s_etat_processus)                              (*s_etat_processus)
                                     .autorisation_empilement_programme = 'N';                                      .autorisation_empilement_programme = 'N';
Line 1191  sequenceur(struct_processus *s_etat_proc Line 1205  sequenceur(struct_processus *s_etat_proc
   
                         if (instruction_majuscule == NULL)                          if (instruction_majuscule == NULL)
                         {                          {
                               free((*s_etat_processus).instruction_courante);
                             return(d_erreur);                              return(d_erreur);
                         }                          }
   

Removed from v.1.14  
changed lines
  Added in v.1.41


CVSweb interface <joel.bertrand@systella.fr>