Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'intern/numaapi/source/build_config.h')
-rw-r--r--intern/numaapi/source/build_config.h379
1 files changed, 379 insertions, 0 deletions
diff --git a/intern/numaapi/source/build_config.h b/intern/numaapi/source/build_config.h
new file mode 100644
index 00000000000..444adcc0c71
--- /dev/null
+++ b/intern/numaapi/source/build_config.h
@@ -0,0 +1,379 @@
+// Copyright (c) 2018, libnumaapi authors
+//
+// Permission is hereby granted, free of charge, to any person obtaining a copy
+// of this software and associated documentation files (the "Software"), to
+// deal in the Software without restriction, including without limitation the
+// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
+// sell copies of the Software, and to permit persons to whom the Software is
+// furnished to do so, subject to the following conditions:
+//
+// The above copyright notice and this permission notice shall be included in
+// all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+// IN THE SOFTWARE.
+//
+// Author: Sergey Sharybin (sergey.vfx@gmail.com)
+
+#ifndef __BUILD_CONFIG_H__
+#define __BUILD_CONFIG_H__
+
+#include <limits.h>
+#include <stdint.h>
+
+// Initially is based on Chromium's build_config.h, with tweaks and extensions
+// needed for this project.
+//
+// NOTE: All commonly used symbols (which are checked on a "top" level, from
+// outside of any platform-specific ifdef block) are to be explicitly defined
+// to 0 when they are not "active". This is extra lines of code in this file,
+// but is not being edited that often. Such approach helps catching cases when
+// one attempted to access build configuration variable without including the
+// header by simply using -Wundef compiler attribute.
+//
+// NOTE: Not having things explicitly defined to 0 is harmless (in terms it
+// follows same rules as Google projects) and will simply cause compiler to
+// become more noisy, which is simple to correct.
+
+////////////////////////////////////////////////////////////////////////////////
+// A set of macros to use for platform detection.
+
+#if defined(__native_client__)
+// __native_client__ must be first, so that other OS_ defines are not set.
+# define OS_NACL 1
+#elif defined(_AIX)
+# define OS_AIX 1
+#elif defined(ANDROID)
+# define OS_ANDROID 1
+#elif defined(__APPLE__)
+// Only include TargetConditions after testing ANDROID as some android builds
+// on mac don't have this header available and it's not needed unless the target
+// is really mac/ios.
+# include <TargetConditionals.h>
+# define OS_MACOSX 1
+# if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE
+# define OS_IOS 1
+# endif // defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE
+#elif defined(__HAIKU__)
+# define OS_HAIKU 1
+#elif defined(__hpux)
+# define OS_HPUX 1
+#elif defined(__linux__)
+# define OS_LINUX 1
+// Include a system header to pull in features.h for glibc/uclibc macros.
+# include <unistd.h>
+# if defined(__GLIBC__) && !defined(__UCLIBC__)
+// We really are using glibc, not uClibc pretending to be glibc.
+# define LIBC_GLIBC 1
+# endif
+#elif defined(__sgi)
+# define OS_IRIX 1
+#elif defined(_WIN32)
+# define OS_WIN 1
+#elif defined(__FreeBSD__)
+# define OS_FREEBSD 1
+#elif defined(__NetBSD__)
+# define OS_NETBSD 1
+#elif defined(__OpenBSD__)
+# define OS_OPENBSD 1
+#elif defined(__sun)
+# define OS_SOLARIS 1
+#elif defined(__QNXNTO__)
+# define OS_QNX 1
+#else
+# error Please add support for your platform in build_config.h
+#endif
+
+#if !defined(OS_AIX)
+# define OS_AIX 0
+#endif
+#if !defined(OS_NACL)
+# define OS_NACL 0
+#endif
+#if !defined(OS_ANDROID)
+# define OS_ANDROID 0
+#endif
+#if !defined(OS_MACOSX)
+# define OS_MACOSX 0
+#endif
+#if !defined(OS_IOS)
+# define OS_IOS 0
+#endif
+#if !defined(OS_HAIKU)
+# define OS_HAIKU 0
+#endif
+#if !defined(OS_HPUX)
+# define OS_HPUX 0
+#endif
+#if !defined(OS_IRIX)
+# define OS_IRIX 0
+#endif
+#if !defined(OS_LINUX)
+# define OS_LINUX 0
+#endif
+#if !defined(LIBC_GLIBC)
+# define LIBC_GLIBC 0
+#endif
+#if !defined(OS_WIN)
+# define OS_WIN 0
+#endif
+#if !defined(OS_FREEBSD)
+# define OS_FREEBSD 0
+#endif
+#if !defined(OS_NETBSD)
+# define OS_NETBSD 0
+#endif
+#if !defined(OS_OPENBSD)
+# define OS_OPENBSD 0
+#endif
+#if !defined(OS_SOLARIS)
+# define OS_SOLARIS 0
+#endif
+#if !defined(OS_QNX)
+# define OS_QNX 0
+#endif
+
+////////////////////////////////////////////////////////////////////////////////
+// *BSD OS family detection.
+//
+// For access to standard BSD features, use OS_BSD instead of a
+// more specific macro.
+#if OS_FREEBSD || OS_OPENBSD || OS_NETBSD
+# define OS_BSD 1
+#else
+# define OS_BSD 0
+#endif
+
+////////////////////////////////////////////////////////////////////////////////
+// POSIX system detection.
+//
+// For access to standard POSIXish features use OS_POSIX instead of a
+// more specific macro.
+#if OS_MACOSX || OS_LINUX || OS_BSD || OS_SOLARIS ||OS_ANDROID || OS_NACL || \
+ OS_QNX || OS_HAIKU || OS_AIX || OS_HPUX || OS_IRIX
+# define OS_POSIX 1
+#else
+# define OS_POSIX 0
+#endif
+
+////////////////////////////////////////////////////////////////////////////////
+// Compiler detection, including its capabilities.
+
+#if defined(__clang__)
+# define COMPILER_CLANG 1
+#elif defined(__GNUC__)
+# define COMPILER_GCC 1
+# define COMPILER_GCC_VERSION (__GNUC__ * 100 + __GNUC_MINOR__)
+#elif defined(_MSC_VER)
+# define COMPILER_MSVC 1
+# define COMPILER_MSVC_VERSION (_MSC_VER)
+#elif defined(__MINGW32__)
+# define COMPILER_MINGW32 1
+#elif defined(__MINGW64__)
+# define COMPILER_MINGW64 1
+#else
+# error Please add support for your compiler in build_config.h
+#endif
+
+#if !defined(COMPILER_CLANG)
+# define COMPILER_CLANG 0
+#endif
+#if !defined(COMPILER_GCC)
+# define COMPILER_GCC 0
+#endif
+#if !defined(COMPILER_MSVC)
+# define COMPILER_MSVC 0
+#endif
+#if !defined(COMPILER_MINGW32)
+# define COMPILER_MINGW32 0
+#endif
+#if !defined(COMPILER_MINGW64)
+# define COMPILER_MINGW64 0
+#endif
+
+// Compiler is any of MinGW family.
+#if COMPILER_MINGW32 || COMPILER_MINGW64
+# define COMPILER_MINGW 1
+#else
+# define COMPILER_MINGW 0
+#endif
+
+// Check what is the latest C++ specification the compiler supports.
+//
+// NOTE: Use explicit definition here to avoid expansion-to-defined warning from
+// being geenrated. While this will most likely a false-positive warning in this
+// particular case, that warning might be helpful to catch errors elsewhere.
+
+// C++11 check.
+#if ((defined(__cplusplus) && (__cplusplus > 199711L)) || \
+ (defined(_MSC_VER) && (_MSC_VER >= 1800)))
+# define COMPILER_SUPPORTS_CXX11 1
+#else
+# define COMPILER_SUPPORTS_CXX11 0
+#endif
+// C++14 check.
+#if (defined(__cplusplus) && (__cplusplus > 201311L))
+# define COMPILER_SUPPORTS_CXX14 1
+#else
+# define COMPILER_SUPPORTS_CXX14 0
+#endif
+// C++17 check.
+#if (defined(__cplusplus) && (__cplusplus > 201611L))
+# define COMPILER_SUPPORTS_CXX17 1
+#else
+# define COMPILER_SUPPORTS_CXX17 0
+#endif
+// C++20 check.
+#if (defined(__cplusplus) && (__cplusplus > 201911L))
+# define COMPILER_SUPPORTS_CXX20 1
+#else
+# define COMPILER_SUPPORTS_CXX20 0
+#endif
+
+// COMPILER_USE_ADDRESS_SANITIZER is defined when program is detected that
+// compilation happened wit haddress sanitizer enabled. This allows to give
+// tips to sanitizer, or maybe work around some known issues with third party
+// libraries.
+#if !defined(COMPILER_USE_ADDRESS_SANITIZER)
+# if defined(__has_feature)
+# define COMPILER_USE_ADDRESS_SANITIZER 1
+# elif defined(__SANITIZE_ADDRESS__)
+# define COMPILER_USE_ADDRESS_SANITIZER 1
+# endif
+#endif
+
+#if !defined(COMPILER_USE_ADDRESS_SANITIZER)
+# define COMPILER_USE_ADDRESS_SANITIZER 0
+#endif
+
+////////////////////////////////////////////////////////////////////////////////
+// Processor architecture detection.
+//
+// For more info on what's defined, see:
+//
+// http://msdn.microsoft.com/en-us/library/b0084kay.aspx
+// http://www.agner.org/optimize/calling_conventions.pdf
+//
+// or with gcc, run: "echo | gcc -E -dM -"
+#if defined(_M_X64) || defined(__x86_64__)
+# define ARCH_CPU_X86_FAMILY 1
+# define ARCH_CPU_X86_64 1
+# define ARCH_CPU_64_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+#elif defined(_M_IX86) || defined(__i386__)
+# define ARCH_CPU_X86_FAMILY 1
+# define ARCH_CPU_X86 1
+# define ARCH_CPU_32_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+#elif defined(__ARMEL__)
+# define ARCH_CPU_ARM_FAMILY 1
+# define ARCH_CPU_ARMEL 1
+# define ARCH_CPU_32_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+#elif defined(__aarch64__)
+# define ARCH_CPU_ARM_FAMILY 1
+# define ARCH_CPU_ARM64 1
+# define ARCH_CPU_64_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+#elif defined(__pnacl__)
+# define ARCH_CPU_32_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+#elif defined(__MIPSEL__)
+# if defined(__LP64__)
+# define ARCH_CPU_MIPS64_FAMILY 1
+# define ARCH_CPU_MIPS64EL 1
+# define ARCH_CPU_64_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+# else
+# define ARCH_CPU_MIPS_FAMILY 1
+# define ARCH_CPU_MIPSEL 1
+# define ARCH_CPU_32_BITS 1
+# define ARCH_CPU_LITTLE_ENDIAN 1
+# endif
+#elif defined(__MIPSEB__)
+# if defined(__LP64__)
+# define ARCH_CPU_MIPS64_FAMILY 1
+# define ARCH_CPU_MIPS64EB 1
+# define ARCH_CPU_64_BITS 1
+# define ARCH_CPU_BIG_ENDIAN 1
+# else
+# define ARCH_CPU_MIPS_FAMILY 1
+# define ARCH_CPU_MIPSEB 1
+# define ARCH_CPU_32_BITS 1
+# define ARCH_CPU_BIG_ENDIAN 1
+# endif
+#else
+# error Please add support for your architecture in build_config.h
+#endif
+
+#if !defined(ARCH_CPU_LITTLE_ENDIAN)
+# define ARCH_CPU_LITTLE_ENDIAN 0
+#endif
+#if !defined(ARCH_CPU_BIG_ENDIAN)
+# define ARCH_CPU_BIG_ENDIAN 0
+#endif
+
+#if !defined(ARCH_CPU_32_BITS)
+# define ARCH_CPU_32_BITS 0
+#endif
+#if !defined(ARCH_CPU_64_BITS)
+# define ARCH_CPU_64_BITS 0
+#endif
+
+#if !defined(ARCH_CPU_X86_FAMILY)
+# define ARCH_CPU_X86_FAMILY 0
+#endif
+#if !defined(ARCH_CPU_ARM_FAMILY)
+# define ARCH_CPU_ARM_FAMILY 0
+#endif
+#if !defined(ARCH_CPU_MIPS_FAMILY)
+# define ARCH_CPU_MIPS_FAMILY 0
+#endif
+#if !defined(ARCH_CPU_MIPS64_FAMILY)
+# define ARCH_CPU_MIPS64_FAMILY 0
+#endif
+
+////////////////////////////////////////////////////////////////////////////////
+// Sizes of platform-dependent types.
+
+#if defined(__SIZEOF_POINTER__)
+# define PLATFORM_SIZEOF_PTR __SIZEOF_POINTER__
+#elif defined(UINTPTR_MAX)
+# if (UINTPTR_MAX == 0xffffffff)
+# define PLATFORM_SIZEOF_PTR 4
+# elif (UINTPTR_MAX == 0xffffffffffffffff) // NOLINT
+# define PLATFORM_SIZEOF_PTR 8
+# endif
+#elif defined(__WORDSIZE)
+# if (__WORDSIZE == 32)
+# define PLATFORM_SIZEOF_PTR 4
+# else if (__WORDSIZE == 64)
+# define PLATFORM_SIZEOF_PTR 8
+# endif
+#endif
+#if !defined(PLATFORM_SIZEOF_PTR)
+# error "Cannot find pointer size"
+#endif
+
+#if (UINT_MAX == 0xffffffff)
+# define PLATFORM_SIZEOF_INT 4
+#elif (UINT_MAX == 0xffffffffffffffff) // NOLINT
+# define PLATFORM_SIZEOF_INT 8
+#else
+# error "Cannot find int size"
+#endif
+
+#if (USHRT_MAX == 0xffffffff)
+# define PLATFORM_SIZEOF_SHORT 4
+#elif (USHRT_MAX == 0xffff) // NOLINT
+# define PLATFORM_SIZEOF_SHORT 2
+#else
+# error "Cannot find short size"
+#endif
+
+#endif // __BUILD_CONFIG_H__