aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael "Croydon" Keck <cr0ydon@outlook.com>2019-01-03 14:42:07 +0100
committerDominic Hamon <dominichamon@users.noreply.github.com>2019-01-03 13:42:07 +0000
commiteec9a8e4976a397988c15e5a4b71a542375a2240 (patch)
treea49bc1cb8d8323d738a368b6a3c7d34c08611d53
parentdc1064554905deca47386bdfc4b72f44c1bd7716 (diff)
downloadgoogle-benchmark-eec9a8e4976a397988c15e5a4b71a542375a2240.tar.gz
Add minimal Conan support (#728)
-rw-r--r--conan/CMakeLists.txt7
-rw-r--r--conan/test_package/CMakeLists.txt10
-rw-r--r--conan/test_package/conanfile.py19
-rw-r--r--conan/test_package/test_package.cpp18
-rw-r--r--conanfile.py79
5 files changed, 133 insertions, 0 deletions
diff --git a/conan/CMakeLists.txt b/conan/CMakeLists.txt
new file mode 100644
index 0000000..15b92ca
--- /dev/null
+++ b/conan/CMakeLists.txt
@@ -0,0 +1,7 @@
+cmake_minimum_required(VERSION 2.8.11)
+project(cmake_wrapper)
+
+include(conanbuildinfo.cmake)
+conan_basic_setup()
+
+include(${CMAKE_SOURCE_DIR}/CMakeListsOriginal.txt)
diff --git a/conan/test_package/CMakeLists.txt b/conan/test_package/CMakeLists.txt
new file mode 100644
index 0000000..089a6c7
--- /dev/null
+++ b/conan/test_package/CMakeLists.txt
@@ -0,0 +1,10 @@
+cmake_minimum_required(VERSION 2.8.11)
+project(test_package)
+
+set(CMAKE_VERBOSE_MAKEFILE TRUE)
+
+include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
+conan_basic_setup()
+
+add_executable(${PROJECT_NAME} test_package.cpp)
+target_link_libraries(${PROJECT_NAME} ${CONAN_LIBS})
diff --git a/conan/test_package/conanfile.py b/conan/test_package/conanfile.py
new file mode 100644
index 0000000..d63f408
--- /dev/null
+++ b/conan/test_package/conanfile.py
@@ -0,0 +1,19 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+from conans import ConanFile, CMake
+import os
+
+
+class TestPackageConan(ConanFile):
+ settings = "os", "compiler", "build_type", "arch"
+ generators = "cmake"
+
+ def build(self):
+ cmake = CMake(self)
+ cmake.configure()
+ cmake.build()
+
+ def test(self):
+ bin_path = os.path.join("bin", "test_package")
+ self.run(bin_path, run_environment=True)
diff --git a/conan/test_package/test_package.cpp b/conan/test_package/test_package.cpp
new file mode 100644
index 0000000..4fa7ec0
--- /dev/null
+++ b/conan/test_package/test_package.cpp
@@ -0,0 +1,18 @@
+#include "benchmark/benchmark.h"
+
+void BM_StringCreation(benchmark::State& state) {
+ while (state.KeepRunning())
+ std::string empty_string;
+}
+
+BENCHMARK(BM_StringCreation);
+
+void BM_StringCopy(benchmark::State& state) {
+ std::string x = "hello";
+ while (state.KeepRunning())
+ std::string copy(x);
+}
+
+BENCHMARK(BM_StringCopy);
+
+BENCHMARK_MAIN();
diff --git a/conanfile.py b/conanfile.py
new file mode 100644
index 0000000..e31fc52
--- /dev/null
+++ b/conanfile.py
@@ -0,0 +1,79 @@
+from conans import ConanFile, CMake, tools
+from conans.errors import ConanInvalidConfiguration
+import shutil
+import os
+
+
+class GoogleBenchmarkConan(ConanFile):
+ name = "benchmark"
+ description = "A microbenchmark support library."
+ topics = ("conan", "benchmark", "google", "microbenchmark")
+ url = "https://github.com/google/benchmark"
+ homepage = "https://github.com/google/benchmark"
+ author = "Google Inc."
+ license = "Apache-2.0"
+ exports_sources = ["*"]
+ generators = "cmake"
+
+ settings = "arch", "build_type", "compiler", "os"
+ options = {
+ "shared": [True, False],
+ "fPIC": [True, False],
+ "enable_lto": [True, False],
+ "enable_exceptions": [True, False]
+ }
+ default_options = {"shared": False, "fPIC": True, "enable_lto": False, "enable_exceptions": True}
+
+ _build_subfolder = "."
+
+ def source(self):
+ # Wrap the original CMake file to call conan_basic_setup
+ shutil.move("CMakeLists.txt", "CMakeListsOriginal.txt")
+ shutil.move(os.path.join("conan", "CMakeLists.txt"), "CMakeLists.txt")
+
+ def config_options(self):
+ if self.settings.os == "Windows":
+ if self.settings.compiler == "Visual Studio" and float(self.settings.compiler.version.value) <= 12:
+ raise ConanInvalidConfiguration("{} {} does not support Visual Studio <= 12".format(self.name, self.version))
+ del self.options.fPIC
+
+ def configure(self):
+ if self.settings.os == "Windows" and self.options.shared:
+ raise ConanInvalidConfiguration("Windows shared builds are not supported right now, see issue #639")
+
+ def _configure_cmake(self):
+ cmake = CMake(self)
+
+ cmake.definitions["BENCHMARK_ENABLE_TESTING"] = "OFF"
+ cmake.definitions["BENCHMARK_ENABLE_GTEST_TESTS"] = "OFF"
+ cmake.definitions["BENCHMARK_ENABLE_LTO"] = "ON" if self.options.enable_lto else "OFF"
+ cmake.definitions["BENCHMARK_ENABLE_EXCEPTIONS"] = "ON" if self.options.enable_exceptions else "OFF"
+
+ # See https://github.com/google/benchmark/pull/638 for Windows 32 build explanation
+ if self.settings.os != "Windows":
+ cmake.definitions["BENCHMARK_BUILD_32_BITS"] = "ON" if "64" not in str(self.settings.arch) else "OFF"
+ cmake.definitions["BENCHMARK_USE_LIBCXX"] = "ON" if (str(self.settings.compiler.libcxx) == "libc++") else "OFF"
+ else:
+ cmake.definitions["BENCHMARK_USE_LIBCXX"] = "OFF"
+
+ cmake.configure(build_folder=self._build_subfolder)
+ return cmake
+
+ def build(self):
+ cmake = self._configure_cmake()
+ cmake.build()
+
+ def package(self):
+ cmake = self._configure_cmake()
+ cmake.install()
+
+ self.copy(pattern="LICENSE", dst="licenses")
+
+ def package_info(self):
+ self.cpp_info.libs = tools.collect_libs(self)
+ if self.settings.os == "Linux":
+ self.cpp_info.libs.extend(["pthread", "rt"])
+ elif self.settings.os == "Windows":
+ self.cpp_info.libs.append("shlwapi")
+ elif self.settings.os == "SunOS":
+ self.cpp_info.libs.append("kstat")