Merge topic 'PackageConfigHelper_UsrMove'
4cad848
configure_package_config_file(): extend documentation37c4bc1
configure_package_config_file(): fix indentationd477414
configure_package_config_file: force absolute paths for usr-move
This commit is contained in:
commit
c42deac744
|
@ -9,6 +9,8 @@
|
||||||
# configure_file() command when creating the <Name>Config.cmake or <Name>-config.cmake
|
# configure_file() command when creating the <Name>Config.cmake or <Name>-config.cmake
|
||||||
# file for installing a project or library. It helps making the resulting package
|
# file for installing a project or library. It helps making the resulting package
|
||||||
# relocatable by avoiding hardcoded paths in the installed Config.cmake file.
|
# relocatable by avoiding hardcoded paths in the installed Config.cmake file.
|
||||||
|
# <Name>Config.cmake files installed under UNIX into /lib(64) or /usr/lib(64) are
|
||||||
|
# considered system packages and are not relocatable.
|
||||||
#
|
#
|
||||||
# In a FooConfig.cmake file there may be code like this to make the
|
# In a FooConfig.cmake file there may be code like this to make the
|
||||||
# install destinations know to the using project:
|
# install destinations know to the using project:
|
||||||
|
@ -173,11 +175,26 @@ function(CONFIGURE_PACKAGE_CONFIG_FILE _inputFile _outputFile)
|
||||||
else()
|
else()
|
||||||
set(absInstallDir "${CMAKE_INSTALL_PREFIX}/${CCF_INSTALL_DESTINATION}")
|
set(absInstallDir "${CMAKE_INSTALL_PREFIX}/${CCF_INSTALL_DESTINATION}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# with the /usr-move, /lib(64) is a symlink to /usr/lib on Fedora, ArchLinux, Mageira and others.
|
||||||
|
# If we are installed to such a location, force using absolute paths.
|
||||||
|
set(forceAbsolutePaths FALSE)
|
||||||
|
if("${absInstallDir}" MATCHES "^(/usr)?/lib(64)?/.+")
|
||||||
|
set(forceAbsolutePaths TRUE)
|
||||||
|
endif()
|
||||||
|
|
||||||
file(RELATIVE_PATH PACKAGE_RELATIVE_PATH "${absInstallDir}" "${CMAKE_INSTALL_PREFIX}" )
|
file(RELATIVE_PATH PACKAGE_RELATIVE_PATH "${absInstallDir}" "${CMAKE_INSTALL_PREFIX}" )
|
||||||
|
|
||||||
foreach(var ${CCF_PATH_VARS})
|
foreach(var ${CCF_PATH_VARS})
|
||||||
if(NOT DEFINED ${var})
|
if(NOT DEFINED ${var})
|
||||||
message(FATAL_ERROR "Variable ${var} does not exist")
|
message(FATAL_ERROR "Variable ${var} does not exist")
|
||||||
|
else()
|
||||||
|
if(forceAbsolutePaths)
|
||||||
|
if(IS_ABSOLUTE "${${var}}")
|
||||||
|
set(PACKAGE_${var} "${${var}}")
|
||||||
|
else()
|
||||||
|
set(PACKAGE_${var} "${CMAKE_INSTALL_PREFIX}/${${var}}")
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
if(IS_ABSOLUTE "${${var}}")
|
if(IS_ABSOLUTE "${${var}}")
|
||||||
string(REPLACE "${CMAKE_INSTALL_PREFIX}" "\${PACKAGE_PREFIX_DIR}"
|
string(REPLACE "${CMAKE_INSTALL_PREFIX}" "\${PACKAGE_PREFIX_DIR}"
|
||||||
|
@ -186,6 +203,7 @@ function(CONFIGURE_PACKAGE_CONFIG_FILE _inputFile _outputFile)
|
||||||
set(PACKAGE_${var} "\${PACKAGE_PREFIX_DIR}/${${var}}")
|
set(PACKAGE_${var} "\${PACKAGE_PREFIX_DIR}/${${var}}")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
get_filename_component(inputFileName "${_inputFile}" NAME)
|
get_filename_component(inputFileName "${_inputFile}" NAME)
|
||||||
|
|
Loading…
Reference in New Issue