summaryrefslogtreecommitdiff
path: root/Zend/zend_config.w32.h
diff options
context:
space:
mode:
authorAnatol Belski <ab@php.net>2014-01-04 00:47:10 +0100
committerAnatol Belski <ab@php.net>2014-01-04 01:41:49 +0100
commit19aafe43b27b52be6a006c652bbefd936bd3721c (patch)
treee009c57d5b0af2a62646aa9667885ae4dc07b077 /Zend/zend_config.w32.h
parent250ee4c17a40eb79b4057374384b8669e803636a (diff)
downloadphp-git-19aafe43b27b52be6a006c652bbefd936bd3721c.tar.gz
Fixed bug #66009 Failed compilation of PHP extension with C++ std library using VS 2012
Visual Studio 2012 includes sanity checks for C++11 features, see http://msdn.microsoft.com/en-us/library/vstudio/bb531344(v=vs.110).aspx To fix the 'inline' keyword redefinition for C++ in debug mode, the new macros ZEND_WIN32_KEEP_INLINE is introduced, ZEND_WIN32_FORCE_INLINE is automatically appended in release mode.
Diffstat (limited to 'Zend/zend_config.w32.h')
-rw-r--r--Zend/zend_config.w32.h9
1 files changed, 7 insertions, 2 deletions
diff --git a/Zend/zend_config.w32.h b/Zend/zend_config.w32.h
index f779a506e6..6ea67602b4 100644
--- a/Zend/zend_config.w32.h
+++ b/Zend/zend_config.w32.h
@@ -62,10 +62,15 @@ typedef unsigned int uint;
/* This will cause the compilation process to be MUCH longer, but will generate
* a much quicker PHP binary
*/
-#undef inline
#ifdef ZEND_WIN32_FORCE_INLINE
+/* _ALLOW_KEYWORD_MACROS is only relevant for C++ */
+# if (_MSC_VER >= 1700) && !defined(_ALLOW_KEYWORD_MACROS)
+# define _ALLOW_KEYWORD_MACROS
+# endif
+# undef inline
# define inline __forceinline
-#else
+#elif !defined(ZEND_WIN32_KEEP_INLINE)
+# undef inline
# define inline
#endif