CMake: Fix the re-computed value of INSTALL_*DIR variables
For INSTALL_*DIR variables that have the the same value as CMAKE_INSTALL_PREFIX, a second cmake run cleared the value. This is because file(RELATIVE_PATH) returns the empty string if we pass the same absolute paths. Fix this by checking the return value of file(RELATIVE_PATH) for the empty string and setting it to ".". It's a limitation of qmake that empty strings are not handled as ".". Change-Id: I8fc4d1eabcc9d5634be2f3741b0002a347dd17e6 Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
This commit is contained in:
parent
f716a87352
commit
c269d8f086
@ -21,7 +21,10 @@ function(qt_configure_process_path name default docstring)
|
|||||||
# If relative path given, it's relative to the install prefix (rather than the binary dir,
|
# If relative path given, it's relative to the install prefix (rather than the binary dir,
|
||||||
# which is what qmake does for some reason).
|
# which is what qmake does for some reason).
|
||||||
# In both cases, store the value as a relative path.
|
# In both cases, store the value as a relative path.
|
||||||
if(rel_path MATCHES "^\.\./")
|
if("${rel_path}" STREQUAL "")
|
||||||
|
# file(RELATIVE_PATH) returns an empty string if the given absolute paths are equal
|
||||||
|
set(rel_path ".")
|
||||||
|
elseif(rel_path MATCHES "^\.\./")
|
||||||
message(FATAL_ERROR
|
message(FATAL_ERROR
|
||||||
"Path component '${name}' is outside computed install prefix: ${rel_path} ")
|
"Path component '${name}' is outside computed install prefix: ${rel_path} ")
|
||||||
endif()
|
endif()
|
||||||
|
Loading…
Reference in New Issue
Block a user