| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 | 
							- cmake_policy(SET CMP0028 NEW)
 
- 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)
 
 
  |