summaryrefslogtreecommitdiffstats
path: root/Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake
diff options
context:
space:
mode:
authorMarc Chevrier <marc.chevrier@gmail.com>2022-11-22 15:32:59 (GMT)
committerMarc Chevrier <marc.chevrier@gmail.com>2022-11-22 15:44:45 (GMT)
commit61075d2d7b0a77f53bc9a0d4c6644ab338f27886 (patch)
tree6d0130aaa0ee0f92877d4bd7895cfd67eeb92daa /Tests/RunCMake/XcodeProject/LinkBinariesBuildPhase.cmake
parent3d1f91a245fec409b93c4f059ca50efcff9af578 (diff)
downloadCMake-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.cmake62
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()