--- rpl/src/controle.c 2010/04/21 13:45:44 1.5 +++ rpl/src/controle.c 2016/03/01 22:12:26 1.58 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.0.15 - Copyright (C) 1989-2010 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.25 + Copyright (C) 1989-2016 Dr. BERTRAND Joël This file is part of RPL/2. @@ -20,7 +20,7 @@ */ -#include "rpl.conv.h" +#include "rpl-conv.h" /* @@ -56,41 +56,77 @@ controle(struct_processus *s_etat_proces struct stat stat_buf; unsigned char *chaine; + unsigned char *registre; unsigned char somme[EVP_MAX_MD_SIZE]; unsigned char somme_hexadecimale[2 * EVP_MAX_MD_SIZE]; unsigned int i; unsigned int longueur_somme; + 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; - 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; return(d_faux); } if ((in_fd = open(fichier, 0, O_RDONLY)) < 0) { +# ifdef OS2 + free(fichier); +# endif + free(chaine); (*s_etat_processus).erreur_systeme = d_es_erreur_fichier; 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); free(chaine); (*s_etat_processus).erreur_systeme = d_es_erreur_fichier; return(d_faux); +# endif } close(in_fd); @@ -106,7 +142,7 @@ controle(struct_processus *s_etat_proces return(d_faux); } - if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1) + if (EVP_DigestUpdate(&contexte, chaine, (size_t) taille_fichier) != 1) { close(in_fd); free(chaine); @@ -135,7 +171,7 @@ controle(struct_processus *s_etat_proces return(d_faux); } - if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1) + if (EVP_DigestUpdate(&contexte, chaine, (size_t) taille_fichier) != 1) { close(in_fd); free(chaine); @@ -172,6 +208,21 @@ controle(struct_processus *s_etat_proces } 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; }