summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNoah Watkins <noahwatkins@gmail.com>2013-07-20 18:41:38 -0700
committerNoah Watkins <noahwatkins@gmail.com>2013-07-20 18:41:38 -0700
commit4d502f907de6b01df27253302fc1a12a8918b650 (patch)
tree2ec1c3fcd6ec706a70cdc893793afa6355e14d3d
parentdd0be485bca9e33b8d87efacf1dbc7ef7ed2160f (diff)
downloadceph-4d502f907de6b01df27253302fc1a12a8918b650.tar.gz
assert: use feature test for static_cast
Signed-off-by: Noah Watkins <noahwatkins@gmail.com>
-rw-r--r--configure.ac2
-rw-r--r--m4/ax_cxx_static_cast.m443
-rw-r--r--src/include/assert.h2
3 files changed, 46 insertions, 1 deletions
diff --git a/configure.ac b/configure.ac
index bdcf4fc557b..bc70996f34e 100644
--- a/configure.ac
+++ b/configure.ac
@@ -89,6 +89,8 @@ AC_DEFUN([AC_CHECK_CC_FLAG],
AC_CHECK_CC_FLAG([-Wtype-limits], [WARN_TYPE_LIMITS])
AC_CHECK_CC_FLAG([-Wignored-qualifiers], [WARN_IGNORED_QUALIFIERS])
+AX_CXX_STATIC_CAST
+
# Checks for libraries.
ACX_PTHREAD
AC_CHECK_LIB([uuid], [uuid_parse], [true], AC_MSG_FAILURE([libuuid not found]))
diff --git a/m4/ax_cxx_static_cast.m4 b/m4/ax_cxx_static_cast.m4
new file mode 100644
index 00000000000..e09e6c46cb2
--- /dev/null
+++ b/m4/ax_cxx_static_cast.m4
@@ -0,0 +1,43 @@
+# ===========================================================================
+# http://www.gnu.org/software/autoconf-archive/ax_cxx_static_cast.html
+# ===========================================================================
+#
+# SYNOPSIS
+#
+# AX_CXX_STATIC_CAST
+#
+# DESCRIPTION
+#
+# If the compiler supports static_cast<>, define HAVE_STATIC_CAST.
+#
+# LICENSE
+#
+# Copyright (c) 2008 Todd Veldhuizen
+# Copyright (c) 2008 Luc Maisonobe <luc@spaceroots.org>
+#
+# Copying and distribution of this file, with or without modification, are
+# permitted in any medium without royalty provided the copyright notice
+# and this notice are preserved. This file is offered as-is, without any
+# warranty.
+
+#serial 6
+
+AU_ALIAS([AC_CXX_STATIC_CAST], [AX_CXX_STATIC_CAST])
+AC_DEFUN([AX_CXX_STATIC_CAST],
+[AC_CACHE_CHECK(whether the compiler supports static_cast<>,
+ax_cv_cxx_static_cast,
+[AC_LANG_SAVE
+ AC_LANG_CPLUSPLUS
+ AC_TRY_COMPILE([#include <typeinfo>
+class Base { public : Base () {} virtual void f () = 0; };
+class Derived : public Base { public : Derived () {} virtual void f () {} };
+int g (Derived&) { return 0; }],[
+Derived d; Base& b = d; Derived& s = static_cast<Derived&> (b); return g (s);],
+ ax_cv_cxx_static_cast=yes, ax_cv_cxx_static_cast=no)
+ AC_LANG_RESTORE
+])
+if test "$ax_cv_cxx_static_cast" = yes; then
+ AC_DEFINE(HAVE_STATIC_CAST,,
+ [define if the compiler supports static_cast<>])
+fi
+])
diff --git a/src/include/assert.h b/src/include/assert.h
index fa49a2f3e0f..ab1ff4f138d 100644
--- a/src/include/assert.h
+++ b/src/include/assert.h
@@ -27,7 +27,7 @@ struct FailedAssertion {
#endif
-#if defined __cplusplus && __GNUC_PREREQ (2,95)
+#ifdef HAVE_STATIC_CAST
# define __CEPH_ASSERT_VOID_CAST static_cast<void>
#else
# define __CEPH_ASSERT_VOID_CAST (void)