Skip to content

Commit ab349ee

Browse files
committed
Rename CMake project name from tsl_robin_map to tsl-robin-map for coherence with the convention used by most package managers.
1 parent 6edac20 commit ab349ee

5 files changed

+42
-44
lines changed

CMakeLists.txt

+28-32
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,16 @@
11
cmake_minimum_required(VERSION 3.1)
2+
include(GNUInstallDirs)
23

3-
project(tsl_robin_map VERSION 0.5.0)
4+
5+
project(tsl-robin-map VERSION 0.5.0)
46

57
add_library(robin_map INTERFACE)
68
# Use tsl::robin_map as target, more consistent with other libraries conventions (Boost, Qt, ...)
79
add_library(tsl::robin_map ALIAS robin_map)
810

911
target_include_directories(robin_map INTERFACE
1012
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
11-
"$<INSTALL_INTERFACE:include>")
13+
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>")
1214

1315
list(APPEND headers "${CMAKE_CURRENT_SOURCE_DIR}/include/tsl/robin_growth_policy.h"
1416
"${CMAKE_CURRENT_SOURCE_DIR}/include/tsl/robin_hash.h"
@@ -19,12 +21,7 @@ target_sources(robin_map INTERFACE "$<BUILD_INTERFACE:${headers}>")
1921
if(MSVC)
2022
target_sources(robin_map INTERFACE
2123
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/tsl-robin-map.natvis>"
22-
"$<INSTALL_INTERFACE:tsl-robin-map.natvis>")
23-
endif()
24-
25-
# Only compatible with CMake version >= 3.8
26-
if(${CMAKE_VERSION} VERSION_GREATER "3.7")
27-
target_compile_features(robin_map INTERFACE cxx_std_11)
24+
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_DATAROOTDIR}/tsl-robin-map.natvis>")
2825
endif()
2926

3027

@@ -33,50 +30,49 @@ endif()
3330
# Installation (only compatible with CMake version >= 3.3)
3431
if(${CMAKE_VERSION} VERSION_GREATER "3.2")
3532
include(CMakePackageConfigHelpers)
36-
include(GNUInstallDirs)
3733

3834
## Install include directory and potential natvis file
3935
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/tsl"
4036
DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}")
4137

4238
if(MSVC)
4339
install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/tsl-robin-map.natvis"
44-
DESTINATION ".")
40+
DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}")
4541
endif()
4642

4743

4844

49-
## Create and install tsl_robin_mapConfig.cmake
50-
configure_package_config_file("${CMAKE_CURRENT_SOURCE_DIR}/cmake/tsl_robin_mapConfig.cmake.in"
51-
"${CMAKE_CURRENT_BINARY_DIR}/tsl_robin_mapConfig.cmake"
52-
INSTALL_DESTINATION "${CMAKE_INSTALL_LIBDIR}/cmake/tsl_robin_map")
45+
## Create and install tsl-robin-mapConfig.cmake
46+
configure_package_config_file("${CMAKE_CURRENT_SOURCE_DIR}/cmake/tsl-robin-mapConfig.cmake.in"
47+
"${CMAKE_CURRENT_BINARY_DIR}/tsl-robin-mapConfig.cmake"
48+
INSTALL_DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/cmake/tsl-robin-map")
5349

54-
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/tsl_robin_mapConfig.cmake"
55-
DESTINATION "${CMAKE_INSTALL_LIBDIR}/cmake/tsl_robin_map")
50+
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/tsl-robin-mapConfig.cmake"
51+
DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/cmake/tsl-robin-map")
5652

57-
5853

59-
## Create and install tsl_robin_mapTargets.cmake
54+
55+
## Create and install tsl-robin-mapTargets.cmake
6056
install(TARGETS robin_map
61-
EXPORT tsl_robin_mapTargets)
62-
63-
install(EXPORT tsl_robin_mapTargets
57+
EXPORT tsl-robin-mapTargets)
58+
59+
install(EXPORT tsl-robin-mapTargets
6460
NAMESPACE tsl::
65-
DESTINATION "${CMAKE_INSTALL_LIBDIR}/cmake/tsl_robin_map")
61+
DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/cmake/tsl-robin-map")
62+
6663

67-
6864

69-
## Create and install tsl_robin_mapConfigVersion.cmake
70-
# tsl_robin_map is header-only and does not depend on the architecture.
71-
# Remove CMAKE_SIZEOF_VOID_P from tsl_robin_mapConfigVersion.cmake so that a
72-
# tsl_robin_mapConfig.cmake generated for a 64 bit target can be used for 32 bit
65+
## Create and install tsl-robin-mapConfigVersion.cmake
66+
# tsl-robin-map is header-only and does not depend on the architecture.
67+
# Remove CMAKE_SIZEOF_VOID_P from tsl-robin-mapConfigVersion.cmake so that a
68+
# tsl-robin-mapConfig.cmake generated for a 64 bit target can be used for 32 bit
7369
# targets and vice versa.
74-
set(TSL_ROBIN_MAP_CMAKE_SIZEOF_VOID_P ${CMAKE_SIZEOF_VOID_P})
70+
set(CMAKE_SIZEOF_VOID_P_BACKUP ${CMAKE_SIZEOF_VOID_P})
7571
unset(CMAKE_SIZEOF_VOID_P)
76-
write_basic_package_version_file("${CMAKE_CURRENT_BINARY_DIR}/tsl_robin_mapConfigVersion.cmake"
72+
write_basic_package_version_file("${CMAKE_CURRENT_BINARY_DIR}/tsl-robin-mapConfigVersion.cmake"
7773
COMPATIBILITY SameMajorVersion)
78-
set(CMAKE_SIZEOF_VOID_P ${TSL_ROBIN_MAP_CMAKE_SIZEOF_VOID_P})
74+
set(CMAKE_SIZEOF_VOID_P ${CMAKE_SIZEOF_VOID_P_BACKUP})
7975

80-
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/tsl_robin_mapConfigVersion.cmake"
81-
DESTINATION "${CMAKE_INSTALL_LIBDIR}/cmake/tsl_robin_map")
76+
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/tsl-robin-mapConfigVersion.cmake"
77+
DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/cmake/tsl-robin-map")
8278
endif()

README.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -86,7 +86,7 @@ add_subdirectory(third-party/robin-map)
8686
target_link_libraries(your_target PRIVATE tsl::robin_map)
8787
```
8888

89-
If the project has been installed through `make install`, you can also use `find_package(tsl_robin_map REQUIRED)` instead of `add_subdirectory`.
89+
If the project has been installed through `make install`, you can also use `find_package(tsl-robin-map REQUIRED)` instead of `add_subdirectory`.
9090

9191
The code should work with any C++11 standard-compliant compiler and has been tested with GCC 4.8.4, Clang 3.5.0 and Visual Studio 2015.
9292

cmake/tsl-robin-mapConfig.cmake.in

+9
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
# This module sets the following variables:
2+
# * tsl-robin-map_FOUND - true if tsl-robin-map found on the system
3+
# * tsl-robin-map_INCLUDE_DIRS - the directory containing tsl-robin-map headers
4+
@PACKAGE_INIT@
5+
6+
if(NOT TARGET tsl::robin_map)
7+
include("${CMAKE_CURRENT_LIST_DIR}/tsl-robin-mapTargets.cmake")
8+
get_target_property(tsl-robin-map_INCLUDE_DIRS tsl::robin_map INTERFACE_INCLUDE_DIRECTORIES)
9+
endif()

cmake/tsl_robin_mapConfig.cmake.in

-9
This file was deleted.

tests/CMakeLists.txt

+4-2
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,14 @@
1-
cmake_minimum_required(VERSION 3.5)
1+
cmake_minimum_required(VERSION 3.8)
22

33
project(tsl_robin_map_tests)
44

55
add_executable(tsl_robin_map_tests "main.cpp"
66
"custom_allocator_tests.cpp"
77
"policy_tests.cpp"
88
"robin_map_tests.cpp"
9-
"robin_set_tests.cpp")
9+
"robin_set_tests.cpp")
10+
11+
target_compile_features(tsl_robin_map_tests PRIVATE cxx_std_11)
1012

1113
if(CMAKE_CXX_COMPILER_ID MATCHES "Clang" OR CMAKE_CXX_COMPILER_ID MATCHES "GNU")
1214
target_compile_options(tsl_robin_map_tests PRIVATE -Werror -Wall -Wextra -Wold-style-cast -DTSL_DEBUG -UNDEBUG)

0 commit comments

Comments
 (0)