Skip to content

Commit 6b9318d

Browse files
committed
Fix assumptions that CMAKE_INSTALL_*DIR paths are relative.
When an absolute path is desired, the CMAKE_INSTALL_FULL_*DIR variables should be used instead of concatenating with CMAKE_INSTALL_PREFIX. Special handling is also needed for pkg-config and CMake config files to retain relative paths if the lib/include directories are subdirectories of the install prefix.
1 parent 29426ec commit 6b9318d

File tree

3 files changed

+18
-8
lines changed

3 files changed

+18
-8
lines changed

CMakeLists.txt

Lines changed: 13 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ option(APPEND_PROJECT_NAME_TO_INCLUDEDIR
1919

2020
if(APPEND_PROJECT_NAME_TO_INCLUDEDIR)
2121
set(CMAKE_INSTALL_INCLUDEDIR "${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}")
22+
set(CMAKE_INSTALL_FULL_INCLUDEDIR "${CMAKE_INSTALL_FULL_INCLUDEDIR}/${PROJECT_NAME}")
2223
endif()
2324

2425
# set the default build type
@@ -59,16 +60,22 @@ set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}"
5960

6061
enable_testing()
6162

62-
set(CMAKE_CONFIG_INSTALL_DIR ${CMAKE_INSTALL_LIBDIR}/${PROJECT_NAME}/cmake)
63-
string(REGEX REPLACE "[^/]+" ".." RELATIVE_PATH_CMAKE_DIR_TO_PREFIX "${CMAKE_CONFIG_INSTALL_DIR}")
64-
string(REGEX REPLACE "[^/]+" ".." RELATIVE_PATH_LIBDIR_TO_PREFIX "${CMAKE_INSTALL_LIBDIR}")
63+
set(CMAKE_CONFIG_INSTALL_DIR ${CMAKE_INSTALL_FULL_LIBDIR}/${PROJECT_NAME}/cmake)
64+
file(RELATIVE_PATH RELATIVE_PATH_CMAKE_DIR_TO_PREFIX "${CMAKE_CONFIG_INSTALL_DIR}" "${CMAKE_INSTALL_PREFIX}")
65+
file(RELATIVE_PATH RELATIVE_PATH_LIBDIR_TO_PREFIX "${CMAKE_INSTALL_FULL_LIBDIR}" "${CMAKE_INSTALL_PREFIX}")
6566

6667
add_subdirectory(urdf_parser)
6768

6869
set(PKG_NAME ${PROJECT_NAME})
6970
set(PKG_LIBRARIES urdfdom_sensor urdfdom_model_state urdfdom_model urdfdom_world)
7071
set(PKG_DEPENDS urdfdom_headers)
7172
set(PKG_EXPORTS urdfdom)
73+
string(REPLACE
74+
"${CMAKE_INSTALL_PREFIX}" "\${${PROJECT_NAME}_DIR}/${RELATIVE_PATH_CMAKE_DIR_TO_PREFIX}"
75+
CMAKE_CONF_LIBDIR "${CMAKE_INSTALL_FULL_LIBDIR}")
76+
string(REPLACE
77+
"${CMAKE_INSTALL_PREFIX}" "\${${PROJECT_NAME}_DIR}/${RELATIVE_PATH_CMAKE_DIR_TO_PREFIX}"
78+
CMAKE_CONF_INCLUDEDIR "${CMAKE_INSTALL_FULL_INCLUDEDIR}")
7279
set(cmake_conf_file "cmake/urdfdom-config")
7380
include(CMakePackageConfigHelpers)
7481
write_basic_package_version_file(
@@ -92,7 +99,10 @@ install(FILES package.xml DESTINATION share/${PROJECT_NAME})
9299
set(PKG_DESC "Unified Robot Description Format")
93100
set(PKG_DEPENDS "urdfdom_headers") # make the list separated by spaces instead of ;
94101
set(PKG_URDF_LIBS "-lurdfdom_sensor -lurdfdom_model_state -lurdfdom_model -lurdfdom_world")
102+
string(REPLACE "${CMAKE_INSTALL_PREFIX}" "\${prefix}" PKG_CONF_LIBDIR "${CMAKE_INSTALL_FULL_LIBDIR}")
103+
string(REPLACE "${CMAKE_INSTALL_PREFIX}" "\${prefix}" PKG_CONF_INCLUDEDIR "${CMAKE_INSTALL_FULL_INCLUDEDIR}")
95104
set(pkg_conf_file "cmake/pkgconfig/urdfdom.pc")
105+
96106
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/${pkg_conf_file}.in" "${CMAKE_BINARY_DIR}/${pkg_conf_file}" @ONLY)
97107
install(FILES ${CMAKE_BINARY_DIR}/${pkg_conf_file}
98108
DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig/ COMPONENT pkgconfig)

cmake/pkgconfig/urdfdom.pc.in

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,8 @@
11
# This file was generated by CMake for @PROJECT_NAME@
22
prefix=${pcfiledir}/../@RELATIVE_PATH_LIBDIR_TO_PREFIX@
33
exec_prefix=${prefix}
4-
libdir=${prefix}/@CMAKE_INSTALL_LIBDIR@
5-
includedir=${prefix}/@CMAKE_INSTALL_INCLUDEDIR@
4+
libdir=@PKG_CONF_LIBDIR@
5+
includedir=@PKG_CONF_INCLUDEDIR@
66

77
Name: @PKG_NAME@
88
Description: @PKG_DESC@

cmake/urdfdom-config.cmake.in

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,16 +8,16 @@ set(@PKG_NAME@_CONFIG_INCLUDED TRUE)
88
set(CMAKE_MODULE_PATH_BACKUP_URDFDOM ${CMAKE_MODULE_PATH})
99
list(APPEND CMAKE_MODULE_PATH "${@PROJECT_NAME@_DIR}")
1010

11-
set(@PKG_NAME@_INCLUDE_DIRS "${@PROJECT_NAME@_DIR}/@RELATIVE_PATH_CMAKE_DIR_TO_PREFIX@/@CMAKE_INSTALL_INCLUDEDIR@")
11+
set(@PKG_NAME@_INCLUDE_DIRS "@CMAKE_CONF_INCLUDEDIR@")
1212

1313
foreach(lib @PKG_LIBRARIES@)
1414
set(onelib "${lib}-NOTFOUND")
1515
set(onelibd "${lib}-NOTFOUND")
1616
find_library(onelib ${lib}
17-
PATHS "${@PROJECT_NAME@_DIR}/@RELATIVE_PATH_CMAKE_DIR_TO_PREFIX@/@CMAKE_INSTALL_LIBDIR@"
17+
PATHS "@CMAKE_CONF_LIBDIR@"
1818
NO_DEFAULT_PATH)
1919
find_library(onelibd ${lib}d
20-
PATHS "${@PROJECT_NAME@_DIR}/@RELATIVE_PATH_CMAKE_DIR_TO_PREFIX@/@CMAKE_INSTALL_LIBDIR@"
20+
PATHS "@CMAKE_CONF_LIBDIR@"
2121
NO_DEFAULT_PATH)
2222
if(onelib-NOTFOUND AND onelibd-NOTFOUND)
2323
message(FATAL_ERROR "Library '${lib}' in package @PKG_NAME@ is not installed properly")

0 commit comments

Comments
 (0)