# HG changeset patch # User tron # Date 1157010740 0 # Node ID be6ec1c0ed04e1a2b9b33ed26411888071e6ea96 # Parent 746e4c471044d92c8986314942f417f4bdebb240 (svn r6257) Use memcmp() to check the MD5 sum instead of using a home brewed loop diff --git a/gfxinit.c b/gfxinit.c --- a/gfxinit.c +++ b/gfxinit.c @@ -13,6 +13,7 @@ #include "newgrf.h" #include "md5.h" #include "variables.h" +#include typedef struct MD5File { const char * const filename; // filename @@ -96,18 +97,9 @@ /* Check that the supplied MD5 hash matches that stored for the supplied filename */ static bool CheckMD5Digest(const MD5File file, md5_byte_t *digest, bool warn) { - uint i; - - /* Loop through each byte of the file MD5 and the stored MD5... */ - for (i = 0; i < 16; i++) if (file.hash[i] != digest[i]) break; - - /* If all bytes of the MD5's match (i.e. the MD5's match)... */ - if (i == 16) { - return true; - } else { - if (warn) fprintf(stderr, "MD5 of %s is ****INCORRECT**** - File Corrupt.\n", file.filename); - return false; - }; + if (memcmp(file.hash, digest, sizeof(file.hash)) == 0) return true; + if (warn) fprintf(stderr, "MD5 of %s is ****INCORRECT**** - File Corrupt.\n", file.filename); + return false; } /* Calculate and check the MD5 hash of the supplied filename.