Diff for /rpl/src/instructions_f1.c between versions 1.61 and 1.75

version 1.61, 2013/12/12 07:26:53 version 1.75, 2016/09/27 15:29:35
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.17    RPL/2 (R) version 4.1.26
   Copyright (C) 1989-2013 Dr. BERTRAND Joël    Copyright (C) 1989-2016 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 110  instruction_fleche(struct_processus *s_e Line 110  instruction_fleche(struct_processus *s_e
   
         printf("    -> (variables) %s\n\n", d_RPN);          printf("    -> (variables) %s\n\n", d_RPN);
   
         printf("    -> (variables) %s\n", d_ALG);          printf("    -> (variables) %s\n\n", d_ALG);
   
           printf("    -> (variables) %s\n", d_NOM);
   
         return;          return;
     }      }
Line 189  instruction_fleche(struct_processus *s_e Line 191  instruction_fleche(struct_processus *s_e
   
             if ((*s_etat_processus).instruction_valide == 'N')              if ((*s_etat_processus).instruction_valide == 'N')
             {              {
                   (*s_etat_processus).type_en_cours = NON;
                 recherche_type(s_etat_processus);                  recherche_type(s_etat_processus);
   
                 if ((*s_etat_processus).erreur_execution != d_ex)                  if ((*s_etat_processus).erreur_execution != d_ex)
Line 223  instruction_fleche(struct_processus *s_e Line 226  instruction_fleche(struct_processus *s_e
                 else if ((*((struct_nom *) (*(*(*s_etat_processus).l_base_pile)                  else if ((*((struct_nom *) (*(*(*s_etat_processus).l_base_pile)
                         .donnee).objet)).symbole == d_vrai)                          .donnee).objet)).symbole == d_vrai)
                 {                  {
                     (*s_etat_processus).erreur_execution = d_ex_nom_invalide;                      (*s_etat_processus).niveau_courant++;
                     (*s_etat_processus).instruction_courante = tampon;                      fin_scrutation = d_vrai;
                     return;                      presence_expression_algebrique = d_vrai;
   
                       if (depilement(s_etat_processus, &((*s_etat_processus)
                               .l_base_pile), &s_expression_algebrique)
                               == d_erreur)
                       {
                           (*s_etat_processus).erreur_execution =
                                   d_ex_manque_argument;
                           (*s_etat_processus).instruction_courante = tampon;
                           return;
                       }
                 }                  }
                 else                  else
                 {                  {
Line 292  instruction_fleche(struct_processus *s_e Line 305  instruction_fleche(struct_processus *s_e
                 (*s_etat_processus).erreur_execution = d_ex_nom_invalide;                  (*s_etat_processus).erreur_execution = d_ex_nom_invalide;
                 return;                  return;
             }              }
               else if ((*((struct_nom *) (*(*l_element_courant).donnee).objet))
                       .symbole == d_vrai)
               {
                   (*s_etat_processus).niveau_courant++;
                   fin_scrutation = d_vrai;
                   presence_expression_algebrique = d_vrai;
   
                   s_expression_algebrique = (*l_element_courant).donnee;
               }
             else              else
             {              {
                 if ((s_objet_elementaire = copie_objet(s_etat_processus,                  if ((s_objet_elementaire = copie_objet(s_etat_processus,
Line 726  instruction_fleche(struct_processus *s_e Line 748  instruction_fleche(struct_processus *s_e
   
     if (presence_expression_algebrique == d_vrai)      if (presence_expression_algebrique == d_vrai)
     {      {
           // Si l'expression algébrique est réduite à un simple nom, il
           // s'agit toujours d'un nom symbolique. Il faut alors lui retirer
           // son caractère de constante symbolique pour faire remonter les
           // erreurs de type 'variable indéfinie'.
   
           if ((*s_expression_algebrique).type == NOM)
           {
               (*((struct_nom *) (*s_expression_algebrique).objet)).symbole =
                       d_faux;
           }
   
         evaluation(s_etat_processus, s_expression_algebrique, 'N');          evaluation(s_etat_processus, s_expression_algebrique, 'N');
   
           if ((*s_expression_algebrique).type == NOM)
           {
               (*((struct_nom *) (*s_expression_algebrique).objet)).symbole =
                       d_vrai;
           }
   
         if ((*s_etat_processus).mode_execution_programme == 'Y')          if ((*s_etat_processus).mode_execution_programme == 'Y')
         {          {
             liberation(s_etat_processus, s_expression_algebrique);              liberation(s_etat_processus, s_expression_algebrique);
         }          }
   
           (*s_etat_processus).autorisation_empilement_programme = 'Y';
         (*s_etat_processus).niveau_courant--;          (*s_etat_processus).niveau_courant--;
   
         if (retrait_variables_par_niveau(s_etat_processus) == d_erreur)          if (retrait_variables_par_niveau(s_etat_processus) == d_erreur)
         {          {
             return;              return;
         }          }
   
         (*s_etat_processus).autorisation_empilement_programme = 'Y';  
     }      }
   
     return;      return;
Line 1054  instruction_for(struct_processus *s_etat Line 1092  instruction_for(struct_processus *s_etat
             return;              return;
         }          }
   
           (*s_etat_processus).type_en_cours = NON;
         recherche_type(s_etat_processus);          recherche_type(s_etat_processus);
   
         free((*s_etat_processus).instruction_courante);          free((*s_etat_processus).instruction_courante);

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


CVSweb interface <joel.bertrand@systella.fr>