From: Daniel Stenberg Date: Thu, 27 May 2004 06:42:48 +0000 (+0000) Subject: James Bursa's fix to prevent free(NULL) to occur X-Git-Tag: curl-7_12_0~12 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=ff0429a802365250d4e47df718f431284c023aa8;p=thirdparty%2Fcurl.git James Bursa's fix to prevent free(NULL) to occur --- diff --git a/ares/ares__get_hostent.c b/ares/ares__get_hostent.c index ecba75c927..f05d712991 100644 --- a/ares/ares__get_hostent.c +++ b/ares/ares__get_hostent.c @@ -140,7 +140,8 @@ int ares__get_hostent(FILE *fp, struct hostent **host) memcpy(hostent->h_addr_list[0], &addr, sizeof(struct in_addr)); hostent->h_addr_list[1] = NULL; *host = hostent; - free(line); + if(line) + free(line); return ARES_SUCCESS; } free(line); @@ -150,18 +151,21 @@ int ares__get_hostent(FILE *fp, struct hostent **host) /* Memory allocation failure; clean up. */ if (hostent) { - free((char *) hostent->h_name); + if(hostent->h_name) + free((char *) hostent->h_name); if (hostent->h_aliases) { for (alias = hostent->h_aliases; *alias; alias++) free(*alias); } - free(hostent->h_aliases); + if(hostent->h_aliases) + free(hostent->h_aliases); if (hostent->h_addr_list) free(hostent->h_addr_list[0]); - free(hostent->h_addr_list); + if(hostent->h_addr_list) + free(hostent->h_addr_list); + free(hostent); } - free(hostent); return ARES_ENOMEM; }