61ce654742
Commit v2.8.11~156^2~2 (Expand includes and defines transitively in 'external' genexes., 2013-02-13) introduced a recursive loop and a stack overflow during evaluation of a link implementation which depends on a transitive property, such as add_library(empty1 ...) add_library(empty2 ...) target_link_libraries(empty1 PRIVATE $<$<STREQUAL:$<TARGET_PROPERTY:INCLUDE_DIRECTORIES>,/foo/bar>:empty2> ) There is no use-case for code like that currently, but it should not cause a stack overflow. Avoid the recursion by reporting an error early if a case like this is found.
11 lines
302 B
CMake
11 lines
302 B
CMake
|
|
add_library(empty1 empty.cpp)
|
|
add_library(empty2 empty.cpp)
|
|
|
|
# This is OK, because evaluating the INCLUDE_DIRECTORIES is not affected by
|
|
# the content of the INTERFACE_LINK_LIBRARIES.
|
|
target_link_libraries(empty1
|
|
INTERFACE
|
|
$<$<STREQUAL:$<TARGET_PROPERTY:INCLUDE_DIRECTORIES>,/foo/bar>:empty2>
|
|
)
|