Skip to content

Commit

Permalink
Processes variant when OBJECT lib links another OBJECT lib (#1569)
Browse files Browse the repository at this point in the history
This variant is important for dependency discovery because
linking of OBJECT(1) to OBJECT(2) doesn't mean that final
shared library (which links OBJECT(1)) contains also code from
OBJECT(2). It might bring wrong dependency and Swift code for
OBJECT(2) falsely imports incorrect Framework.

Signed-off-by: Yauheni Khnykin <[email protected]>
  • Loading branch information
Hsilgos authored Feb 7, 2024
1 parent e969fc5 commit d3ee832
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,18 @@ function(gluecodium_get_linked_targets_rec result visited_targets _target only_s
elseif(NOT _linked_type STREQUAL "INTERFACE_LIBRARY")
get_target_property(_framework ${_linked_lib} FRAMEWORK)
# Framework can be static, but it's still final target
if(_linked_type STREQUAL "SHARED_LIBRARY" OR _framework)
if(_framework)
continue()
endif()

# According to documentation object files only from directly linked OBJECT libraries are
# used. This check processes this variant.
if(_linked_type STREQUAL "OBJECT_LIBRARY"
AND (_target_type STREQUAL "OBJECT_LIBRARY" OR _target_type STREQUAL "INTERFACE_LIBRARY"
))
# Remove this OBJECT library from visited because it still can be directly linked in
# another place.
list(POP_BACK ${visited_targets})
continue()
endif()
endif()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,7 @@ test_expect_strequal_lists(
if(APPLE AND CMAKE_GENERATOR STREQUAL "Xcode")
# cmake-format: off
# (G) - target with generated code
# (F) - framework
#
# SHARED1(G) -> STATIC1(G) -> SHARED2(G)
# |-------> STATIC2 -> OBJECT1(G)
Expand All @@ -150,3 +151,38 @@ if(APPLE AND CMAKE_GENERATOR STREQUAL "Xcode")
test_expect_strequal_lists(EXPECTED shared1.generated.code static1.generated.code
object1.generated.code ACTUAL ${_targets})
endif()

# cmake-format: off
# (G) - target with generated code
# (F) - framework
#
# SHARED1(G) -> STATIC1(G) -> SHARED2(G)
# |-------> STATIC2 -> OBJECT1(G) -> OBJECT4(G)
# |-------> OBJECT3 -> SHARED1(G) - loop
# |-------> STATIC3(GF)
# cmake-format: on

add_library(object4.generated.code OBJECT EXCLUDE_FROM_ALL "cpp/FooImpl.cpp" "lime/foo.lime")
gluecodium_generate(object4.generated.code GENERATORS ${_gluecodium_generators})
target_link_libraries(object1.generated.code PRIVATE object4.generated.code)

gluecodium_get_linked_targets_with_generated_sources(_targets shared1.generated.code ONLY_STATIC)
test_expect_strequal_lists(EXPECTED shared1.generated.code static1.generated.code
object1.generated.code ACTUAL ${_targets})

# cmake-format: off
# (G) - target with generated code
# (F) - framework
#
# SHARED1(G) -> STATIC1(G) -> SHARED2(G)
# |-------> STATIC2 -> OBJECT1(G) -> OBJECT4(G)
# |-------> OBJECT3 -> SHARED1(G) - loop
# |-------> STATIC3(GF)
# |-------> OBJECT4(G)
# cmake-format: on

target_link_libraries(shared1.generated.code PRIVATE object4.generated.code)
gluecodium_get_linked_targets_with_generated_sources(_targets shared1.generated.code ONLY_STATIC)
test_expect_strequal_lists(
EXPECTED shared1.generated.code static1.generated.code object1.generated.code
object4.generated.code ACTUAL ${_targets})

0 comments on commit d3ee832

Please sign in to comment.