Diff for /rpl/src/controle.c between versions 1.1 and 1.47

version 1.1, 2010/03/04 17:42:46 version 1.47, 2013/09/06 10:30:50
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.12    RPL/2 (R) version 4.1.16
   Copyright (C) 1989-2010 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 20 Line 20
 */  */
   
   
 #include "rpl.conv.h"  #include "rpl-conv.h"
   
   
 /*  /*
 ================================================================================  ================================================================================
   Calcul des sommes de contrôle avant le lancement d'un exécutable    Calcul des sommes de contrôle avant le lancement d'un exécutable
   de la famille RPL/2 (rpliconv, rplconvert, rplfile et rplpp).    de la famille RPL/2 (rpliconv, rplconvert, rplfile et rplpp).
 ================================================================================  ================================================================================
   Entrée :    Entrée :
     - chaîne de caractères sur le fichier à contrôler      - chaîne de caractères sur le fichier à contrôler
     - chaîne de caractères contenant la somme à contrôler      - chaîne de caractères contenant la somme à contrôler
     - type de somme de contrôle      - type de somme de contrôle
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
   Sortie : drapeau    Sortie : drapeau
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
   Effets de bord : néant    Effets de bord : néant
 ================================================================================  ================================================================================
 */  */
   
   
 logical1  logical1
 controle(struct_processus *s_etat_processus, unsigned char *fichier,  controle(struct_processus *s_etat_processus, unsigned char *fichier,
         unsigned char *type, unsigned char *somme_candidate)          unsigned char *type, unsigned char *somme_candidate)
 {  {
     EVP_MD_CTX          contexte;      EVP_MD_CTX          contexte;
   
     int                 i_rval = 0;      int                 in_fd;
     int                 in_fd = -1;  
   
     logical1            drapeau;      logical1            drapeau;
   
Line 58  controle(struct_processus *s_etat_proces Line 56  controle(struct_processus *s_etat_proces
     struct stat         stat_buf;      struct stat         stat_buf;
   
     unsigned char       *chaine;      unsigned char       *chaine;
       unsigned char       *registre;
     unsigned char       somme[EVP_MAX_MD_SIZE];      unsigned char       somme[EVP_MAX_MD_SIZE];
     unsigned char       somme_hexadecimale[2 * EVP_MAX_MD_SIZE];      unsigned char       somme_hexadecimale[2 * EVP_MAX_MD_SIZE];
   
     unsigned int        i;      unsigned int        i;
     unsigned int        longueur_somme;      unsigned int        longueur_somme;
   
     i_rval = stat(fichier, &stat_buf);      registre = fichier;
   
   #   ifdef OS2
       unsigned char       *tampon;
   
       if ((tampon = malloc((strlen(fichier) + 5) * sizeof(unsigned char)))
               == NULL)
       {
           (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
           return(d_faux);
       }
   
       sprintf(tampon, "%s.exe", fichier);
       fichier = tampon;
   #   endif
   
       if (stat(fichier, &stat_buf) != 0)
       {
   #       ifdef OS2
           free(fichier);
   #       endif
   
           (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
           return(d_faux);
       }
   
     taille_fichier = stat_buf.st_size;      taille_fichier = stat_buf.st_size;
   
     if ((chaine = malloc(taille_fichier)) == NULL)      if ((chaine = malloc((size_t) taille_fichier)) == NULL)
     {      {
   #       ifdef OS2
           free(fichier);
   #       endif
   
         (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;          (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
         return(d_faux);          return(d_faux);
     }      }
   
     if ((in_fd = open(fichier, 0, O_RDONLY)) < 0)      if ((in_fd = open(fichier, 0, O_RDONLY)) < 0)
     {      {
   #       ifdef OS2
           free(fichier);
   #       endif
   
         free(chaine);          free(chaine);
   
         (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;          (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
         return(d_faux);          return(d_faux);
     }      }
   
     if ((octets_lus = read(in_fd, chaine, taille_fichier)) != taille_fichier)  #   ifdef OS2
       free(fichier);
   #   endif
   
       if ((octets_lus = read(in_fd, chaine, (size_t) taille_fichier))
               != (ssize_t) taille_fichier)
     {      {
   #       ifndef OS2
         close(in_fd);          close(in_fd);
         free(chaine);          free(chaine);
   
         (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;          (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
         return(d_faux);          return(d_faux);
   #       endif
     }      }
   
     close(in_fd);      close(in_fd);
Line 103  controle(struct_processus *s_etat_proces Line 142  controle(struct_processus *s_etat_proces
             return(d_faux);              return(d_faux);
         }          }
   
         if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1)          if (EVP_DigestUpdate(&contexte, chaine, (size_t) taille_fichier) != 1)
         {          {
             close(in_fd);              close(in_fd);
             free(chaine);              free(chaine);
Line 132  controle(struct_processus *s_etat_proces Line 171  controle(struct_processus *s_etat_proces
             return(d_faux);              return(d_faux);
         }          }
   
         if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1)          if (EVP_DigestUpdate(&contexte, chaine, (size_t) taille_fichier) != 1)
         {          {
             close(in_fd);              close(in_fd);
             free(chaine);              free(chaine);
Line 150  controle(struct_processus *s_etat_proces Line 189  controle(struct_processus *s_etat_proces
             return(d_faux);              return(d_faux);
         }          }
     }      }
       else
       {
           return(d_faux);
       }
   
     EVP_MD_CTX_cleanup(&contexte);      EVP_MD_CTX_cleanup(&contexte);
     free(chaine);      free(chaine);
Line 165  controle(struct_processus *s_etat_proces Line 208  controle(struct_processus *s_etat_proces
     }      }
     else      else
     {      {
           if ((*s_etat_processus).langue == 'F')
           {
               printf("+++Fatal : Somme de contrôle invalide\n");
               printf("Fonction %s(%s)\n", type, registre);
               printf("Résultat obtenu  : %s\n", somme_hexadecimale);
               printf("Résultat attendu : %s\n", somme_candidate);
           }
           else
           {
               printf("+++Fatal : Hash code mismatch\n");
               printf("Function %s(%s)\n", type, registre);
               printf("Computed hash code : %s\n", somme_hexadecimale);
               printf("Expected hash code : %s\n", somme_candidate);
           }
   
         drapeau = d_faux;          drapeau = d_faux;
     }      }
   

Removed from v.1.1  
changed lines
  Added in v.1.47


CVSweb interface <joel.bertrand@systella.fr>