X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fcanon-host.c;h=74c36f6f75b7bf11b07ac74c38ea4dc5bfc8efdd;hb=4b4109233097408185555b472eb302c8d3da33b9;hp=180057c3fff08ac1af70aa25651026ecd4831c8e;hpb=eeedc1da55cffb2f03fe8eaaad1a595ed698d668;p=gnulib.git diff --git a/lib/canon-host.c b/lib/canon-host.c index 180057c3f..74c36f6f7 100644 --- a/lib/canon-host.c +++ b/lib/canon-host.c @@ -26,6 +26,9 @@ #ifdef HAVE_UNISTD_H # include #endif +#ifdef HAVE_STDLIB_H +# include +#endif #ifdef HAVE_STRING_H # include #endif @@ -46,7 +49,6 @@ #ifndef strdup char *strdup (); #endif -void free (); /* Returns the canonical hostname associated with HOST (allocated in a static buffer), or 0 if it can't be determined. */ @@ -80,11 +82,12 @@ canon_host (const char *host) directly to gethostbyaddr because on some systems he->h_addr is located in a static library buffer that is reused in the gethostbyaddr call. Make a copy and use that instead. */ - char *h_addr_copy = strdup (he->h_addr); + char *h_addr_copy = (char *) malloc (he->h_length); if (h_addr_copy == NULL) he = NULL; else { + memcpy (h_addr_copy, he->h_addr, he->h_length); he = gethostbyaddr (h_addr_copy, he->h_length, he->h_addrtype); free (h_addr_copy); }