summaryrefslogtreecommitdiffstats
path: root/configure.in.in
diff options
context:
space:
mode:
authorSlávek Banko <slavek.banko@axis.cz>2019-10-30 19:30:37 +0100
committerSlávek Banko <slavek.banko@axis.cz>2019-10-30 19:30:37 +0100
commit82895daec0ccb16c14b98e1b21b49dd71d68dd2f (patch)
tree0c7eccacd0e63b42647ea61a724eb2a8bf9c85bb /configure.in.in
parentfa4a35fd4b069bde6cc6d924f18376096b644737 (diff)
downloadkoffice-82895daec0ccb16c14b98e1b21b49dd71d68dd2f.tar.gz
koffice-82895daec0ccb16c14b98e1b21b49dd71d68dd2f.zip
Add check whether OpenEXR requires explicit specification of C++ standard.
Signed-off-by: Slávek Banko <slavek.banko@axis.cz>
Diffstat (limited to 'configure.in.in')
-rw-r--r--configure.in.in33
1 files changed, 32 insertions, 1 deletions
diff --git a/configure.in.in b/configure.in.in
index 01eed782..fcc96492 100644
--- a/configure.in.in
+++ b/configure.in.in
@@ -288,6 +288,37 @@ fi
if test -n "$OPENEXR_LIBS"
then
AC_MSG_RESULT([yes])
+
+ AC_LANG_SAVE
+ AC_LANG_CPLUSPLUS
+ SAVED_CXXFLAGS="$CXXFLAGS"
+ for CXX_STD_TEST in "" 11 14 17; do
+ CXXFLAGS="$SAVED_CXXFLAGS"
+ if test "x$CXX_STD_TEST" = "x"; then
+ AC_MSG_CHECKING([OpenEXR build with default C++ standard])
+ OPENEXR_CXXFLAGS=""
+ else
+ AC_MSG_CHECKING([OpenEXR build with C++$CXX_STD_TEST])
+ OPENEXR_CXXFLAGS="-std=c++$CXX_STD_TEST"
+ fi
+ CXXFLAGS="$SAVED_CXXFLAGS $OPENEXR_CFLAGS $OPENEXR_CXXFLAGS"
+ AC_TRY_COMPILE([
+ #include <ImfRgbaFile.h>
+ ],[ ],
+ openexr_cxx_std=yes,
+ openexr_cxx_std=no
+ )
+ if test "x$openexr_cxx_std" = "xyes"; then
+ AC_SUBST(OPENEXR_CXXFLAGS)
+ AC_MSG_RESULT(yes)
+ break
+ else
+ AC_MSG_RESULT(no)
+ fi
+ done
+ CXXFLAGS="$SAVED_CXXFLAGS"
+ AC_LANG_RESTORE
+
else
AC_MSG_RESULT([not found])
fi
@@ -296,6 +327,6 @@ AC_SUBST(OPENEXR_LIBS)
AC_SUBST(OPENEXR_CFLAGS)
AC_SUBST(OPENEXR_RPATH)
-AM_CONDITIONAL(have_openexr, test -n "$OPENEXR_LIBS")
+AM_CONDITIONAL(have_openexr, test "x$openexr_cxx_std" = "xyes")
# --- End of OpenEXR check ---