Blame sendmail-8.15.2-gethostbyname2.patch
|
|
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
|