summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorjimw@rama.(none) <>2006-09-29 19:28:16 -0700
committerjimw@rama.(none) <>2006-09-29 19:28:16 -0700
commit52d22ad827e298a6dc6c581cc266022eefd475d8 (patch)
tree9c907d127acd58dacd2ca6925a1cd19011c0b875 /include
parent5963b5af0f07c4e690d968e7ea5a53eb0b143b16 (diff)
downloadmariadb-git-52d22ad827e298a6dc6c581cc266022eefd475d8.tar.gz
Disable __attribute__ entirely on g++ < 3.4. (Bug #2717)
Diffstat (limited to 'include')
-rw-r--r--include/my_global.h25
1 files changed, 15 insertions, 10 deletions
diff --git a/include/my_global.h b/include/my_global.h
index 2fbb1db4b77..173f054b306 100644
--- a/include/my_global.h
+++ b/include/my_global.h
@@ -423,23 +423,28 @@ typedef unsigned short ushort;
#endif
/*
- Disable __attribute__() on GCC < 2.7 and non-GCC compilers
+ Disable __attribute__() on gcc < 2.7, g++ < 3.4, and non-gcc compilers.
+ Some forms of __attribute__ are actually supported in earlier versions of
+ g++, but we just disable them all because we only use them to generate
+ compilation warnings.
*/
-#if !defined(__attribute__) && (!defined(__GNUC__) || GCC_VERSION < 2007)
-#define __attribute__(A)
+#ifndef __attribute__
+# if !defined(__GNUC__)
+# define __attribute__(A)
+# elif GCC_VERSION < 2008
+# define __attribute__(A)
+# elif defined(__cplusplus__) && GCC_VERSION < 3004
+# define __attribute__(A)
+# endif
#endif
/*
__attribute__((format(...))) is only supported in gcc >= 2.8 and g++ >= 3.4
+ But that's already covered by the __attribute__ tests above, so this is
+ just a convenience macro.
*/
#ifndef ATTRIBUTE_FORMAT
-# if defined(__GNUC__) && \
- ((!defined(__cplusplus__) && GCC_VERSION >= 2008) || \
- GCC_VERSION >= 3004)
-# define ATTRIBUTE_FORMAT(style, m, n) __attribute__((format(style, m, n)))
-# else
-# define ATTRIBUTE_FORMAT(style, m, n)
-# endif
+# define ATTRIBUTE_FORMAT(style, m, n) __attribute__((format(style, m, n)))
#endif
/* From old s-system.h */