Diff for /rpl/src/instructions_f3.c between versions 1.44 and 1.57

version 1.44, 2012/04/13 14:12:54 version 1.57, 2013/03/16 20:11:29
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.8    RPL/2 (R) version 4.1.13
   Copyright (C) 1989-2012 Dr. BERTRAND Joël    Copyright (C) 1989-2013 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("    { \"lambda\" 'SEQUENTIAL' 'NEW' 'WRITEONLY' 'FORMATTED' }"          printf("    { { \"NAME\" \"lambda\" } \"SEQUENTIAL\" \"NEW\""
                 " OPEN FORMAT\n\n");                  "\"WRITEONLY\" \"FORMATTED\" } OPEN\n            FORMAT\n\n");
   
         if ((*s_etat_processus).langue == 'F')          if ((*s_etat_processus).langue == 'F')
         {          {
Line 96  instruction_format(struct_processus *s_e Line 96  instruction_format(struct_processus *s_e
         printf("    { \"CHARACTER*(*)\" }\n");          printf("    { \"CHARACTER*(*)\" }\n");
         printf("    { \"CHARACTER*(%s)\" }\n", d_INT);          printf("    { \"CHARACTER*(%s)\" }\n", d_INT);
         printf("    { \"BINARY*%s(*)\" }\n", d_INT);          printf("    { \"BINARY*%s(*)\" }\n", d_INT);
         printf("    { \"BINARY*%s(%s)\" }\n\n", d_INT, d_INT);          printf("    { \"BINARY*%s(%s)\" }\n", d_INT, d_INT);
           printf("    { \"NATIVE*(*)\" }\n\n");
   
         printf("  UNFORMATTED\n");          printf("  UNFORMATTED\n");
         printf("    { \"INTEGER*1\", \"INTEGER*2\", \"INTEGER*4\", "          printf("    { \"INTEGER*1\", \"INTEGER*2\", \"INTEGER*4\", "
Line 105  instruction_format(struct_processus *s_e Line 106  instruction_format(struct_processus *s_e
                 "\"LOGICAL*8\" }\n");                  "\"LOGICAL*8\" }\n");
         printf("    { \"REAL*4\", \"REAL*8\" }\n");          printf("    { \"REAL*4\", \"REAL*8\" }\n");
         printf("    { \"COMPLEX*8\", \"COMPLEX*16\" }\n");          printf("    { \"COMPLEX*8\", \"COMPLEX*16\" }\n");
         printf("    { \"CHARACTER\" }\n\n");          printf("    { \"CHARACTER*(*)\", \"CHARACTER*(%s)\" }\n", d_INT);
           printf("    { \"NATIVE*(*)\" }\n\n");
   
         printf("  FLOW\n");          printf("  FLOW\n");
         printf("    { \"CHARACTER*(*)\" }\n");  
         printf("    { \"CHARACTER*(%s)\" }\n", d_INT);  
         printf("    { \"LENGTH*(*)\" }\n");          printf("    { \"LENGTH*(*)\" }\n");
         printf("    { \"LENGTH*(%s)\" }\n", d_INT);          printf("    { \"LENGTH*(%s)\" }\n", d_INT);
   
Line 148  instruction_format(struct_processus *s_e Line 148  instruction_format(struct_processus *s_e
     if (((*s_objet_argument_1).type == FCH) &&      if (((*s_objet_argument_1).type == FCH) &&
             ((*s_objet_argument_2).type == LST))              ((*s_objet_argument_2).type == LST))
     {      {
         if ((*((struct_fichier *) (*s_objet_argument_1).objet)).binaire  
                 == 'F')  
         {  
             liberation(s_etat_processus, s_objet_argument_1);  
             liberation(s_etat_processus, s_objet_argument_2);  
   
             (*s_etat_processus).erreur_execution =  
                     d_ex_erreur_format_fichier;  
             return;  
         }  
   
         if ((s_copie_argument_1 = copie_objet(s_etat_processus,          if ((s_copie_argument_1 = copie_objet(s_etat_processus,
                 s_objet_argument_1, 'N')) == NULL)                  s_objet_argument_1, 'N')) == NULL)
         {          {
Line 178  instruction_format(struct_processus *s_e Line 167  instruction_format(struct_processus *s_e
     else if (((*s_objet_argument_1).type == SCK) &&      else if (((*s_objet_argument_1).type == SCK) &&
             ((*s_objet_argument_2).type == LST))              ((*s_objet_argument_2).type == LST))
     {      {
         if ((*((struct_socket *) (*s_objet_argument_1).objet)).binaire  
                 == 'F')  
         {  
             liberation(s_etat_processus, s_objet_argument_1);  
             liberation(s_etat_processus, s_objet_argument_2);  
   
             (*s_etat_processus).erreur_execution =  
                     d_ex_erreur_format_fichier;  
             return;  
         }  
   
         if ((s_copie_argument_1 = copie_objet(s_etat_processus,          if ((s_copie_argument_1 = copie_objet(s_etat_processus,
                 s_objet_argument_1, 'N')) == NULL)                  s_objet_argument_1, 'N')) == NULL)
         {          {
Line 564  instruction_fleche_q(struct_processus *s Line 542  instruction_fleche_q(struct_processus *s
   
             if (y != 0)              if (y != 0)
             {              {
                 z = fabs(objectif - (r1 / r2));                  z = abs(objectif - (r1 / r2));
                 x = ((real8) 1) / y;                  x = ((real8) 1) / y;
             }              }
             else              else

Removed from v.1.44  
changed lines
  Added in v.1.57


CVSweb interface <joel.bertrand@systella.fr>