[PATCH] C++11 keyword fallback

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The attached patch introduces three macros:
  AC_CXX_CONSTEXPR
  AC_CXX_FINAL
  AC_CXX_NULLPTR
which behave like AC_C_CONST et al but are for the new
C++11 constextr, final and nullptr keywords.  I can add
additional macros for other keywords, but not all of them
have the possibility of falling back e.g. decltype, so I
have excluded these for now since I don't see these as
being useful additions.

I would also like to add checks for a number of types which
have implementations in the std:: (C++11) and std::tr1 (C++98TR1)
and boost:: (Boost) namespaces.  Examples: regex, tuple, memory.
In many projects, I have logic in compatibility headers such as
follows.  In brief, these include the std:: header (if present)
or else include the std::tr1 header (if present) or else include
the boost:: header (if present) or else fail.  This permits once
to use the C++11 types with fallback to C++98TR1 or Boost being
completely transparent.

Would including macros such as AC_CXX_MEMORY, AC_CXX_TUPLE,
AC_CXX_REGEX etc. be acceptable?  If so, is it acceptable to
include logic similar to the following in config.h or an
alternate header?  Does autoconf allow the user to specify
which header will be used to e.g. redirect C++-specific
stuff to a specific header?


Regards,
Roger


# ifdef HAVE_MEMORY_SHARED_PTR
#  include <memory>
# elif HAVE_TR1_MEMORY
# include <tr1/memory>
namespace std {
    using std::tr1::shared_ptr;
    using std::tr1::weak_ptr;
    using std::tr1::static_pointer_cast;
    using std::tr1::const_pointer_cast;
    using std::tr1::dynamic_pointer_cast;
}
# elif HAVE_BOOST_SHARED_PTR_HPP
#  include <boost/shared_ptr.hpp>
namespace std {
    using boost::shared_ptr;
    using boost::weak_ptr;
    using boost::static_pointer_cast;
    using boost::const_pointer_cast;
    using boost::dynamic_pointer_cast;
}
# else
#  error A shared_ptr implementation is not available
# endif

# ifdef HAVE_TUPLE
#  include <tuple>
# elif HAVE_TR1_TUPLE
#  include <tr1/tuple>
namespace std {
  using tr1::tuple;
  using tr1::get;
}
# elif HAVE_BOOST_TUPLE_TUPLE_HPP
#  include <boost/tuple/tuple.hpp>
namespace std {
  using boost::tuple;
  using boost::get;
}
# else
#  error A tuple implementation is not available
# endif


-- 
  .''`.  Roger Leigh
 : :' :  Debian GNU/Linux    http://people.debian.org/~rleigh/
 `. `'   schroot and sbuild  http://alioth.debian.org/projects/buildd-tools
   `-    GPG Public Key      F33D 281D 470A B443 6756 147C 07B3 C8BC 4083 E800
>From afa1f8df49d1b95c2553604ae621ab7b10eb48aa Mon Sep 17 00:00:00 2001
From: Roger Leigh <rleigh@xxxxxxxxxx>
Date: Sun, 3 Feb 2013 00:51:45 +0000
Subject: [PATCH] C++: Add AC_CXX_CONSTEXPR, AC_CXX_FINAL and AC_CXX_NULLPTR

---
 doc/autoconf.texi |   41 ++++++++++++++++++++++++++++++++++++
 lib/autoconf/c.m4 |   60 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 101 insertions(+)

diff --git a/doc/autoconf.texi b/doc/autoconf.texi
index 8f58d4a..d93820f 100644
--- a/doc/autoconf.texi
+++ b/doc/autoconf.texi
@@ -7704,6 +7704,47 @@ Test whether the C++ compiler accepts the options @option{-c} and
 if it does not.
 @end defmac
 
+@anchor{AC_CXX_CONSTEXPR}
+@defmac AC_CXX_CONSTEXPR
+@acindex{CXX_CONSTEXPR}
+@cvindex constexpr
+@caindex cxx_constexpr
+If the C++ compiler does not fully support the @code{constexpr} keyword,
+define @code{constexpr} to be empty.  Programs can simply use
+@code{constexpr} as if every C++ compiler supported it; for those that
+don't, the makefile or configuration header file defines it as empty.
+Note that code which requires @code{constexpr}, e.g. for sizing an
+array based upon a constant expression evaluation, will not work with
+this fallback.
+
+This macro caches its result in the @code{ac_cv_cxx_constexpr} variable.
+@end defmac
+
+@anchor{AC_CXX_FINAL}
+@defmac AC_CXX_FINAL
+@acindex{CXX_FINAL}
+@cvindex final
+@caindex cxx_final
+If the C++ compiler does not fully support the @code{final} keyword,
+define @code{final} to be empty.  Programs can simply use
+@code{final} as if every C++ compiler supported it; for those that
+don't, the makefile or configuration header file defines it as empty.
+
+This macro caches its result in the @code{ac_cv_cxx_final} variable.
+@end defmac
+
+@anchor{AC_CXX_NULLPTR}
+@defmac AC_CXX_NULLPTR
+@acindex{CXX_NULLPTR}
+@cvindex nullptr
+@caindex cxx_nullptr
+If the C++ compiler does not fully support the @code{nullptr} keyword,
+define @code{nullptr} to be empty.  Programs can simply use
+@code{nullptr} as if every C++ compiler supported it; for those that
+don't, the makefile or configuration header file defines it as @code{0}.
+
+This macro caches its result in the @code{ac_cv_cxx_nullptr} variable.
+@end defmac
 
 @node Objective C Compiler
 @subsection Objective C Compiler Characteristics
diff --git a/lib/autoconf/c.m4 b/lib/autoconf/c.m4
index 6fe00fb..a263613 100644
--- a/lib/autoconf/c.m4
+++ b/lib/autoconf/c.m4
@@ -2494,3 +2494,63 @@ dnl Tru64	N/A (no support)
 dnl with extended modes being tried first.
 [[-std=gnu++11 -std=c++11 -std=gnu++0x -std=c++0x -qlanglvl=extended0x -AA]], [$1], [$2])[]dnl
 ])# _AC_PROG_CXX_CXX11
+
+# AC_CXX_CONSTEXPR
+# ----------------
+AC_DEFUN([AC_CXX_CONSTEXPR],
+[AC_CACHE_CHECK([for working constexpr], ac_cv_cxx_constexpr,
+[AC_LANG_PUSH(C++)dnl
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
+constexpr int get_val() { return 20; }
+]], [[
+  short sa[get_val()] = { 0 };
+]])],
+		   [ac_cv_cxx_constexpr=yes],
+		   [ac_cv_cxx_constexpr=no])])
+AC_LANG_POP(C++)dnl
+if test $ac_cv_cxx_constexpr = no; then
+  AC_DEFINE(constexpr,,
+	    [Define to empty if the keyword `constexpr' does not work.
+	     Warning: valid code using `constexpr' can become incorrect
+	     without.  Disable with care.])
+fi
+])# AC_CXX_CONSTEXPR
+
+# AC_CXX_NULLPTR
+# --------------
+AC_DEFUN([AC_CXX_NULLPTR],
+[AC_CACHE_CHECK([for working nullptr], ac_cv_cxx_nullptr,
+[AC_LANG_PUSH(C++)dnl
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
+  char *c = nullptr;
+]])],
+		   [ac_cv_cxx_nullptr=yes],
+		   [ac_cv_cxx_nullptr=no])])
+AC_LANG_POP(C++)dnl
+if test $ac_cv_cxx_nullptr = no; then
+  AC_DEFINE(nullptr,0,
+	    [Define to 0 if the keyword `nullptr' does not work.])
+fi
+])# AC_CXX_NULLPTR
+
+# AC_CXX_FINAL
+# --------------
+AC_DEFUN([AC_CXX_FINAL],
+[AC_CACHE_CHECK([for working final], ac_cv_cxx_final,
+[AC_LANG_PUSH(C++)dnl
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
+class f1 final { int i; };
+
+class f2 { virtual void f() final {} };
+]], [[
+  f1 fi1;
+  f2 fi2;
+]])],
+		   [ac_cv_cxx_final=yes],
+		   [ac_cv_cxx_final=no])])
+AC_LANG_POP(C++)dnl
+if test $ac_cv_cxx_final = no; then
+  AC_DEFINE(final,,
+	    [Define to empty if the keyword `final' does not work.])
+fi
+])# AC_CXX_FINAL
-- 
1.7.10.4

_______________________________________________
Autoconf mailing list
Autoconf@xxxxxxx
https://lists.gnu.org/mailman/listinfo/autoconf

[Index of Archives]     [GCC Help]     [Kernel Discussion]     [RPM Discussion]     [Red Hat Development]     [Yosemite News]     [Linux USB]     [Samba]

  Powered by Linux