diff options
author | Rolf Eike Beer <eike@sf-mail.de> | 2012-01-16 20:03:23 (GMT) |
---|---|---|
committer | Rolf Eike Beer <eike@sf-mail.de> | 2012-01-16 20:03:23 (GMT) |
commit | 6856b4d19d85a9f72354744b5118e2946a90da45 (patch) | |
tree | b143c8fef5b594695f99eec60956015010efb5ba /Tests/CMakeOnly | |
parent | 8e1f376782be078407f926c042f07c789e073856 (diff) | |
parent | 8e756d2b9bb84b182a8402e71fb62d7a28d0a9c6 (diff) | |
download | CMake-6856b4d19d85a9f72354744b5118e2946a90da45.zip CMake-6856b4d19d85a9f72354744b5118e2946a90da45.tar.gz CMake-6856b4d19d85a9f72354744b5118e2946a90da45.tar.bz2 |
Merge topic 'link-shared-depend-cycle-issue-12647' into check_symbol_exists
Diffstat (limited to 'Tests/CMakeOnly')
-rw-r--r-- | Tests/CMakeOnly/CMakeLists.txt | 3 | ||||
-rw-r--r-- | Tests/CMakeOnly/LinkInterfaceLoop/CMakeLists.txt | 27 | ||||
-rw-r--r-- | Tests/CMakeOnly/LinkInterfaceLoop/lib.c | 1 | ||||
-rw-r--r-- | Tests/CMakeOnly/LinkInterfaceLoop/main.c | 1 |
4 files changed, 32 insertions, 0 deletions
diff --git a/Tests/CMakeOnly/CMakeLists.txt b/Tests/CMakeOnly/CMakeLists.txt index ec883ef..f6aa9b5 100644 --- a/Tests/CMakeOnly/CMakeLists.txt +++ b/Tests/CMakeOnly/CMakeLists.txt @@ -8,6 +8,9 @@ macro(add_CMakeOnly_test test) ) endmacro() +add_CMakeOnly_test(LinkInterfaceLoop) +set_property(TEST CMakeOnly.LinkInterfaceLoop PROPERTY TIMEOUT 90) + add_CMakeOnly_test(CheckSymbolExists) add_CMakeOnly_test(CheckCXXSymbolExists) diff --git a/Tests/CMakeOnly/LinkInterfaceLoop/CMakeLists.txt b/Tests/CMakeOnly/LinkInterfaceLoop/CMakeLists.txt new file mode 100644 index 0000000..56e449a --- /dev/null +++ b/Tests/CMakeOnly/LinkInterfaceLoop/CMakeLists.txt @@ -0,0 +1,27 @@ +cmake_minimum_required (VERSION 2.8) +project(LinkInterfaceLoop C) + +# Add a shared library that incorrectly names itself as a +# dependency, thus forming a cycle. +add_library(A SHARED IMPORTED) +set_target_properties(A PROPERTIES + IMPORTED_LINK_DEPENDENT_LIBRARIES A + IMPORTED_LOCATION "${CMAKE_CURRENT_BINARY_DIR}/dirA/A" + ) + +# Add a shared library that incorrectly names itself in +# its link interface, thus forming a cycle. +add_library(B SHARED IMPORTED) +set_target_properties(B PROPERTIES + IMPORTED_LINK_INTERFACE_LIBRARIES B + IMPORTED_LOCATION "${CMAKE_CURRENT_BINARY_DIR}/dirB/B" + ) + +# Add a shared library with an empty link interface +# that depends on two shared libraries. +add_library(C SHARED lib.c) +set_property(TARGET C PROPERTY LINK_INTERFACE_LIBRARIES "") +target_link_libraries(C B A) + +add_executable(main main.c) +target_link_libraries(main C) diff --git a/Tests/CMakeOnly/LinkInterfaceLoop/lib.c b/Tests/CMakeOnly/LinkInterfaceLoop/lib.c new file mode 100644 index 0000000..fede1d6 --- /dev/null +++ b/Tests/CMakeOnly/LinkInterfaceLoop/lib.c @@ -0,0 +1 @@ +int lib(void) { return 0; } diff --git a/Tests/CMakeOnly/LinkInterfaceLoop/main.c b/Tests/CMakeOnly/LinkInterfaceLoop/main.c new file mode 100644 index 0000000..78f2de1 --- /dev/null +++ b/Tests/CMakeOnly/LinkInterfaceLoop/main.c @@ -0,0 +1 @@ +int main(void) { return 0; } |