Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[occupancy_map_monitor] add dependencies #1901

Merged

Conversation

gleichdick
Copy link
Contributor

Description

explicit dependencies to tf2_ros, geometric_shapes and boost are added.
I noticed some linking errors while compiling from source. Applies to master as well

Checklist

  • Required by CI: Code is auto formatted using clang-format
  • Extend the tutorials / documentation reference
  • Document API changes relevant to the user in the MIGRATION.md notes
  • Create tests, which fail without this PR reference
  • Include a screenshot if changing a GUI
  • While waiting for someone to review your request, please help review another open pull request to support the maintainers

@gleichdick gleichdick force-pushed the fix_occupancy_dependencies_melodic branch from 75b45d1 to ec302c5 Compare February 14, 2020 17:47
Copy link
Contributor

@rhaschke rhaschke left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm curious about which kind of linking errors you've got. Usually, all those dependencies should be transitively pulled in.

@@ -10,7 +10,7 @@ if(NOT CMAKE_CONFIGURATION_TYPES AND NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE Release)
endif()

find_package(Boost REQUIRED thread)
find_package(Boost REQUIRED thread function)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no specific lib required for boost::function, it's just part of the headers.
This change makes Travis failing.

DEPENDS
EIGEN3
OCTOMAP
Boost
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no need to explicitly link downstream projects against boost.

explicit dependencies to tf2_ros, geometric_shapes and boost are added
@gleichdick gleichdick force-pushed the fix_occupancy_dependencies_melodic branch from ec302c5 to f38cadf Compare February 15, 2020 10:49
@gleichdick
Copy link
Contributor Author

The error message was:

/usr/bin/ld: CMakeFiles/moveit_ros_occupancy_map_server.dir/src/occupancy_map_server.cpp.o: in function `std::_Sp_counted_ptr_inplace<tf2_ros::TransformListener, std::allocator<tf2_ros::TransformListener>, (__gnu_cxx::_Lock_policy)2>::_M_dispose()':
occupancy_map_server.cpp:(.text._ZNSt23_Sp_counted_ptr_inplaceIN7tf2_ros17TransformListenerESaIS1_ELN9__gnu_cxx12_Lock_policyE2EE10_M_disposeEv[_ZNSt23_Sp_counted_ptr_inplaceIN7tf2_ros17TransformListenerESaIS1_ELN9__gnu_cxx12_Lock_policyE2EE10_M_disposeEv]+0x5): undefined reference to `tf2_ros::TransformListener::~TransformListener()'
/usr/bin/ld: CMakeFiles/moveit_ros_occupancy_map_server.dir/src/occupancy_map_server.cpp.o: in function `main':
occupancy_map_server.cpp:(.text.startup+0x187): undefined reference to `tf2_ros::Buffer::Buffer(ros::Duration, bool)'
/usr/bin/ld: occupancy_map_server.cpp:(.text.startup+0x1da): undefined reference to `tf2_ros::TransformListener::TransformListener(tf2::BufferCore&, ros::NodeHandle const&, bool)'

I noticed it when I tried to compile moveit from source on Debian Buster. tf2 was from the repo (libtf2-ros-dev 0.6.5-3).
Unfortunately there is right now a dependency issue with catkin on Buster so I could not create a docker container from scratch to reproduce it. However, compiling everything from source (including tf2) without this patch works too.

@rhaschke rhaschke merged commit 301c80a into moveit:melodic-devel Feb 15, 2020
sjahr pushed a commit to sjahr/moveit that referenced this pull request Jun 21, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants