lkundrak / rpms / sendmail

Forked from rpms/sendmail 4 years ago
Clone
048b886
diff --git a/libmilter/sm_gethost.c b/libmilter/sm_gethost.c
048b886
index a025c8f..cd0ef31 100644
048b886
--- a/libmilter/sm_gethost.c
048b886
+++ b/libmilter/sm_gethost.c
048b886
@@ -49,8 +49,16 @@ sm_getipnodebyname(name, family, flags, err)
048b886
 	int flags;
048b886
 	int *err;
048b886
 {
048b886
-	bool resv6 = true;
048b886
 	struct hostent *h;
048b886
+# if HAS_GETHOSTBYNAME2
048b886
+
048b886
+	h = gethostbyname2(name, family);
048b886
+	if (h == NULL)
048b886
+		*err = h_errno;
048b886
+	return h;
048b886
+
048b886
+# else /* HAS_GETHOSTBYNAME2 */
048b886
+	bool resv6 = true;
048b886
 
048b886
 	if (family == AF_INET6)
048b886
 	{
048b886
@@ -60,7 +68,7 @@ sm_getipnodebyname(name, family, flags, err)
048b886
 	}
048b886
 	SM_SET_H_ERRNO(0);
048b886
 	h = gethostbyname(name);
048b886
-	if (family == AF_INET6 && !resv6)
048b886
+	if (!resv6)
048b886
 		_res.options &= ~RES_USE_INET6;
048b886
 
048b886
 	/* the function is supposed to return only the requested family */
048b886
@@ -75,6 +83,7 @@ sm_getipnodebyname(name, family, flags, err)
048b886
 	else
048b886
 		*err = h_errno;
048b886
 	return h;
048b886
+# endif /* HAS_GETHOSTBYNAME2 */
048b886
 }
048b886
 
048b886
 void