Skip to content

Commit

Permalink
cxxbridge: Link to static and shared crate
Browse files Browse the repository at this point in the history
This is a convenience for the user, as this is usually needed anyway.
  • Loading branch information
LeonMatthesKDAB authored and jschwe committed Dec 4, 2024
1 parent 27cced0 commit 934fee2
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 4 deletions.
10 changes: 7 additions & 3 deletions cmake/Corrosion.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -1561,9 +1561,6 @@ Corrosion does not import `rlib` only libraries. As a workaround users can add
by either adding an option to also import Rlib targets (without build rules) or by
adding a `MANIFEST_PATH` argument to this function, specifying where the crate is.
The generated `cxxtarget` CMake library target does not yet link to anything.
This is left to the user, as the exact requirements for linking are not known when creating the target.
### Contributing
Specifically some more realistic test / demo projects and feedback about limitations would be
Expand Down Expand Up @@ -1698,6 +1695,13 @@ function(corrosion_add_cxxbridge cxx_target)
# cxx generated code is using c++11 features in headers, so propagate c++11 as minimal requirement
target_compile_features(${cxx_target} PUBLIC cxx_std_11)

if (TARGET "${_arg_CRATE}-static")
target_link_libraries(${cxx_target} PRIVATE "${_arg_CRATE}-static")
endif()
if (TARGET "${_arg_CRATE}-shared")
target_link_libraries(${cxx_target} PRIVATE "${_arg_CRATE}-shared")
endif()

file(MAKE_DIRECTORY "${generated_dir}/include/rust")
add_custom_command(
OUTPUT "${generated_dir}/include/rust/cxx.h"
Expand Down
1 change: 0 additions & 1 deletion test/cxxbridge/cxxbridge_rust2cpp/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ set(CMAKE_CXX_STANDARD_REQUIRED 1)

corrosion_import_crate(MANIFEST_PATH rust/Cargo.toml)
corrosion_add_cxxbridge(cxxbridge-cpp CRATE cxxbridge_crate MANIFEST_PATH rust FILES lib.rs foo/mod.rs)
target_link_libraries(cxxbridge-cpp PRIVATE cxxbridge_crate)

add_executable(cxxbridge-exe main.cpp)
target_link_libraries(cxxbridge-exe PUBLIC cxxbridge-cpp)
Expand Down

0 comments on commit 934fee2

Please sign in to comment.