diff options
author | Marc Chevrier <marc.chevrier@gmail.com> | 2022-11-22 15:32:59 (GMT) |
---|---|---|
committer | Marc Chevrier <marc.chevrier@gmail.com> | 2022-11-22 15:44:45 (GMT) |
commit | 61075d2d7b0a77f53bc9a0d4c6644ab338f27886 (patch) | |
tree | 6d0130aaa0ee0f92877d4bd7895cfd67eeb92daa /Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake | |
parent | 3d1f91a245fec409b93c4f059ca50efcff9af578 (diff) | |
download | CMake-61075d2d7b0a77f53bc9a0d4c6644ab338f27886.zip CMake-61075d2d7b0a77f53bc9a0d4c6644ab338f27886.tar.gz CMake-61075d2d7b0a77f53bc9a0d4c6644ab338f27886.tar.bz2 |
XCode: ensure LINK_LIBRARY genex is usable with XCODE_LINK_BUILD_PHASE_MODE
Fixes: #24176
Diffstat (limited to 'Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake')
-rw-r--r-- | Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake | 62 |
1 files changed, 57 insertions, 5 deletions
diff --git a/Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake b/Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake index 7abc58b..a9ea717 100644 --- a/Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake +++ b/Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake @@ -65,8 +65,12 @@ add_custom_target(prebuildDependencies ALL COMMAND ${CMAKE_COMMAND} --build ${CMAKE_CURRENT_BINARY_DIR}/ExternalFrameworks/build --target staticFrameworkExt sharedFrameworkExt --config Debug ) add_executable(app1 mainOuter.m) +add_executable(app2 mainOuter.m) +add_executable(app3 mainOuter.m) add_library(static1 STATIC funcOuter.c) add_library(shared1 SHARED funcOuter.c) +add_library(shared3 SHARED funcOuter.c) +add_library(shared4 SHARED funcOuter.c) add_library(module1 MODULE funcOuter.c) add_library(obj1 OBJECT funcOuter.c) add_library(staticFramework1 STATIC funcOuter.c) @@ -74,8 +78,12 @@ add_library(sharedFramework1 SHARED funcOuter.c) set_target_properties(staticFramework1 PROPERTIES FRAMEWORK TRUE) set_target_properties(sharedFramework1 PROPERTIES FRAMEWORK TRUE) add_dependencies(app1 prebuildDependencies) +add_dependencies(app2 prebuildDependencies) +add_dependencies(app3 prebuildDependencies) add_dependencies(static1 prebuildDependencies) add_dependencies(shared1 prebuildDependencies) +add_dependencies(shared3 prebuildDependencies) +add_dependencies(shared4 prebuildDependencies) add_dependencies(module1 prebuildDependencies) add_dependencies(obj1 prebuildDependencies) add_dependencies(staticFramework1 prebuildDependencies) @@ -103,6 +111,14 @@ set(libresolv \"${libresolv}\") set(CoreFoundation \"${CoreFoundation}\") ") +macro(SET_LINK_LIBRARIES) + foreach(mainTarget IN LISTS mainTargets) + foreach(linkTo IN LISTS linkToThings) + target_link_libraries(${mainTarget} PRIVATE ${linkTo}) + endforeach() + endforeach() +endmacro() + set(mainTargets app1 static1 @@ -125,8 +141,44 @@ set(linkToThings "${CMAKE_CURRENT_BINARY_DIR}/ExternalFrameworks/build/Debug/staticFrameworkExt.framework" ) -foreach(mainTarget IN LISTS mainTargets) - foreach(linkTo IN LISTS linkToThings) - target_link_libraries(${mainTarget} PRIVATE ${linkTo}) - endforeach() -endforeach() +set_link_libraries() + +set(mainTargets + app2 + shared3 +) + +set(linkToThings + static2 + "$<LINK_LIBRARY:WEAK_LIBRARY,shared2>" + obj2 + staticFramework2 + "$<LINK_LIBRARY:WEAK_FRAMEWORK,sharedFramework2>" + imported2 + ${libresolv} + ${CoreFoundation} + "$<LINK_LIBRARY:WEAK_FRAMEWORK,${CMAKE_CURRENT_BINARY_DIR}/ExternalFrameworks/build/Debug/sharedFrameworkExt.framework>" + "${CMAKE_CURRENT_BINARY_DIR}/ExternalFrameworks/build/Debug/staticFrameworkExt.framework" +) + +set_link_libraries() + +set(mainTargets + app3 + shared4 +) + +set(linkToThings + static2 + "$<LINK_LIBRARY:REEXPORT_LIBRARY,shared2>" + obj2 + staticFramework2 + "$<LINK_LIBRARY:REEXPORT_FRAMEWORK,sharedFramework2>" + imported2 + ${libresolv} + ${CoreFoundation} + "$<LINK_LIBRARY:REEXPORT_FRAMEWORK,${CMAKE_CURRENT_BINARY_DIR}/ExternalFrameworks/build/Debug/sharedFrameworkExt.framework>" + "${CMAKE_CURRENT_BINARY_DIR}/ExternalFrameworks/build/Debug/staticFrameworkExt.framework" +) + +set_link_libraries() |