Diff for /rpl/src/instructions_f3.c between versions 1.78 and 1.87

version 1.78, 2018/06/01 09:57:27 version 1.87, 2022/09/07 13:40:35
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.29    RPL/2 (R) version 4.1.34
   Copyright (C) 1989-2018 Dr. BERTRAND Joël    Copyright (C) 1989-2021 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 72  instruction_format(struct_processus *s_e Line 72  instruction_format(struct_processus *s_e
         }          }
   
         printf("    { \"STANDARD*(*)\" }\n");          printf("    { \"STANDARD*(*)\" }\n");
         printf("    { { \"NAME\" \"lambda\" } \"SEQUENTIAL\" \"NEW\""          printf("    { { \"NAME\" \"lambda\" } \"SEQUENTIAL\" \"NEW\" "
                 "\"WRITEONLY\" \"FORMATTED\" } OPEN\n            FORMAT\n\n");                  "\"WRITEONLY\" \"FORMATTED\" } OPEN\n            FORMAT\n\n");
   
         if ((*s_etat_processus).langue == 'F')          if ((*s_etat_processus).langue == 'F')
Line 1643  instruction_fleche_num(struct_processus Line 1643  instruction_fleche_num(struct_processus
         return;          return;
     }      }
   
     if ((s_objet_simplifie = simplification(s_etat_processus, s_objet)) == NULL)      if (test_cfsf(s_etat_processus, 46) == d_vrai)
     {      {
         if (last_valide == d_vrai)          if (evaluation(s_etat_processus, s_objet, 'N') == d_erreur)
         {          {
             sf(s_etat_processus, 31);              if (last_valide == d_vrai)
               {
                   sf(s_etat_processus, 31);
               }
   
               if (registre_type_evaluation == 'E')
               {
                   sf(s_etat_processus, 35);
               }
               else
               {
                   cf(s_etat_processus, 35);
               }
   
               liberation(s_etat_processus, s_objet);
               return;
         }          }
   
         if (registre_type_evaluation == 'E')          if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                   &s_objet) == d_erreur)
         {          {
             sf(s_etat_processus, 35);              if (last_valide == d_vrai)
               {
                   sf(s_etat_processus, 31);
               }
   
               if (registre_type_evaluation == 'E')
               {
                   sf(s_etat_processus, 35);
               }
               else
               {
                   cf(s_etat_processus, 35);
               }
   
               (*s_etat_processus).erreur_execution = d_ex_manque_argument;
               return;
         }          }
         else  
           if ((s_objet_simplifie = simplification(s_etat_processus, s_objet))
                   == NULL)
         {          {
             cf(s_etat_processus, 35);              if (last_valide == d_vrai)
               {
                   sf(s_etat_processus, 31);
               }
   
               if (registre_type_evaluation == 'E')
               {
                   sf(s_etat_processus, 35);
               }
               else
               {
                   cf(s_etat_processus, 35);
               }
   
               return;
         }          }
   
         return;          liberation(s_etat_processus, s_objet);
           s_objet = s_objet_simplifie;
     }      }
   
     liberation(s_etat_processus, s_objet);  
     s_objet = s_objet_simplifie;  
   
     if (evaluation(s_etat_processus, s_objet, 'N') == d_erreur)      if (evaluation(s_etat_processus, s_objet, 'N') == d_erreur)
     {      {
         if (last_valide == d_vrai)          if (last_valide == d_vrai)

Removed from v.1.78  
changed lines
  Added in v.1.87


CVSweb interface <joel.bertrand@systella.fr>