From e61c9672d1df2e9dac0667520ecd44202fafa78d Mon Sep 17 00:00:00 2001 From: Vladimir Tamara Date: Thu, 26 Mar 2020 13:19:32 -0500 Subject: [PATCH] By default use CXX11, however if it works use CXX17. Fixes #115 simplify --- configure | 40 ++++++++++++++++++++++++++++++++++++++-- src/Makevars.in | 3 +-- 2 files changed, 39 insertions(+), 4 deletions(-) diff --git a/configure b/configure index 85c118c9..d2aa6aac 100755 --- a/configure +++ b/configure @@ -3,7 +3,7 @@ echo "Running configure script" # Find compiler -CC=$("${R_HOME}"/bin/R CMD config CC) +CC=`"${R_HOME}"/bin/R CMD config CC` # Detect whether -latomic is needed during linking. This is needed on some # platforms, notably ARM (Raspberry Pi). @@ -21,8 +21,44 @@ else fi +# By defalt CXX_STD is CXX11 +CXX_STD=CXX11 + +# But if it works, use CXX17 +CXX=`"${R_HOME}"/bin/R CMD config CXX` +CXX17STD=`"${R_HOME}"/bin/R CMD config CXX17STD` +CXX17FLAGS=`"${R_HOME}"/bin/R CMD config CXX17FLAGS` +if [ "$CXX" != "" -a "$CXX17FLAGS" != "" -a "$CXX17STD" != "" ]; then + ptimespec='#include +#include +// Example adapted from https://en.cppreference.com/w/cpp/chrono/c/timespec_get + +namespace std { + + int main() + { + timespec ts; + timespec_get(&ts, TIME_UTC); + char buf[100]; + strftime(buf, sizeof buf, "%D %T", gmtime(&ts.tv_sec)); + printf("Current time: %s.%09ld UTC", buf, ts.tv_nsec); + return 0; + } + +}' + echo "$ptimespec" | ${CXX} -x c++ -c $CXX17FLAGS $CXX17STD - -o /dev/null > /dev/null 2>&1 + if [ $? -eq 0 ]; then + # See https://github.com/r-lib/later/issues/115 + echo "Using c++17." + CXX_STD=CXX17 + else + echo "Cannot use c++17 using default configuration for c++11" + fi +fi + + # Write to Makevars -sed -e "s|@extra_pkg_libs@|$EXTRA_PKG_LIBS|" src/Makevars.in > src/Makevars +sed -e "s|@extra_pkg_libs@|$EXTRA_PKG_LIBS|;s|@cxx_std@|$CXX_STD|" src/Makevars.in > src/Makevars # Success exit 0 diff --git a/src/Makevars.in b/src/Makevars.in index f3d2a500..9227f2e8 100644 --- a/src/Makevars.in +++ b/src/Makevars.in @@ -1,5 +1,4 @@ -# Use C++11 if available -CXX_STD=CXX11 +CXX_STD=@cxx_std@ PKG_CPPFLAGS = -pthread -DSTRICT_R_HEADERS PKG_LIBS = -pthread @extra_pkg_libs@