Skip to content

Commit 244edd2

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 6d3c5de commit 244edd2

File tree

3 files changed

+19
-9
lines changed

3 files changed

+19
-9
lines changed

CMakeLists.txt

Lines changed: 14 additions & 4 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
@@ -67,19 +68,25 @@ set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR}"
6768
enable_testing()
6869

6970
if(WIN32 AND NOT CYGWIN)
70-
set(CMAKE_CONFIG_INSTALL_DIR CMake)
71+
set(CMAKE_CONFIG_INSTALL_DIR "${CMAKE_INSTALL_PREFIX}/CMake")
7172
else()
72-
set(CMAKE_CONFIG_INSTALL_DIR ${CMAKE_INSTALL_LIBDIR}/${PROJECT_NAME}/cmake)
73+
set(CMAKE_CONFIG_INSTALL_DIR "${CMAKE_INSTALL_FULL_LIBDIR}/${PROJECT_NAME}/cmake")
7374
endif()
74-
string(REGEX REPLACE "[^/]+" ".." RELATIVE_PATH_CMAKE_DIR_TO_PREFIX "${CMAKE_CONFIG_INSTALL_DIR}")
75-
string(REGEX REPLACE "[^/]+" ".." RELATIVE_PATH_LIBDIR_TO_PREFIX "${CMAKE_INSTALL_LIBDIR}")
75+
file(RELATIVE_PATH RELATIVE_PATH_CMAKE_DIR_TO_PREFIX "${CMAKE_CONFIG_INSTALL_DIR}" "${CMAKE_INSTALL_PREFIX}")
76+
file(RELATIVE_PATH RELATIVE_PATH_LIBDIR_TO_PREFIX "${CMAKE_INSTALL_FULL_LIBDIR}" "${CMAKE_INSTALL_PREFIX}")
7677

7778
add_subdirectory(urdf_parser)
7879

7980
set(PKG_NAME ${PROJECT_NAME})
8081
set(PKG_LIBRARIES urdfdom_sensor urdfdom_model_state urdfdom_model urdfdom_world)
8182
set(PKG_DEPENDS urdfdom_headers console_bridge)
8283
set(PKG_EXPORTS urdfdom)
84+
string(REPLACE
85+
"${CMAKE_INSTALL_PREFIX}" "\${${PROJECT_NAME}_DIR}/${RELATIVE_PATH_CMAKE_DIR_TO_PREFIX}"
86+
CMAKE_CONF_LIBDIR "${CMAKE_INSTALL_FULL_LIBDIR}")
87+
string(REPLACE
88+
"${CMAKE_INSTALL_PREFIX}" "\${${PROJECT_NAME}_DIR}/${RELATIVE_PATH_CMAKE_DIR_TO_PREFIX}"
89+
CMAKE_CONF_INCLUDEDIR "${CMAKE_INSTALL_FULL_INCLUDEDIR}")
8390
set(cmake_conf_file "cmake/urdfdom-config.cmake")
8491
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/${cmake_conf_file}.in" "${CMAKE_BINARY_DIR}/${cmake_conf_file}" @ONLY)
8592
install(FILES package.xml DESTINATION share/${PROJECT_NAME})
@@ -90,7 +97,10 @@ install(FILES ${CMAKE_BINARY_DIR}/${cmake_conf_file}
9097
set(PKG_DESC "Unified Robot Description Format")
9198
set(PKG_DEPENDS "urdfdom_headers console_bridge") # make the list separated by spaces instead of ;
9299
set(PKG_URDF_LIBS "-lurdfdom_sensor -lurdfdom_model_state -lurdfdom_model -lurdfdom_world")
100+
string(REPLACE "${CMAKE_INSTALL_PREFIX}" "\${prefix}" PKG_CONF_LIBDIR "${CMAKE_INSTALL_FULL_LIBDIR}")
101+
string(REPLACE "${CMAKE_INSTALL_PREFIX}" "\${prefix}" PKG_CONF_INCLUDEDIR "${CMAKE_INSTALL_FULL_INCLUDEDIR}")
93102
set(pkg_conf_file "cmake/pkgconfig/urdfdom.pc")
103+
94104
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/${pkg_conf_file}.in" "${CMAKE_BINARY_DIR}/${pkg_conf_file}" @ONLY)
95105
install(FILES ${CMAKE_BINARY_DIR}/${pkg_conf_file}
96106
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
@@ -3,16 +3,16 @@ if (@PKG_NAME@_CONFIG_INCLUDED)
33
endif()
44
set(@PKG_NAME@_CONFIG_INCLUDED TRUE)
55

6-
set(@PKG_NAME@_INCLUDE_DIRS "${@PROJECT_NAME@_DIR}/@RELATIVE_PATH_CMAKE_DIR_TO_PREFIX@/@CMAKE_INSTALL_INCLUDEDIR@" "@TinyXML_INCLUDE_DIRS@")
6+
set(@PKG_NAME@_INCLUDE_DIRS "@CMAKE_CONF_INCLUDEDIR@" "@TinyXML_INCLUDE_DIRS@")
77

88
foreach(lib @PKG_LIBRARIES@)
99
set(onelib "${lib}-NOTFOUND")
1010
set(onelibd "${lib}-NOTFOUND")
1111
find_library(onelib ${lib}
12-
PATHS "${@PROJECT_NAME@_DIR}/@RELATIVE_PATH_CMAKE_DIR_TO_PREFIX@/@CMAKE_INSTALL_LIBDIR@"
12+
PATHS "@CMAKE_CONF_LIBDIR@"
1313
NO_DEFAULT_PATH)
1414
find_library(onelibd ${lib}d
15-
PATHS "${@PROJECT_NAME@_DIR}/@RELATIVE_PATH_CMAKE_DIR_TO_PREFIX@/@CMAKE_INSTALL_LIBDIR@"
15+
PATHS "@CMAKE_CONF_LIBDIR@"
1616
NO_DEFAULT_PATH)
1717
if(onelib-NOTFOUND AND onelibd-NOTFOUND)
1818
message(FATAL_ERROR "Library '${lib}' in package @PKG_NAME@ is not installed properly")

0 commit comments

Comments
 (0)