Diff for /rpl/src/instructions_f1.c between versions 1.1.1.1 and 1.42

version 1.1.1.1, 2010/01/26 15:22:45 version 1.42, 2012/10/01 11:05:04
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.9    RPL/2 (R) version 4.1.11
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2012 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 271  instruction_fleche(struct_processus *s_e Line 271  instruction_fleche(struct_processus *s_e
                 }                  }
                 else                  else
                 {                  {
                       (*s_etat_processus).expression_courante = l_element_courant;
                     (*s_etat_processus).erreur_execution = d_ex_nom_invalide;                      (*s_etat_processus).erreur_execution = d_ex_nom_invalide;
                     return;                      return;
                 }                  }
Line 285  instruction_fleche(struct_processus *s_e Line 286  instruction_fleche(struct_processus *s_e
             }              }
             else if ((*(*l_element_courant).donnee).type != NOM)              else if ((*(*l_element_courant).donnee).type != NOM)
             {              {
                   (*s_etat_processus).expression_courante = l_element_courant;
                 (*s_etat_processus).erreur_execution = d_ex_nom_invalide;                  (*s_etat_processus).erreur_execution = d_ex_nom_invalide;
                 return;                  return;
             }              }
Line 293  instruction_fleche(struct_processus *s_e Line 295  instruction_fleche(struct_processus *s_e
                 if ((s_objet_elementaire = copie_objet(s_etat_processus,                  if ((s_objet_elementaire = copie_objet(s_etat_processus,
                         (*l_element_courant).donnee, 'P')) == NULL)                          (*l_element_courant).donnee, 'P')) == NULL)
                 {                  {
                       (*s_etat_processus).expression_courante = l_element_courant;
                     (*s_etat_processus).erreur_systeme =                      (*s_etat_processus).erreur_systeme =
                             d_es_allocation_memoire;                              d_es_allocation_memoire;
                     return;                      return;
Line 301  instruction_fleche(struct_processus *s_e Line 304  instruction_fleche(struct_processus *s_e
                 if (empilement(s_etat_processus, &((*s_etat_processus)                  if (empilement(s_etat_processus, &((*s_etat_processus)
                         .l_base_pile), s_objet_elementaire) == d_erreur)                          .l_base_pile), s_objet_elementaire) == d_erreur)
                 {                  {
                       (*s_etat_processus).expression_courante = l_element_courant;
                     return;                      return;
                 }                  }
   
Line 312  instruction_fleche(struct_processus *s_e Line 316  instruction_fleche(struct_processus *s_e
             l_element_courant = (*l_element_courant).suivant;              l_element_courant = (*l_element_courant).suivant;
         } while((fin_scrutation == d_faux) && (l_element_courant != NULL));          } while((fin_scrutation == d_faux) && (l_element_courant != NULL));
   
           (*s_etat_processus).objet_courant =
                   (*(*s_etat_processus).expression_courante).donnee;
         (*s_etat_processus).instruction_courante = tampon;          (*s_etat_processus).instruction_courante = tampon;
   
         if (fin_scrutation == d_faux)          if (fin_scrutation == d_faux)
Line 351  instruction_fleche(struct_processus *s_e Line 357  instruction_fleche(struct_processus *s_e
   
     for(i = 0; i < nombre_variables; i++)      for(i = 0; i < nombre_variables; i++)
     {      {
           if (l_emplacement_valeurs == NULL)
           {
               (*s_etat_processus).erreur_execution = d_ex_manque_argument;
               return;
           }
   
         l_emplacement_valeurs = (*l_emplacement_valeurs).suivant;          l_emplacement_valeurs = (*l_emplacement_valeurs).suivant;
     }      }
   
Line 416  instruction_fleche(struct_processus *s_e Line 428  instruction_fleche(struct_processus *s_e
         if (recherche_variable(s_etat_processus, s_variable.nom) == d_vrai)          if (recherche_variable(s_etat_processus, s_variable.nom) == d_vrai)
         {          {
             if ((*s_etat_processus).niveau_courant ==              if ((*s_etat_processus).niveau_courant ==
                     (*s_etat_processus).s_liste_variables[(*s_etat_processus)                      (*(*s_etat_processus).pointeur_variable_courante).niveau)
                     .position_variable_courante].niveau)  
             {              {
                 liberation(s_etat_processus, s_objet);                  liberation(s_etat_processus, s_objet);
                 free(s_variable.nom);                  free(s_variable.nom);
Line 578  instruction_fleche(struct_processus *s_e Line 589  instruction_fleche(struct_processus *s_e
             }              }
             else              else
             {              {
                   // Variable partagée à utiliser
                 // Variable partagee à créer                  // Variable partagee à créer
   
                 (*s_etat_processus).erreur_systeme = d_es;                  (*s_etat_processus).erreur_systeme = d_es;
Line 585  instruction_fleche(struct_processus *s_e Line 597  instruction_fleche(struct_processus *s_e
                 if ((s_variable_partagee.nom = malloc((strlen(s_variable.nom)                  if ((s_variable_partagee.nom = malloc((strlen(s_variable.nom)
                         + 1) * sizeof(unsigned char))) == NULL)                          + 1) * sizeof(unsigned char))) == NULL)
                 {                  {
                       if (pthread_mutex_unlock(&((*(*s_etat_processus)
                               .s_liste_variables_partagees).mutex)) != 0)
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                     (*s_etat_processus).erreur_systeme =                      (*s_etat_processus).erreur_systeme =
                             d_es_allocation_memoire;                              d_es_allocation_memoire;
                     return;                      return;
Line 631  instruction_fleche(struct_processus *s_e Line 650  instruction_fleche(struct_processus *s_e
                 if (creation_variable_partagee(s_etat_processus,                  if (creation_variable_partagee(s_etat_processus,
                         &s_variable_partagee) == d_erreur)                          &s_variable_partagee) == d_erreur)
                 {                  {
                       if (pthread_mutex_unlock(&((*(*s_etat_processus)
                               .s_liste_variables_partagees).mutex)) != 0)
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                     return;                      return;
                 }                  }
   
Line 958  instruction_for(struct_processus *s_etat Line 984  instruction_for(struct_processus *s_etat
         }          }
     }      }
   
     empilement_pile_systeme(s_etat_processus);  
   
     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),      if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
             &s_objet_1) == d_erreur)              &s_objet_1) == d_erreur)
     {      {
Line 1000  instruction_for(struct_processus *s_etat Line 1024  instruction_for(struct_processus *s_etat
     instruction_valide = (*s_etat_processus).instruction_valide;      instruction_valide = (*s_etat_processus).instruction_valide;
     (*s_etat_processus).test_instruction = 'Y';      (*s_etat_processus).test_instruction = 'Y';
   
       empilement_pile_systeme(s_etat_processus);
   
       if ((*s_etat_processus).erreur_systeme != d_es)
       {
           return;
       }
   
     if ((*s_etat_processus).mode_execution_programme == 'Y')      if ((*s_etat_processus).mode_execution_programme == 'Y')
     {      {
         if (recherche_instruction_suivante(s_etat_processus) == d_erreur)          if (recherche_instruction_suivante(s_etat_processus) == d_erreur)
Line 1017  instruction_for(struct_processus *s_etat Line 1048  instruction_for(struct_processus *s_etat
             free((*s_etat_processus).instruction_courante);              free((*s_etat_processus).instruction_courante);
             (*s_etat_processus).instruction_courante = tampon;              (*s_etat_processus).instruction_courante = tampon;
   
               depilement_pile_systeme(s_etat_processus);
   
             (*s_etat_processus).erreur_execution = d_ex_nom_reserve;              (*s_etat_processus).erreur_execution = d_ex_nom_reserve;
             return;              return;
         }          }
Line 1031  instruction_for(struct_processus *s_etat Line 1064  instruction_for(struct_processus *s_etat
             liberation(s_etat_processus, s_objet_1);              liberation(s_etat_processus, s_objet_1);
             liberation(s_etat_processus, s_objet_2);              liberation(s_etat_processus, s_objet_2);
   
               depilement_pile_systeme(s_etat_processus);
             return;              return;
         }          }
   
Line 1040  instruction_for(struct_processus *s_etat Line 1074  instruction_for(struct_processus *s_etat
             liberation(s_etat_processus, s_objet_1);              liberation(s_etat_processus, s_objet_1);
             liberation(s_etat_processus, s_objet_2);              liberation(s_etat_processus, s_objet_2);
   
               depilement_pile_systeme(s_etat_processus);
   
             (*s_etat_processus).erreur_execution = d_ex_manque_argument;              (*s_etat_processus).erreur_execution = d_ex_manque_argument;
             return;              return;
         }          }
Line 1051  instruction_for(struct_processus *s_etat Line 1087  instruction_for(struct_processus *s_etat
     {      {
         if ((*s_etat_processus).expression_courante == NULL)          if ((*s_etat_processus).expression_courante == NULL)
         {          {
               depilement_pile_systeme(s_etat_processus);
             (*s_etat_processus).erreur_execution = d_ex_manque_argument;              (*s_etat_processus).erreur_execution = d_ex_manque_argument;
             return;              return;
         }          }
Line 1075  instruction_for(struct_processus *s_etat Line 1112  instruction_for(struct_processus *s_etat
         liberation(s_etat_processus, s_objet_1);          liberation(s_etat_processus, s_objet_1);
         liberation(s_etat_processus, s_objet_2);          liberation(s_etat_processus, s_objet_2);
   
           depilement_pile_systeme(s_etat_processus);
   
         (*s_etat_processus).erreur_execution = d_ex_erreur_traitement_boucle;          (*s_etat_processus).erreur_execution = d_ex_erreur_traitement_boucle;
         return;          return;
     }      }
Line 1083  instruction_for(struct_processus *s_etat Line 1122  instruction_for(struct_processus *s_etat
         liberation(s_etat_processus, s_objet_1);          liberation(s_etat_processus, s_objet_1);
         liberation(s_etat_processus, s_objet_2);          liberation(s_etat_processus, s_objet_2);
   
           depilement_pile_systeme(s_etat_processus);
   
         (*s_etat_processus).erreur_execution = d_ex_erreur_traitement_boucle;          (*s_etat_processus).erreur_execution = d_ex_erreur_traitement_boucle;
         return;          return;
     }      }

Removed from v.1.1.1.1  
changed lines
  Added in v.1.42


CVSweb interface <joel.bertrand@systella.fr>