Diff for /rpl/rplsums/rplsum.c between versions 1.8 and 1.9

version 1.8, 2015/01/30 08:00:12 version 1.9, 2016/09/27 09:21:58
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.12    RPL/2 (R) version 4.1.25
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2015 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 30 Line 30
 int  int
 main(int argc, char *argv[])  main(int argc, char *argv[])
 {  {
     EVP_MD_CTX          contexte;      EVP_MD_CTX          *contexte;
   
     int                 in_fd;      int                 in_fd;
   
Line 97  main(int argc, char *argv[]) Line 97  main(int argc, char *argv[])
   
     close(in_fd);      close(in_fd);
   
     if (EVP_DigestInit(&contexte, EVP_sum()) != 1)      if ((contexte = EVP_MD_CTX_new()) == NULL)
       {
           fprintf(stderr, "EVP_MD_CTX_new() failed\n");
           close(in_fd);
           free(chaine);
           exit(EXIT_FAILURE);
       }
   
       if (EVP_DigestInit(contexte, EVP_sum()) != 1)
     {      {
         fprintf(stderr, "EVP_DigestInit() failed\n");          fprintf(stderr, "EVP_DigestInit() failed\n");
           EVP_MD_CTX_free(contexte);
         close(in_fd);          close(in_fd);
         free(chaine);          free(chaine);
         exit(EXIT_FAILURE);          exit(EXIT_FAILURE);
     }      }
   
     if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1)      if (EVP_DigestUpdate(contexte, chaine, taille_fichier) != 1)
     {      {
         fprintf(stderr, "EVP_DigestUpdate() failed\n");          fprintf(stderr, "EVP_DigestUpdate() failed\n");
           EVP_MD_CTX_free(contexte);
         close(in_fd);          close(in_fd);
         free(chaine);          free(chaine);
         exit(EXIT_FAILURE);          exit(EXIT_FAILURE);
     }      }
   
     if (EVP_DigestFinal_ex(&contexte, somme, &longueur_somme) != 1)      if (EVP_DigestFinal_ex(contexte, somme, &longueur_somme) != 1)
     {      {
         fprintf(stderr, "EVP_DigestFinal_ex() failed\n");          fprintf(stderr, "EVP_DigestFinal_ex() failed\n");
           EVP_MD_CTX_free(contexte);
         close(in_fd);          close(in_fd);
         free(chaine);          free(chaine);
         exit(EXIT_FAILURE);          exit(EXIT_FAILURE);
     }      }
   
     EVP_MD_CTX_cleanup(&contexte);      EVP_MD_CTX_free(contexte);
     free(chaine);      free(chaine);
   
     for(i = 0; i < longueur_somme; i++)      for(i = 0; i < longueur_somme; i++)

Removed from v.1.8  
changed lines
  Added in v.1.9


CVSweb interface <joel.bertrand@systella.fr>