Diff for /rpl/src/instructions_s1.c between versions 1.53 and 1.59

version 1.53, 2012/08/22 10:47:17 version 1.59, 2012/12/17 21:22:44
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.10    RPL/2 (R) version 4.1.11
   Copyright (C) 1989-2012 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 2572  instruction_start(struct_processus *s_et Line 2572  instruction_start(struct_processus *s_et
         }          }
     }      }
   
     empilement_pile_systeme(s_etat_processus);  
   
     if ((*s_etat_processus).erreur_systeme != d_es)  
     {  
         return;  
     }  
   
     (*(*s_etat_processus).l_base_pile_systeme).type_cloture = 'S';  
   
     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 2614  instruction_start(struct_processus *s_et Line 2605  instruction_start(struct_processus *s_et
         return;          return;
     }      }
   
       empilement_pile_systeme(s_etat_processus);
   
       if ((*s_etat_processus).erreur_systeme != d_es)
       {
           return;
       }
   
       (*(*s_etat_processus).l_base_pile_systeme).type_cloture = 'S';
   
     (*(*s_etat_processus).l_base_pile_systeme).indice_boucle = s_objet_2;      (*(*s_etat_processus).l_base_pile_systeme).indice_boucle = s_objet_2;
     (*(*s_etat_processus).l_base_pile_systeme).limite_indice_boucle = s_objet_1;      (*(*s_etat_processus).l_base_pile_systeme).limite_indice_boucle = s_objet_1;
   
Line 2916  instruction_step(struct_processus *s_eta Line 2916  instruction_step(struct_processus *s_eta
         {          {
             (*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;
             }              }
Line 3219  instruction_sto(struct_processus *s_etat Line 3219  instruction_sto(struct_processus *s_etat
   
         if ((*(*s_etat_processus).pointeur_variable_courante).objet == NULL)          if ((*(*s_etat_processus).pointeur_variable_courante).objet == NULL)
         {          {
             if (pthread_mutex_lock(&((*(*s_etat_processus)  
                     .s_liste_variables_partagees).mutex)) != 0)  
             {  
                 (*s_etat_processus).erreur_systeme = d_es_processus;  
                 return;  
             }  
   
             if (recherche_variable_partagee(s_etat_processus,              if (recherche_variable_partagee(s_etat_processus,
                     (*(*s_etat_processus).pointeur_variable_courante).nom,                      (*(*s_etat_processus).pointeur_variable_courante).nom,
                     (*(*s_etat_processus).pointeur_variable_courante)                      (*(*s_etat_processus).pointeur_variable_courante)
                     .variable_partagee, (*(*s_etat_processus)                      .variable_partagee, (*(*s_etat_processus)
                     .pointeur_variable_courante).origine) == d_faux)                      .pointeur_variable_courante).origine) == NULL)
             {              {
                 if (pthread_mutex_unlock(&((*(*s_etat_processus)                  if (((*s_etat_processus).autorisation_nom_implicite == 'N') &&
                         .s_liste_variables_partagees).mutex)) != 0)                          ((*((struct_nom *) (*s_objet_1).objet)).symbole
                 {                          == d_faux))
                     (*s_etat_processus).erreur_systeme = d_es_processus;  
                     return;  
                 }  
   
                 if ((*s_etat_processus).autorisation_nom_implicite == 'N')  
                 {                  {
                     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);
Line 3282  instruction_sto(struct_processus *s_etat Line 3270  instruction_sto(struct_processus *s_etat
             else              else
             {              {
                 liberation(s_etat_processus, (*(*s_etat_processus)                  liberation(s_etat_processus, (*(*s_etat_processus)
                         .s_liste_variables_partagees).table                          .pointeur_variable_partagee_courante).objet);
                         [(*(*s_etat_processus).s_liste_variables_partagees)                  (*(*s_etat_processus).pointeur_variable_partagee_courante)
                         .position_variable].objet);                          .objet = s_objet_2;
   
                 (*(*s_etat_processus).s_liste_variables_partagees).table  
                         [(*(*s_etat_processus).s_liste_variables_partagees)  
                         .position_variable].objet = s_objet_2;  
   
                 if (pthread_mutex_unlock(&((*(*s_etat_processus)                  if (pthread_mutex_unlock(&((*(*s_etat_processus)
                         .s_liste_variables_partagees).mutex)) != 0)                          .pointeur_variable_partagee_courante).mutex)) != 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                      return;
Line 3300  instruction_sto(struct_processus *s_etat Line 3284  instruction_sto(struct_processus *s_etat
         }          }
         else          else
         {          {
             if ((*s_etat_processus).autorisation_nom_implicite == 'N')              if (((*s_etat_processus).autorisation_nom_implicite == 'N') &&
                       ((*((struct_nom *) (*s_objet_1).objet)).symbole == d_faux))
             {              {
                 if ((*(*s_etat_processus).pointeur_variable_courante)                  if ((*(*s_etat_processus).pointeur_variable_courante)
                         .niveau == 1)                          .niveau == 1)
Line 3327  instruction_sto(struct_processus *s_etat Line 3312  instruction_sto(struct_processus *s_etat
          * une variable globale.           * une variable globale.
          */           */
   
         if ((*s_etat_processus).autorisation_nom_implicite == 'N')          if (((*s_etat_processus).autorisation_nom_implicite == 'N') &&
                   ((*((struct_nom *) (*s_objet_1).objet)).symbole == d_faux))
         {          {
             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);

Removed from v.1.53  
changed lines
  Added in v.1.59


CVSweb interface <joel.bertrand@systella.fr>