From ea59b8486a5049be06260c655c6e863276a45deb Mon Sep 17 00:00:00 2001 From: thilo Date: Sat, 17 May 2008 10:46:41 +0000 Subject: - Workaround for buggy MacOSX getaddrinfo() implementation that doesn't accept AF_UNSPEC parameter in hints structure. Thanks icculus for reporting. - Add -faltivec flag for debug builds. git-svn-id: svn://svn.icculus.org/quake3/trunk@1344 edf5b092-35ff-0310-97b2-ce42778d08ea --- code/qcommon/net_ip.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'code/qcommon/net_ip.c') diff --git a/code/qcommon/net_ip.c b/code/qcommon/net_ip.c index a2960c4..cb2094e 100644 --- a/code/qcommon/net_ip.c +++ b/code/qcommon/net_ip.c @@ -266,12 +266,20 @@ Sys_StringToSockaddr static qboolean Sys_StringToSockaddr(const char *s, struct sockaddr *sadr, int sadr_len, sa_family_t family) { struct addrinfo hints, *res = NULL, *search; + struct addrinfo *hintsp; int retval; memset(sadr, '\0', sizeof(*sadr)); memset(&hints, '\0', sizeof(hints)); - - hints.ai_family = family; + + // workaround for buggy MacOSX getaddrinfo implementation that doesn't handle AF_UNSPEC in hints correctly. + if(family == AF_UNSPEC) + hintsp = NULL; + else + { + hintsp = &hints; + hintsp->ai_family = family; + } retval = getaddrinfo(s, NULL, &hints, &res); -- cgit v1.2.3