From: Thomas Petazzoni Date: Fri, 1 May 2015 10:52:18 +0000 (+0200) Subject: Link against libm when needed X-Git-Tag: json-c-0.13-20171207~194^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F182%2Fhead;p=thirdparty%2Fjson-c.git Link against libm when needed In certain C libraries (e.g uClibc), isnan() and related functions are implemented in libm, so json-c needs to link against it. This commit therefore adds an AC_TRY_LINK() test to check whether a program calling isnan() can be properly linked with no special flags. If not, we assume linking against libm is needed. The json-c.pc.in file is also adjusted so that in the case of static linking against json-c, -lm is also used. Signed-off-by: Thomas Petazzoni --- diff --git a/configure.ac b/configure.ac index c50f81bd..30e71745 100644 --- a/configure.ac +++ b/configure.ac @@ -50,6 +50,10 @@ AC_CHECK_DECLS([isinf], [], [], [[#include ]]) AC_CHECK_DECLS([_isnan], [], [], [[#include ]]) AC_CHECK_DECLS([_finite], [], [], [[#include ]]) +if test "$ac_cv_have_decl_isnan" = "yes" ; then + AC_TRY_LINK([#include ], [float f = 0.0; return isnan(f)], [], [LIBS="$LIBS -lm"]) +fi + #check if .section.gnu.warning accepts long strings (for __warn_references) AC_LANG_PUSH([C]) diff --git a/json-c.pc.in b/json-c.pc.in index 037739d2..05bfbc8c 100644 --- a/json-c.pc.in +++ b/json-c.pc.in @@ -6,6 +6,7 @@ includedir=@includedir@ Name: json-c Description: JSON implementation in C Version: @VERSION@ -Requires: +Requires: +Libs.private: @LIBS@ Libs: -L${libdir} -ljson-c Cflags: -I${includedir}/json-c