From 196777f3d8e32cc243ade0f8e5bf7d653da78ef4 Mon Sep 17 00:00:00 2001 From: Charles Hannum Date: Thu, 21 Nov 1996 20:47:59 +0000 Subject: gethostbyname() may return a pointer to static data, which is overwritten deep inside krb_realmofhost(). Copy the host name to avoid conflicts. --- lib-src/pop.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'lib-src') diff --git a/lib-src/pop.c b/lib-src/pop.c index 5657df5a5d0..c4d4c26e5ef 100644 --- a/lib-src/pop.c +++ b/lib-src/pop.c @@ -1005,6 +1005,7 @@ socket_connection (host, flags) CREDENTIALS cred; Key_schedule schedule; int rem; + char *realhost; #endif /* KRB5 */ #endif /* KERBEROS */ @@ -1175,8 +1176,9 @@ socket_connection (host, flags) } #else /* ! KRB5 */ ticket = (KTEXT) malloc (sizeof (KTEXT_ST)); - rem = krb_sendauth (0L, sock, ticket, "pop", hostent->h_name, - (char *) krb_realmofhost (hostent->h_name), + realhost = strdup (hostent->h_name); + rem = krb_sendauth (0L, sock, ticket, "pop", realhost, + (char *) krb_realmofhost (realhost), (unsigned long) 0, &msg_data, &cred, schedule, (struct sockaddr_in *) 0, (struct sockaddr_in *) 0, -- cgit v1.2.1