Diff for /rpl/src/instructions_c4.c between versions 1.15 and 1.79

version 1.15, 2010/08/06 15:32:59 version 1.79, 2021/03/13 12:50:40
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.18    RPL/2 (R) version 4.1.33
   Copyright (C) 1989-2010 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 39 Line 39
 void  void
 instruction_cov(struct_processus *s_etat_processus)  instruction_cov(struct_processus *s_etat_processus)
 {  {
     integer8                            nombre_colonnes;  
   
     logical1                            erreur;      logical1                            erreur;
     logical1                            presence_variable;  
   
     long                                i;  
   
     struct_objet                        *s_objet_statistique;      struct_objet                        *s_objet_statistique;
     struct_objet                        *s_objet_resultat;      struct_objet                        *s_objet_resultat;
   
       integer8                            nombre_colonnes;
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
   
     if ((*s_etat_processus).affichage_arguments == 'Y')      if ((*s_etat_processus).affichage_arguments == 'Y')
Line 86  instruction_cov(struct_processus *s_etat Line 83  instruction_cov(struct_processus *s_etat
      * Recherche d'une variable globale référencée par SIGMA       * Recherche d'une variable globale référencée par SIGMA
      */       */
   
     if (recherche_variable(s_etat_processus, ds_sdat) == d_faux)      if (recherche_variable_globale(s_etat_processus, ds_sdat) == d_faux)
     {      {
         /*          /*
          * Aucune variable SIGMA           * Aucune variable SIGMA
Line 98  instruction_cov(struct_processus *s_etat Line 95  instruction_cov(struct_processus *s_etat
     }      }
     else      else
     {      {
         /*          if (((*(*(*s_etat_processus).pointeur_variable_courante).objet)
          * Il existe une variable locale SIGMA. Reste à vérifier l'existence                  .type != MIN) && ((*(*(*s_etat_processus)
          * d'une variable SIGMA globale...                  .pointeur_variable_courante).objet).type != MRL))
          */  
   
         i = (*s_etat_processus).position_variable_courante;  
         presence_variable = d_faux;  
   
         while(i >= 0)  
         {          {
             if ((strcmp((*s_etat_processus).s_liste_variables[i].nom,              (*s_etat_processus).erreur_execution =
                     ds_sdat) == 0) && ((*s_etat_processus)                      d_ex_matrice_statistique_invalide;
                     .s_liste_variables[i].niveau == 1))  
             {  
                 presence_variable = d_vrai;  
                 break;  
             }  
   
             i--;  
         }  
   
         if (presence_variable == d_faux)  
         {  
             (*s_etat_processus).erreur_execution = d_ex_absence_observations;  
             return;              return;
         }          }
         else  
         {  
             (*s_etat_processus).position_variable_courante = i;  
   
             if ((*s_etat_processus).s_liste_variables  
                     [(*s_etat_processus).position_variable_courante].objet  
                     == NULL)  
             {  
                 (*s_etat_processus).erreur_execution = d_ex_variable_partagee;  
                 return;  
             }  
   
             if (((*((*s_etat_processus).s_liste_variables  
                     [(*s_etat_processus).position_variable_courante].objet))  
                     .type != MIN) && ((*((*s_etat_processus)  
                     .s_liste_variables[(*s_etat_processus)  
                     .position_variable_courante].objet)).type != MRL))  
             {  
                 (*s_etat_processus).erreur_execution =  
                         d_ex_matrice_statistique_invalide;  
                 return;  
             }  
   
             nombre_colonnes = (*((struct_matrice *) (*((*s_etat_processus)          nombre_colonnes = (*((struct_matrice *) (*(*(*s_etat_processus)
                     .s_liste_variables[(*s_etat_processus)                  .pointeur_variable_courante).objet).objet)).nombre_colonnes;
                     .position_variable_courante].objet)).objet))  
                     .nombre_colonnes;  
         }  
     }      }
   
     s_objet_statistique = ((*s_etat_processus).s_liste_variables      s_objet_statistique = (*(*s_etat_processus).pointeur_variable_courante)
             [(*s_etat_processus).position_variable_courante]).objet;              .objet;
   
     if (((*s_objet_statistique).type == MIN) ||      if (((*s_objet_statistique).type == MIN) ||
             ((*s_objet_statistique).type == MRL))              ((*s_objet_statistique).type == MRL))
Line 221  void Line 175  void
 instruction_corr(struct_processus *s_etat_processus)  instruction_corr(struct_processus *s_etat_processus)
 {  {
     logical1                            erreur;      logical1                            erreur;
     logical1                            presence_variable;  
   
     long                                i;  
   
     struct_objet                        *s_objet_statistique;      struct_objet                        *s_objet_statistique;
     struct_objet                        *s_objet_resultat;      struct_objet                        *s_objet_resultat;
   
     unsigned long                       nombre_colonnes;      integer8                            nombre_colonnes;
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
   
Line 267  instruction_corr(struct_processus *s_eta Line 218  instruction_corr(struct_processus *s_eta
      * Recherche d'une variable globale référencée par SIGMA       * Recherche d'une variable globale référencée par SIGMA
      */       */
   
     if (recherche_variable(s_etat_processus, ds_sdat) == d_faux)      if (recherche_variable_globale(s_etat_processus, ds_sdat) == d_faux)
     {      {
         /*          /*
          * Aucune variable SIGMA           * Aucune variable SIGMA
Line 279  instruction_corr(struct_processus *s_eta Line 230  instruction_corr(struct_processus *s_eta
     }      }
     else      else
     {      {
         /*          if (((*(*(*s_etat_processus).pointeur_variable_courante).objet)
          * Il existe une variable locale SIGMA. Reste à vérifier l'existence                  .type != MIN) && ((*(*(*s_etat_processus)
          * d'une variable SIGMA globale...                  .pointeur_variable_courante).objet).type != MRL))
          */  
   
         i = (*s_etat_processus).position_variable_courante;  
         presence_variable = d_faux;  
   
         while(i >= 0)  
         {  
             if ((strcmp((*s_etat_processus).s_liste_variables[i].nom,  
                     ds_sdat) == 0) && ((*s_etat_processus)  
                     .s_liste_variables[i].niveau == 1))  
             {  
                 presence_variable = d_vrai;  
                 break;  
             }  
   
             i--;  
         }  
   
         if (presence_variable == d_faux)  
         {          {
             (*s_etat_processus).erreur_execution = d_ex_absence_observations;              (*s_etat_processus).erreur_execution =
                       d_ex_matrice_statistique_invalide;
             return;              return;
         }          }
         else  
         {  
             (*s_etat_processus).position_variable_courante = i;  
   
             if ((*s_etat_processus).s_liste_variables  
                     [(*s_etat_processus).position_variable_courante].objet  
                     == NULL)  
             {  
                 (*s_etat_processus).erreur_execution = d_ex_variable_partagee;  
                 return;  
             }  
   
             if (((*((*s_etat_processus).s_liste_variables          nombre_colonnes = (*((struct_matrice *) (*(*(*s_etat_processus)
                     [(*s_etat_processus).position_variable_courante].objet))                  .pointeur_variable_courante).objet).objet))
                     .type != MIN) && ((*((*s_etat_processus)                  .nombre_colonnes;
                     .s_liste_variables[(*s_etat_processus)  
                     .position_variable_courante].objet)).type != MRL))  
             {  
                 (*s_etat_processus).erreur_execution =  
                         d_ex_matrice_statistique_invalide;  
                 return;  
             }  
   
             nombre_colonnes = (*((struct_matrice *) (*((*s_etat_processus)  
                     .s_liste_variables[(*s_etat_processus)  
                     .position_variable_courante].objet)).objet))  
                     .nombre_colonnes;  
         }  
     }      }
   
     s_objet_statistique = ((*s_etat_processus).s_liste_variables      s_objet_statistique = (*(*s_etat_processus).pointeur_variable_courante)
             [(*s_etat_processus).position_variable_courante]).objet;              .objet;
   
     if (((*s_objet_statistique).type == MIN) ||      if (((*s_objet_statistique).type == MIN) ||
             ((*s_objet_statistique).type == MRL))              ((*s_objet_statistique).type == MRL))
Line 463  instruction_convert(struct_processus *s_ Line 372  instruction_convert(struct_processus *s_
   
     logical1                    last_valide;      logical1                    last_valide;
   
     long                        longueur_chaine;      size_t                      longueur_chaine;
   
     logical1                    presence_resultat;      logical1                    presence_resultat;
   
Line 562  instruction_convert(struct_processus *s_ Line 471  instruction_convert(struct_processus *s_
                     (unsigned char *) (*s_objet_argument_2).objet,                      (unsigned char *) (*s_objet_argument_2).objet,
                     (unsigned char *) (*s_objet_argument_1).objet);                      (unsigned char *) (*s_objet_argument_1).objet);
   
             if (alsprintf(&executable_candidat, "%s/bin/rplconvert",              if (alsprintf(s_etat_processus, &executable_candidat,
                     d_exec_path) < 0)                      "%s/bin/rplconvert", d_exec_path) < 0)
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                 return;                  return;
             }              }
   
             if (controle(s_etat_processus, executable_candidat, "md5",              if (controle_integrite(s_etat_processus, executable_candidat,
                     rplconvert_md5) != d_vrai)                      "rplconvert") != d_vrai)
             {  
                 (*s_etat_processus).erreur_systeme = d_es_somme_controle;  
                 return;  
             }  
   
             if (controle(s_etat_processus, executable_candidat, "sha1",  
                     rplconvert_sha1) != d_vrai)  
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_somme_controle;                  (*s_etat_processus).erreur_systeme = d_es_somme_controle;
                 return;                  return;
Line 604  instruction_convert(struct_processus *s_ Line 506  instruction_convert(struct_processus *s_
                     (unsigned char *) (*s_objet_argument_2).objet,                      (unsigned char *) (*s_objet_argument_2).objet,
                     (unsigned char *) (*s_objet_argument_1).objet);                      (unsigned char *) (*s_objet_argument_1).objet);
   
             if (alsprintf(&executable_candidat, "%s/bin/rplconvert",              if (alsprintf(s_etat_processus, &executable_candidat,
                     (*s_etat_processus).rpl_home) < 0)                      "%s/bin/rplconvert", (*s_etat_processus).rpl_home) < 0)
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                 return;                  return;
             }              }
   
             if (controle(s_etat_processus, executable_candidat, "md5",              if (controle_integrite(s_etat_processus, executable_candidat,
                     rplconvert_md5) != d_vrai)                      "rplconvert") != d_vrai)
             {  
                 (*s_etat_processus).erreur_systeme = d_es_somme_controle;  
                 return;  
             }  
   
             if (controle(s_etat_processus, executable_candidat, "sha1",  
                     rplconvert_sha1) != d_vrai)  
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_somme_controle;                  (*s_etat_processus).erreur_systeme = d_es_somme_controle;
                 return;                  return;
Line 654  instruction_convert(struct_processus *s_ Line 549  instruction_convert(struct_processus *s_
                             (*s_etat_processus).instruction_courante;                              (*s_etat_processus).instruction_courante;
                     (*s_etat_processus).instruction_courante = ligne;                      (*s_etat_processus).instruction_courante = ligne;
   
                       (*s_etat_processus).type_en_cours = NON;
                     recherche_type(s_etat_processus);                      recherche_type(s_etat_processus);
                                           
                     (*s_etat_processus).instruction_courante =                      (*s_etat_processus).instruction_courante =
Line 1190  instruction_cswp(struct_processus *s_eta Line 1086  instruction_cswp(struct_processus *s_eta
     struct_objet                *s_objet_argument_2;      struct_objet                *s_objet_argument_2;
     struct_objet                *s_objet_argument_3;      struct_objet                *s_objet_argument_3;
   
     signed long                 colonne_1;      integer8                    colonne_1;
     signed long                 colonne_2;      integer8                    colonne_2;
       integer8                    i;
     unsigned long               i;  
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
   
Line 1265  instruction_cswp(struct_processus *s_eta Line 1160  instruction_cswp(struct_processus *s_eta
   
         if ((*s_objet_argument_3).type == MIN)          if ((*s_objet_argument_3).type == MIN)
         {          {
             if ((colonne_1 < 0) || (colonne_1 > ((signed long)              if ((colonne_1 < 0) || (colonne_1 >
                     (*((struct_matrice *) (*s_objet_argument_3).objet))                      (*((struct_matrice *) (*s_objet_argument_3).objet))
                     .nombre_colonnes) - 1) || (colonne_2 < 0) || (colonne_2 >                      .nombre_colonnes - 1) || (colonne_2 < 0) || (colonne_2 >
                     ((signed long) (*((struct_matrice *)                      (*((struct_matrice *)
                     (*s_objet_argument_3).objet)).nombre_colonnes) - 1))                      (*s_objet_argument_3).objet)).nombre_colonnes - 1))
             {              {
                 liberation(s_etat_processus, s_objet_argument_1);                  liberation(s_etat_processus, s_objet_argument_1);
                 liberation(s_etat_processus, s_objet_argument_2);                  liberation(s_etat_processus, s_objet_argument_2);
Line 1302  instruction_cswp(struct_processus *s_eta Line 1197  instruction_cswp(struct_processus *s_eta
         }          }
         else if ((*s_objet_argument_3).type == MRL)          else if ((*s_objet_argument_3).type == MRL)
         {          {
             if ((colonne_1 < 0) || (colonne_1 > ((signed long)              if ((colonne_1 < 0) || (colonne_1 >
                     (*((struct_matrice *) (*s_objet_argument_3).objet))                      (*((struct_matrice *) (*s_objet_argument_3).objet))
                     .nombre_colonnes) - 1) || (colonne_2 < 0) || (colonne_2 >                      .nombre_colonnes - 1) || (colonne_2 < 0) || (colonne_2 >
                     ((signed long) (*((struct_matrice *)                      (*((struct_matrice *)
                     (*s_objet_argument_3).objet)).nombre_colonnes) - 1))                      (*s_objet_argument_3).objet)).nombre_colonnes - 1))
             {              {
                 liberation(s_etat_processus, s_objet_argument_1);                  liberation(s_etat_processus, s_objet_argument_1);
                 liberation(s_etat_processus, s_objet_argument_2);                  liberation(s_etat_processus, s_objet_argument_2);
Line 1339  instruction_cswp(struct_processus *s_eta Line 1234  instruction_cswp(struct_processus *s_eta
         }          }
         else if ((*s_objet_argument_3).type == MCX)          else if ((*s_objet_argument_3).type == MCX)
         {          {
             if ((colonne_1 < 0) || (colonne_1 > ((signed long)              if ((colonne_1 < 0) || (colonne_1 >
                     (*((struct_matrice *) (*s_objet_argument_3).objet))                      (*((struct_matrice *) (*s_objet_argument_3).objet))
                     .nombre_colonnes) - 1) || (colonne_2 < 0) || (colonne_2 >                      .nombre_colonnes - 1) || (colonne_2 < 0) || (colonne_2 >
                     ((signed long) (*((struct_matrice *)                      (*((struct_matrice *)
                     (*s_objet_argument_3).objet)).nombre_colonnes) - 1))                      (*s_objet_argument_3).objet)).nombre_colonnes - 1))
             {              {
                 liberation(s_etat_processus, s_objet_argument_1);                  liberation(s_etat_processus, s_objet_argument_1);
                 liberation(s_etat_processus, s_objet_argument_2);                  liberation(s_etat_processus, s_objet_argument_2);

Removed from v.1.15  
changed lines
  Added in v.1.79


CVSweb interface <joel.bertrand@systella.fr>