Closed clalancette closed 10 months ago
Thanks @clalancette ! One problem of using imported target for linking, is that even if the library is linked as PRIVATE, if the library is compiled is STATIC
, you still need to make sure that any PRIVATE-linked target is found in the <package>-config.cmake
. This is due to the fact that if you have a downstream executable that links a urdfdom
library, it also needs to link the tinyxml2
library (that can be either static or shared).
However, looking at the systems for which urdfdom is packaged (https://repology.org/project/urdfdom/versions) this is just a problem of *-static
triplets of vcpkg (or perhaps conan, but I do not have an experience with that), so I think we can safely assume that if one wants to build urdfdom
as static (i.e. BUILD_SHARED_LIBS=OFF
) it is on a system in which tinyxml2
installs a tinyxml2-config.cmake
file. In that case, the required modifications are minimal.
Thanks @clalancette ! One problem of using imported target for linking, is that even if the library is linked as PRIVATE, if the library is compiled is
STATIC
, you still need to make sure that any PRIVATE-linked target is found in the<package>-config.cmake
. This is due to the fact that if you have a downstream executable that links aurdfdom
library, it also needs to link thetinyxml2
library (that can be either static or shared).However, looking at the systems for which urdfdom is packaged (https://repology.org/project/urdfdom/versions) this is just a problem of
*-static
triplets of vcpkg (or perhaps conan, but I do not have an experience with that), so I think we can safely assume that if one wants to buildurdfdom
as static (i.e.BUILD_SHARED_LIBS=OFF
) it is on a system in whichtinyxml2
installs atinyxml2-config.cmake
file. In that case, the required modifications are minimal.
Actually we are currently hardcoding libraries to be SHARED
in https://github.com/ros/urdfdom/blob/10093ba12c74e64977ab6620c2da99db823a10cf/urdf_parser/CMakeLists.txt#L6, so clearly we are not supporting the use case of building static libraries, so I think the PR is good to go as it is.
, so clearly we are not supporting the use case of building static libraries, so I think the PR is good to go as it is.
Thanks Silvio! If we want to support that in the future I'll guess we'll have to do some additional modifications, but I'll go ahead and merge this one as-is for now.
That way, we don't have to export the tinyxml2 dependencies to downstream consumers. It is just a private dependency at that point.
Based on the code in https://github.com/SMillerDev/urdfdom/commit/092b57c20bca37d1d81eaa6da6b08a7bebb04662
Closes #189
@scpeters @sloretz Thoughts from both of you appreciated.
@traversaro If you have time, any testing you can do on this is highly appreciated.