summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrubidium <rubidium@openttd.org>2010-05-21 15:56:19 +0000
committerrubidium <rubidium@openttd.org>2010-05-21 15:56:19 +0000
commite3df7caf18e6260dad84b8e4dd09f11886fbbe0e (patch)
treeb4f47a5188725c0bc8c66f8b5d14a59bf24707be
parentd8d37466afe02034fef2447a81fe4fe2469d352b (diff)
downloadopenttd-e3df7caf18e6260dad84b8e4dd09f11886fbbe0e.tar.xz
(svn r19874) -Fix [FS#3845]: NetBSD compilation was still broken in some cases (Krille)
-rw-r--r--src/string.cpp4
-rw-r--r--src/string_func.h7
2 files changed, 7 insertions, 4 deletions
diff --git a/src/string.cpp b/src/string.cpp
index 58ac00a6c..4ed2da129 100644
--- a/src/string.cpp
+++ b/src/string.cpp
@@ -398,7 +398,7 @@ size_t Utf8TrimString(char *s, size_t maxlen)
return length;
}
-#ifndef _GNU_SOURCE
+#ifdef DEFINE_STRNDUP
#include "core/math_func.hpp"
char *strndup(const char *s, size_t len)
{
@@ -407,7 +407,7 @@ char *strndup(const char *s, size_t len)
memcpy(tmp, s, len);
return tmp;
}
-#endif /* !_GNU_SOURCE */
+#endif /* DEFINE_STRNDUP */
#ifdef DEFINE_STRCASESTR
char *strcasestr(const char *haystack, const char *needle)
diff --git a/src/string_func.h b/src/string_func.h
index 7787ee57c..f921397a0 100644
--- a/src/string_func.h
+++ b/src/string_func.h
@@ -251,10 +251,13 @@ static inline bool IsWhitespace(WChar c)
#include <sys/param.h>
#endif
-#if !defined(_GNU_SOURCE) && !(defined(__NetBSD_Version__) && 400000000 < __NetBSD_Version__ )
/* strndup is a GNU extension */
+#if defined(_GNU_SOURCE) || (defined(__NetBSD_Version__) && 400000000 <= __NetBSD_Version__)
+# undef DEFINE_STRNDUP
+#else
+# define DEFINE_STRNDUP
char *strndup(const char *s, size_t len);
-#endif /* !_GNU_SOURCE */
+#endif /* strndup is available */
/* strcasestr is available for _GNU_SOURCE, BSD and some Apple */
#if defined(_GNU_SOURCE) || (defined(__BSD_VISIBLE) && __BSD_VISIBLE) || (defined(__APPLE__) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))) || defined(_NETBSD_SOURCE)