summaryrefslogtreecommitdiff
path: root/configure
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2013-11-14 12:19:04 +0100
committerAnton Khirnov <anton@khirnov.net>2014-03-10 10:27:17 +0100
commite854b8f9f4097a3c560b746895e9da6721aa4cdb (patch)
tree003241c26cefa79a5cbd2c27a462c42022ea9109 /configure
parent8cafeb8bca5d079041739dbd72ccec0ead138eaf (diff)
Work around broken floating point limits on some systems.
The values of {FLT,DBL}_{MAX,MIN} macros on some systems (older musl libc, some BSD flavours) are not exactly representable, i.e. (double)DBL_MAX == DBL_MAX is false This violates (at least some interpretations of) the C99 standard and breaks code (e.g. in vf_fps) like double f = DBL_MAX; [...] if (f == DBL_MAX) { // f has not been changed yet [....] }
Diffstat (limited to 'configure')
-rwxr-xr-xconfigure14
1 files changed, 14 insertions, 0 deletions
diff --git a/configure b/configure
index 766df998f7..c98f0bd883 100755
--- a/configure
+++ b/configure
@@ -994,6 +994,16 @@ check_builtin(){
check_code ld "$headers" "$builtin" "$@" && enable "$name"
}
+check_compile_assert(){
+ log check_compile_assert "$@"
+ name=$1
+ headers=$2
+ condition=$3
+ shift 3
+ disable "$name"
+ check_code cc "$headers" "char c[2 * !!($condition) - 1]" "$@" && enable "$name"
+}
+
require(){
name="$1"
header="$2"
@@ -1360,6 +1370,7 @@ HAVE_LIST="
fast_clz
fast_cmov
fcntl
+ flt_lim
fork
getaddrinfo
gethrtime
@@ -3536,6 +3547,9 @@ if enabled_all ccc libc_glibc; then
add_ldflags -Wl,-z,now # calls to libots crash without this
fi
+check_compile_assert flt_lim "float.h limits.h" "DBL_MAX == (double)DBL_MAX" ||
+ add_cppflags '-I\$(SRC_PATH)/compat/float'
+
esc(){
echo "$*" | sed 's/%/%25/g;s/:/%3a/g'
}