Index: third_party/google_benchmark/CMakeLists.txt |
diff --git a/third_party/google_benchmark/CMakeLists.txt b/third_party/google_benchmark/CMakeLists.txt |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f7f1566f5693e878139237971720ce2f64a00fd5 |
--- /dev/null |
+++ b/third_party/google_benchmark/CMakeLists.txt |
@@ -0,0 +1,202 @@ |
+cmake_minimum_required (VERSION 2.8.12) |
+ |
+project (benchmark) |
+ |
+foreach(p |
+ CMP0054 # CMake 3.1 |
+ CMP0056 # export EXE_LINKER_FLAGS to try_run |
+ ) |
+ if(POLICY ${p}) |
+ cmake_policy(SET ${p} NEW) |
+ endif() |
+endforeach() |
+ |
+option(BENCHMARK_ENABLE_TESTING "Enable testing of the benchmark library." ON) |
+option(BENCHMARK_ENABLE_EXCEPTIONS "Enable the use of exceptions in the benchmark library." ON) |
+option(BENCHMARK_ENABLE_LTO "Enable link time optimisation of the benchmark library." OFF) |
+option(BENCHMARK_USE_LIBCXX "Build and test using libc++ as the standard library." OFF) |
+option(BENCHMARK_BUILD_32_BITS "Build a 32 bit version of the library" OFF) |
+ |
+# Make sure we can import out CMake functions |
+list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake") |
+ |
+# Read the git tags to determine the project version |
+include(GetGitVersion) |
+get_git_version(GIT_VERSION) |
+ |
+# Tell the user what versions we are using |
+string(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]+" VERSION ${GIT_VERSION}) |
+message("-- Version: ${VERSION}") |
+ |
+# The version of the libraries |
+set(GENERIC_LIB_VERSION ${VERSION}) |
+string(SUBSTRING ${VERSION} 0 1 GENERIC_LIB_SOVERSION) |
+ |
+# Import our CMake modules |
+include(CheckCXXCompilerFlag) |
+include(AddCXXCompilerFlag) |
+include(CXXFeatureCheck) |
+ |
+if (BENCHMARK_BUILD_32_BITS) |
+ add_required_cxx_compiler_flag(-m32) |
+endif() |
+ |
+if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC") |
+ # Turn compiler warnings up to 11 |
+ string(REGEX REPLACE "[-/]W[1-4]" "" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") |
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /W4") |
+ add_definitions(-D_CRT_SECURE_NO_WARNINGS) |
+ |
+ if (NOT BENCHMARK_ENABLE_EXCEPTIONS) |
+ add_cxx_compiler_flag(-EHs-) |
+ add_cxx_compiler_flag(-EHa-) |
+ endif() |
+ # Link time optimisation |
+ if (BENCHMARK_ENABLE_LTO) |
+ set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /GL") |
+ set(CMAKE_STATIC_LINKER_FLAGS_RELEASE "${CMAKE_STATIC_LINKER_FLAGS_RELEASE} /LTCG") |
+ set(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE} /LTCG") |
+ set(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE} /LTCG") |
+ |
+ set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /GL") |
+ string(REGEX REPLACE "[-/]INCREMENTAL" "/INCREMENTAL:NO" CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO}") |
+ set(CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO} /LTCG") |
+ string(REGEX REPLACE "[-/]INCREMENTAL" "/INCREMENTAL:NO" CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO}") |
+ set(CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO} /LTCG") |
+ string(REGEX REPLACE "[-/]INCREMENTAL" "/INCREMENTAL:NO" CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO}") |
+ set(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO} /LTCG") |
+ |
+ set(CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} /GL") |
+ set(CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL "${CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL} /LTCG") |
+ set(CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL "${CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL} /LTCG") |
+ set(CMAKE_EXE_LINKER_FLAGS_MINSIZEREL "${CMAKE_EXE_LINKER_FLAGS_MINSIZEREL} /LTCG") |
+ endif() |
+else() |
+ # Try and enable C++11. Don't use C++14 because it doesn't work in some |
+ # configurations. |
+ add_cxx_compiler_flag(-std=c++11) |
+ if (NOT HAVE_CXX_FLAG_STD_CXX11) |
+ add_cxx_compiler_flag(-std=c++0x) |
+ endif() |
+ |
+ # Turn compiler warnings up to 11 |
+ add_cxx_compiler_flag(-Wall) |
+ |
+ add_cxx_compiler_flag(-Wextra) |
+ add_cxx_compiler_flag(-Wshadow) |
+ add_cxx_compiler_flag(-Werror RELEASE) |
+ add_cxx_compiler_flag(-Werror RELWITHDEBINFO) |
+ add_cxx_compiler_flag(-Werror MINSIZEREL) |
+ add_cxx_compiler_flag(-pedantic) |
+ add_cxx_compiler_flag(-pedantic-errors) |
+ add_cxx_compiler_flag(-Wshorten-64-to-32) |
+ add_cxx_compiler_flag(-Wfloat-equal) |
+ add_cxx_compiler_flag(-fstrict-aliasing) |
+ if (NOT BENCHMARK_ENABLE_EXCEPTIONS) |
+ add_cxx_compiler_flag(-fno-exceptions) |
+ endif() |
+ if (NOT BENCHMARK_USE_LIBCXX) |
+ add_cxx_compiler_flag(-Wzero-as-null-pointer-constant) |
+ endif() |
+ if (HAVE_CXX_FLAG_FSTRICT_ALIASING) |
+ if (NOT CMAKE_CXX_COMPILER_ID STREQUAL "Intel") #ICC17u2: Many false positives for Wstrict-aliasing |
+ add_cxx_compiler_flag(-Wstrict-aliasing) |
+ endif() |
+ endif() |
+ # ICC17u2: overloaded virtual function "benchmark::Fixture::SetUp" is only partially overridden |
+ # (because of deprecated overload) |
+ add_cxx_compiler_flag(-wd654) |
+ add_cxx_compiler_flag(-Wthread-safety) |
+ if (HAVE_CXX_FLAG_WTHREAD_SAFETY) |
+ cxx_feature_check(THREAD_SAFETY_ATTRIBUTES) |
+ endif() |
+ |
+ # On most UNIX like platforms g++ and clang++ define _GNU_SOURCE as a |
+ # predefined macro, which turns on all of the wonderful libc extensions. |
+ # However g++ doesn't do this in Cygwin so we have to define it ourselfs |
+ # since we depend on GNU/POSIX/BSD extensions. |
+ if (CYGWIN) |
+ add_definitions(-D_GNU_SOURCE=1) |
+ endif() |
+ |
+ # Link time optimisation |
+ if (BENCHMARK_ENABLE_LTO) |
+ add_cxx_compiler_flag(-flto) |
+ if ("${CMAKE_C_COMPILER_ID}" STREQUAL "GNU") |
+ find_program(GCC_AR gcc-ar) |
+ if (GCC_AR) |
+ set(CMAKE_AR ${GCC_AR}) |
+ endif() |
+ find_program(GCC_RANLIB gcc-ranlib) |
+ if (GCC_RANLIB) |
+ set(CMAKE_RANLIB ${GCC_RANLIB}) |
+ endif() |
+ endif() |
+ endif() |
+ |
+ # Coverage build type |
+ set(CMAKE_CXX_FLAGS_COVERAGE "${CMAKE_CXX_FLAGS_DEBUG}" CACHE STRING |
+ "Flags used by the C++ compiler during coverage builds." |
+ FORCE) |
+ set(CMAKE_EXE_LINKER_FLAGS_COVERAGE |
+ "${CMAKE_EXE_LINKER_FLAGS_DEBUG}" CACHE STRING |
+ "Flags used for linking binaries during coverage builds." |
+ FORCE) |
+ set(CMAKE_SHARED_LINKER_FLAGS_COVERAGE |
+ "${CMAKE_SHARED_LINKER_FLAGS_DEBUG}" CACHE STRING |
+ "Flags used by the shared libraries linker during coverage builds." |
+ FORCE) |
+ mark_as_advanced( |
+ CMAKE_CXX_FLAGS_COVERAGE |
+ CMAKE_EXE_LINKER_FLAGS_COVERAGE |
+ CMAKE_SHARED_LINKER_FLAGS_COVERAGE) |
+ set(CMAKE_BUILD_TYPE "${CMAKE_BUILD_TYPE}" CACHE STRING |
+ "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel Coverage." |
+ FORCE) |
+ add_cxx_compiler_flag(--coverage COVERAGE) |
+endif() |
+ |
+if (BENCHMARK_USE_LIBCXX) |
+ if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") |
+ add_cxx_compiler_flag(-stdlib=libc++) |
+ elseif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" OR |
+ "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Intel") |
+ add_cxx_compiler_flag(-nostdinc++) |
+ message("libc++ header path must be manually specified using CMAKE_CXX_FLAGS") |
+ # Adding -nodefaultlibs directly to CMAKE_<TYPE>_LINKER_FLAGS will break |
+ # configuration checks such as 'find_package(Threads)' |
+ list(APPEND BENCHMARK_CXX_LINKER_FLAGS -nodefaultlibs) |
+ # -lc++ cannot be added directly to CMAKE_<TYPE>_LINKER_FLAGS because |
+ # linker flags appear before all linker inputs and -lc++ must appear after. |
+ list(APPEND BENCHMARK_CXX_LIBRARIES c++) |
+ else() |
+ message(FATAL "-DBENCHMARK_USE_LIBCXX:BOOL=ON is not supported for compiler") |
+ endif() |
+endif(BENCHMARK_USE_LIBCXX) |
+ |
+# C++ feature checks |
+# Determine the correct regular expression engine to use |
+cxx_feature_check(STD_REGEX) |
+cxx_feature_check(GNU_POSIX_REGEX) |
+cxx_feature_check(POSIX_REGEX) |
+if(NOT HAVE_STD_REGEX AND NOT HAVE_GNU_POSIX_REGEX AND NOT HAVE_POSIX_REGEX) |
+ message(FATAL_ERROR "Failed to determine the source files for the regular expression backend") |
+endif() |
+if (NOT BENCHMARK_ENABLE_EXCEPTIONS AND HAVE_STD_REGEX |
+ AND NOT HAVE_GNU_POSIX_REGEX AND NOT HAVE_POSIX_REGEX) |
+ message(WARNING "Using std::regex with exceptions disabled is not fully supported") |
+endif() |
+cxx_feature_check(STEADY_CLOCK) |
+# Ensure we have pthreads |
+find_package(Threads REQUIRED) |
+ |
+# Set up directories |
+include_directories(${PROJECT_SOURCE_DIR}/include) |
+ |
+# Build the targets |
+add_subdirectory(src) |
+ |
+if (BENCHMARK_ENABLE_TESTING) |
+ enable_testing() |
+ add_subdirectory(test) |
+endif() |