[add] first
This commit is contained in:
		
							
								
								
									
										74
									
								
								Libraries/external/baselib/Include/Internal/Compiler/CompilerEnvironmentClang.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								Libraries/external/baselib/Include/Internal/Compiler/CompilerEnvironmentClang.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,74 @@
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
// This defines the compiler environment for clang based compilers. Please make sure to define all required features
 | 
			
		||||
// (see VerifyCompilerEnvironment.h for reference)
 | 
			
		||||
 | 
			
		||||
#if defined(__cplusplus) && __cplusplus < 201103L
 | 
			
		||||
    #error "Baselib requires C++11 support"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_CLANG 1
 | 
			
		||||
 | 
			
		||||
#define HAS_CLANG_FEATURE(x) (__has_feature(x))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_SUPPORTS_EXCEPTIONS                 HAS_CLANG_FEATURE(cxx_exceptions)
 | 
			
		||||
#define COMPILER_SUPPORTS_RTTI                       HAS_CLANG_FEATURE(cxx_rtti)
 | 
			
		||||
#define COMPILER_SUPPORTS_GENERIC_LAMBDA_EXPRESSIONS HAS_CLANG_FEATURE(cxx_generic_lambdas) // Clang >=3.4
 | 
			
		||||
 | 
			
		||||
#define COMPILER_BUILTIN_EXPECT(X_, Y_)              __builtin_expect((X_), (Y_))
 | 
			
		||||
 | 
			
		||||
// Tells the compiler to assume that this statement is never reached.
 | 
			
		||||
// (reaching it anyways is undefined behavior!)
 | 
			
		||||
#define COMPILER_BUILTIN_UNREACHABLE()              __builtin_unreachable()
 | 
			
		||||
// Tells the compiler to assume that the given expression is true until the expression is modified.
 | 
			
		||||
// (it is undefined behavior if the expression is not true after all)
 | 
			
		||||
#define COMPILER_BUILTIN_ASSUME(EXPR_)              __builtin_assume(EXPR_)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#define COMPILER_NOINLINE               __attribute__((unused, noinline)) // unused is needed to avoid warning when a function is not used
 | 
			
		||||
#define COMPILER_INLINE                 __attribute__((unused)) inline
 | 
			
		||||
#define COMPILER_FORCEINLINE            __attribute__((unused, always_inline, nodebug)) inline
 | 
			
		||||
#define COMPILER_EMPTYINLINE            __attribute__((const, always_inline, nodebug)) inline
 | 
			
		||||
#define COMPILER_NORETURN               __attribute__((noreturn))
 | 
			
		||||
 | 
			
		||||
#if __has_extension(attribute_deprecated_with_message)
 | 
			
		||||
    #define COMPILER_DEPRECATED(msg)     __attribute__((deprecated(msg)))
 | 
			
		||||
    #if __has_extension(enumerator_attributes)
 | 
			
		||||
        #define COMPILER_DEPRECATED_ENUM_VALUE(msg) __attribute__((deprecated(msg)))
 | 
			
		||||
    #else
 | 
			
		||||
        #define COMPILER_DEPRECATED_ENUM_VALUE(msg)
 | 
			
		||||
    #endif
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_DEPRECATED(msg)     __attribute__((deprecated))
 | 
			
		||||
    #if __has_extension(enumerator_attributes)
 | 
			
		||||
        #define COMPILER_DEPRECATED_ENUM_VALUE(msg) __attribute__((deprecated))
 | 
			
		||||
    #else
 | 
			
		||||
        #define COMPILER_DEPRECATED_ENUM_VALUE(msg)
 | 
			
		||||
    #endif
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_ALIGN_OF(TYPE_)            __alignof__(TYPE_)
 | 
			
		||||
#define COMPILER_ALIGN_AS(ALIGN_)           __attribute__((aligned(ALIGN_)))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_C_STATIC_ASSERT(EXPR_, MSG_)  _Static_assert(EXPR_, MSG_)
 | 
			
		||||
 | 
			
		||||
#define COMPILER_ATTRIBUTE_UNUSED           __attribute__((unused))
 | 
			
		||||
 | 
			
		||||
// Note that this is how the compiler defines a debug break which is not necessarily the standard way on any given platform.
 | 
			
		||||
// For a platform friendly implementation, use `BASELIB_DEBUG_TRAP`
 | 
			
		||||
#define COMPILER_DEBUG_TRAP()               __builtin_debugtrap()
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARN_UNUSED_RESULT         __attribute__((warn_unused_result))
 | 
			
		||||
 | 
			
		||||
// Warning management
 | 
			
		||||
// pragma message on clang does always generate a warning that cannot be disabled, therefore the clang version
 | 
			
		||||
// of COMPILER_PRINT_MESSAGE() does nothing
 | 
			
		||||
#define COMPILER_PRINT_MESSAGE(MESSAGE_)
 | 
			
		||||
#define COMPILER_PRINT_WARNING(MESSAGE_)    _Pragma(PP_STRINGIZE(message(__FILE__ "warning: " MESSAGE_)))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARNING_UNUSED_VARIABLE    PP_STRINGIZE(-Wunused-variable)
 | 
			
		||||
#define COMPILER_WARNING_DEPRECATED         PP_STRINGIZE(-Wdeprecated)
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARNINGS_PUSH              _Pragma(PP_STRINGIZE(clang diagnostic push))
 | 
			
		||||
#define COMPILER_WARNINGS_POP               _Pragma(PP_STRINGIZE(clang diagnostic pop))
 | 
			
		||||
#define COMPILER_WARNINGS_DISABLE(Warn)     _Pragma(PP_STRINGIZE(clang diagnostic ignored Warn))
 | 
			
		||||
							
								
								
									
										99
									
								
								Libraries/external/baselib/Include/Internal/Compiler/CompilerEnvironmentGcc.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								Libraries/external/baselib/Include/Internal/Compiler/CompilerEnvironmentGcc.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,99 @@
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
// Verify that the GCC is correctly defining __cplusplus. This is not the case for
 | 
			
		||||
// GCC versions < 4.7, where it is just defined to 1. We only error here in case of linux build
 | 
			
		||||
// as we, as we use the commandline --std=xxx to select the featureset there. On armcc and cxppc
 | 
			
		||||
// we do not use any >C99 features, so the detection works correctly with __cplusplus==1
 | 
			
		||||
#if (__cplusplus == 1) && defined(LINUX)
 | 
			
		||||
    #error "This version of GCC is not supported. Please update to a more recent one."
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(__cplusplus) && __cplusplus < 201103L
 | 
			
		||||
    #error "Baselib requires C++11 support"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_GCC 1
 | 
			
		||||
 | 
			
		||||
// __cpp_exceptions is the correct way to check whether exceptions are enabled or not, but is unfortunately not supported
 | 
			
		||||
// by GCC versions before 5.0. For Pre 5.0 GCC, we also need to check the __EXCEPTIONS macro
 | 
			
		||||
#if defined(__cpp_exceptions) || __EXCEPTIONS == 1
 | 
			
		||||
    #define COMPILER_SUPPORTS_EXCEPTIONS             1
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_SUPPORTS_EXCEPTIONS             0
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// __cpp_rtti is the correct way to check whether RTTI is enabled or not, but is unfortunately not supported
 | 
			
		||||
// by GCC versions before 5.0. For Pre 5.0 GCC, we also need to check the __GXX_RTTI macro
 | 
			
		||||
#if defined(__cpp_rtti) || __GXX_RTTI == 1
 | 
			
		||||
    #define COMPILER_SUPPORTS_RTTI                   1
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_SUPPORTS_RTTI                   0
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// GCC >=4.9
 | 
			
		||||
#if defined(__cpp_generic_lambdas) && (__cpp_generic_lambdas >= 201304)
 | 
			
		||||
#define COMPILER_SUPPORTS_GENERIC_LAMBDA_EXPRESSIONS 1
 | 
			
		||||
#else
 | 
			
		||||
#define COMPILER_SUPPORTS_GENERIC_LAMBDA_EXPRESSIONS 0
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_BUILTIN_EXPECT(X_, Y_)              __builtin_expect((X_), (Y_))
 | 
			
		||||
 | 
			
		||||
// Tells the compiler to assume that this statement is never reached.
 | 
			
		||||
// (reaching it anyways is undefined behavior!)
 | 
			
		||||
#define COMPILER_BUILTIN_UNREACHABLE()              __builtin_unreachable()
 | 
			
		||||
// Tells the compiler to assume that the given expression is true until the expression is modified.
 | 
			
		||||
// (it is undefined behavior if the expression is not true after all)
 | 
			
		||||
#define COMPILER_BUILTIN_ASSUME(EXPR_)              do { if (!(EXPR_)) COMPILER_BUILTIN_UNREACHABLE(); } while(false)
 | 
			
		||||
 | 
			
		||||
#define COMPILER_NOINLINE                   __attribute__((unused, noinline)) // unused is needed to avoid warning when a function is not used
 | 
			
		||||
#define COMPILER_INLINE                     __attribute__((unused)) inline
 | 
			
		||||
#define COMPILER_FORCEINLINE                __attribute__((unused, always_inline)) inline
 | 
			
		||||
#define COMPILER_EMPTYINLINE                __attribute__((const, always_inline)) inline
 | 
			
		||||
#define COMPILER_NORETURN                   __attribute__((noreturn))
 | 
			
		||||
 | 
			
		||||
#if (__GNUC__ == 4 && __GNUC_MINOR__ >= 5) || __GNUC__ > 4
 | 
			
		||||
    #define COMPILER_DEPRECATED(msg) __attribute__((deprecated(msg)))
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_DEPRECATED(msg) __attribute__((deprecated))
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// Support for attributes on enumerators is GCC 6
 | 
			
		||||
#if __GNUC__ >= 6
 | 
			
		||||
    #define COMPILER_DEPRECATED_ENUM_VALUE(msg) __attribute__((deprecated(msg)))
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_DEPRECATED_ENUM_VALUE(msg)
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_ALIGN_OF(TYPE_)            __alignof__(TYPE_)
 | 
			
		||||
#define COMPILER_ALIGN_AS(ALIGN_)           __attribute__((aligned(ALIGN_)))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_C_STATIC_ASSERT(EXPR_, MSG_)  _Static_assert(EXPR_, MSG_)
 | 
			
		||||
 | 
			
		||||
#define COMPILER_ATTRIBUTE_UNUSED           __attribute__((unused))
 | 
			
		||||
 | 
			
		||||
// Some versions of GCC do provide __builtin_debugtrap, but it seems to be unreliable.
 | 
			
		||||
// See https://github.com/scottt/debugbreak/issues/13
 | 
			
		||||
#if defined(__i386__) || defined(__x86_64__)
 | 
			
		||||
#define COMPILER_DEBUG_TRAP()               __asm__ volatile("int $0x03")
 | 
			
		||||
#elif defined(__thumb__)
 | 
			
		||||
#define COMPILER_DEBUG_TRAP()               __asm__ volatile(".inst 0xde01")
 | 
			
		||||
#elif defined(__arm__) && !defined(__thumb__)
 | 
			
		||||
#define COMPILER_DEBUG_TRAP()               __asm__ volatile(".inst 0xe7f001f0")
 | 
			
		||||
#elif defined(__aarch64__)
 | 
			
		||||
#define COMPILER_DEBUG_TRAP()               __asm__ volatile(".inst 0xd4200000")
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARN_UNUSED_RESULT         __attribute__((warn_unused_result))
 | 
			
		||||
 | 
			
		||||
#define HAS_CLANG_FEATURE(x) 0
 | 
			
		||||
 | 
			
		||||
// Warning management
 | 
			
		||||
#define COMPILER_PRINT_MESSAGE(MESSAGE_)    _Pragma(PP_STRINGIZE(message(__FILE__ "info: " MESSAGE_)))
 | 
			
		||||
#define COMPILER_PRINT_WARNING(MESSAGE_)    _Pragma(PP_STRINGIZE(message(__FILE__ "warning: " MESSAGE_)))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARNING_UNUSED_VARIABLE    PP_STRINGIZE(-Wunused-variable)
 | 
			
		||||
#define COMPILER_WARNING_DEPRECATED         PP_STRINGIZE(-Wdeprecated)
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARNINGS_PUSH              _Pragma("GCC diagnostic push")
 | 
			
		||||
#define COMPILER_WARNINGS_POP               _Pragma("GCC diagnostic pop")
 | 
			
		||||
#define COMPILER_WARNINGS_DISABLE(Warn)     _Pragma(PP_STRINGIZE(GCC diagnostic ignored Warn))
 | 
			
		||||
							
								
								
									
										68
									
								
								Libraries/external/baselib/Include/Internal/Compiler/CompilerEnvironmentMsvc.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								Libraries/external/baselib/Include/Internal/Compiler/CompilerEnvironmentMsvc.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#if _MSC_VER < 1900
 | 
			
		||||
    #error "Baselib requires C++11 support, i.e. MSVC 2015 or newer"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_MSVC 1
 | 
			
		||||
 | 
			
		||||
#ifdef _CPPUNWIND
 | 
			
		||||
    #define COMPILER_SUPPORTS_EXCEPTIONS                _CPPUNWIND
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_SUPPORTS_EXCEPTIONS                0
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifdef _CPPRTTI
 | 
			
		||||
    #define COMPILER_SUPPORTS_RTTI                      _CPPRTTI
 | 
			
		||||
#else
 | 
			
		||||
    #define COMPILER_SUPPORTS_RTTI                      0
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define COMPILER_SUPPORTS_GENERIC_LAMBDA_EXPRESSIONS    1 // _MSC_VER >= 1900
 | 
			
		||||
 | 
			
		||||
#define COMPILER_BUILTIN_EXPECT(X_, Y_)             (X_)
 | 
			
		||||
 | 
			
		||||
// Tells the compiler to assume that this statement is never reached.
 | 
			
		||||
// (reaching it anyways is undefined behavior!)
 | 
			
		||||
#define COMPILER_BUILTIN_UNREACHABLE()              __assume(false)
 | 
			
		||||
// Tells the compiler to assume that the given expression is true until the expression is modified.
 | 
			
		||||
// (it is undefined behavior if the expression is not true after all)
 | 
			
		||||
#define COMPILER_BUILTIN_ASSUME(EXPR_)              __assume(EXPR_)
 | 
			
		||||
 | 
			
		||||
#define HAS_CLANG_FEATURE(x) 0
 | 
			
		||||
 | 
			
		||||
// Warning management
 | 
			
		||||
#define COMPILER_PRINT_MESSAGE(MESSAGE_)    __pragma(message(__FILE__ "(" PP_STRINGIZE(__LINE__) ") : info: " MESSAGE_))
 | 
			
		||||
#define COMPILER_PRINT_WARNING(MESSAGE_)    __pragma(message(__FILE__ "(" PP_STRINGIZE(__LINE__) ") : warning: " MESSAGE_))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARNING_UNUSED_VARIABLE    4101
 | 
			
		||||
#define COMPILER_WARNING_DEPRECATED         4995 4996
 | 
			
		||||
 | 
			
		||||
#define COMPILER_WARNINGS_PUSH              __pragma(warning(push))
 | 
			
		||||
#define COMPILER_WARNINGS_POP               __pragma(warning(pop))
 | 
			
		||||
#define COMPILER_WARNINGS_DISABLE(Warn)     __pragma(warning(disable : Warn))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_NOINLINE                   __declspec(noinline)
 | 
			
		||||
#define COMPILER_INLINE                     inline
 | 
			
		||||
#define COMPILER_FORCEINLINE                __forceinline
 | 
			
		||||
#define COMPILER_EMPTYINLINE                __forceinline
 | 
			
		||||
#define COMPILER_NORETURN                   __declspec(noreturn)
 | 
			
		||||
 | 
			
		||||
#define COMPILER_DEPRECATED(msg)            __declspec(deprecated(msg))
 | 
			
		||||
#define COMPILER_DEPRECATED_ENUM_VALUE(msg) /* no equivalent for this in MSVC */
 | 
			
		||||
 | 
			
		||||
#define COMPILER_ALIGN_OF(TYPE_)            __alignof(TYPE_)
 | 
			
		||||
#define COMPILER_ALIGN_AS(ALIGN_)           __declspec(align(ALIGN_))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_C_STATIC_ASSERT(EXPR_, MSG_)  typedef char __static_assert_t[(EXPR_) != 0]
 | 
			
		||||
 | 
			
		||||
#define COMPILER_ATTRIBUTE_UNUSED           __pragma(warning(suppress:4100))
 | 
			
		||||
 | 
			
		||||
#define COMPILER_DEBUG_TRAP()               __debugbreak()
 | 
			
		||||
 | 
			
		||||
// Note that this is best effort, as "/analyze" compiler flag required to make warning appear
 | 
			
		||||
#define COMPILER_WARN_UNUSED_RESULT         _Check_return_
 | 
			
		||||
 | 
			
		||||
#if !defined(alloca)
 | 
			
		||||
    #define alloca _alloca
 | 
			
		||||
#endif
 | 
			
		||||
		Reference in New Issue
	
	Block a user