| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- include(GenerateExportHeader)
- set(CMAKE_INCLUDE_CURRENT_DIR ON)
- cmake_policy(SET CMP0022 NEW)
- add_library(cmp0022lib SHARED cmp0022lib.cpp)
- generate_export_header(cmp0022lib)
- add_library(cmp0022ifacelib SHARED cmp0022ifacelib.cpp)
- generate_export_header(cmp0022ifacelib)
- target_link_libraries(cmp0022lib LINK_PUBLIC cmp0022ifacelib)
- assert_property(cmp0022lib LINK_INTERFACE_LIBRARIES "")
- assert_property(cmp0022ifacelib LINK_INTERFACE_LIBRARIES "")
- assert_property(cmp0022lib INTERFACE_LINK_LIBRARIES "cmp0022ifacelib")
- assert_property(cmp0022ifacelib INTERFACE_LINK_LIBRARIES "")
- add_executable(cmp0022exe cmp0022exe.cpp)
- target_link_libraries(cmp0022exe cmp0022lib)
- # Test adding unquoted genex with ';' to LINK_LIBRARIES and INTERFACE_LINK_LIBRARIES.
- target_link_libraries(cmp0022lib
- PUBLIC $<0:imp::missing1;imp::missing2>
- PRIVATE $<0:imp::missing3;imp::missing4>
- INTERFACE $<0:imp::missing5;imp::missing6>
- )
- assert_property(cmp0022lib INTERFACE_LINK_LIBRARIES "cmp0022ifacelib;$<0:imp::missing1;imp::missing2>;$<0:imp::missing5;imp::missing6>")
- assert_property(cmp0022lib LINK_LIBRARIES "cmp0022ifacelib;$<0:imp::missing1;imp::missing2>;$<0:imp::missing3;imp::missing4>")
- add_library(staticlib1 STATIC staticlib1.cpp)
- generate_export_header(staticlib1)
- add_library(staticlib2 STATIC staticlib2.cpp)
- generate_export_header(staticlib2)
- target_link_libraries(staticlib1 LINK_PUBLIC staticlib2)
- # Test adding LINK_ONLY to each of multiple specified libraries.
- add_library(staticlib2iface1 INTERFACE)
- add_library(staticlib2iface2 INTERFACE)
- target_compile_definitions(staticlib2iface1 INTERFACE STATICLIB2_IFACE_1)
- target_compile_definitions(staticlib2iface2 INTERFACE STATICLIB2_IFACE_2)
- target_link_libraries(staticlib2 PRIVATE staticlib2iface1 staticlib2iface2)
- # Test adding unquoted genex with ';' to LINK_LIBRARIES and INTERFACE_LINK_LIBRARIES.
- target_link_libraries(staticlib2
- PUBLIC $<0:imp::missing1;imp::missing2>
- PRIVATE $<0:imp::missing3;imp::missing4>
- INTERFACE $<0:imp::missing5;imp::missing6>
- )
- assert_property(staticlib2 INTERFACE_LINK_LIBRARIES "$<LINK_ONLY:staticlib2iface1>;$<LINK_ONLY:staticlib2iface2>;$<0:imp::missing1;imp::missing2>;$<LINK_ONLY:$<0:imp::missing3;imp::missing4>>;$<0:imp::missing5;imp::missing6>")
- assert_property(staticlib2 LINK_LIBRARIES "staticlib2iface1;staticlib2iface2;$<0:imp::missing1;imp::missing2>;$<0:imp::missing3;imp::missing4>")
- # Try adding a private link item to be propagated out of a static lib.
- set(private_link "")
- if (CMAKE_CXX_COMPILER_ID MATCHES GNU OR CMAKE_CXX_COMPILER_ID MATCHES Clang OR CMAKE_CXX_COMPILER_ID MATCHES LCC)
- if (CMAKE_SYSTEM_NAME STREQUAL "SunOS")
- set(private_link "-Wl,-V")
- else()
- set(private_link "-Wl,-v")
- endif()
- endif()
- if(private_link)
- target_link_libraries(staticlib1 LINK_PRIVATE "${private_link}")
- endif()
- add_executable(staticlib_exe staticlib_exe.cpp)
- target_link_libraries(staticlib_exe staticlib1)
- add_library(onlyplainlib1 SHARED onlyplainlib1.cpp)
- add_library(onlyplainlib2 SHARED onlyplainlib2.cpp)
- target_link_libraries(onlyplainlib2 onlyplainlib1)
- add_executable(onlyplainlib_user onlyplainlib_user.cpp)
- target_link_libraries(onlyplainlib_user onlyplainlib2)
|