Skip to content

Commit

Permalink
Resolve compilation errors and runtime failures to load introspection…
Browse files Browse the repository at this point in the history
… type support

Signed-off-by: Andrea Sorbini <asorbini@rti.com>
  • Loading branch information
asorbini committed Apr 12, 2021
1 parent 83bfd82 commit a64051f
Show file tree
Hide file tree
Showing 5 changed files with 71 additions and 5 deletions.
2 changes: 0 additions & 2 deletions rmw_connextdds_common/src/common/rmw_node.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,6 @@ rmw_api_connextdds_create_node(
const char * ns,
size_t domain_id,
const rmw_node_security_options_t * security_options,
size_t domain_id,
const rmw_node_security_options_t * security_options,
bool localhost_only)
{
RMW_CHECK_ARGUMENT_FOR_NULL(context, nullptr);
Expand Down
4 changes: 2 additions & 2 deletions rmw_dds_common/rmw_dds_common/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ ament_export_dependencies(ament_cmake_core)
ament_export_dependencies(rcpputils)
ament_export_dependencies(rcutils)
ament_export_dependencies(rmw)
ament_export_dependencies(rosidl_default_runtime)
ament_export_dependencies(rmw_dds_common_typesupports)

rosidl_generate_interfaces(
${PROJECT_NAME}
Expand All @@ -39,7 +39,7 @@ ament_target_dependencies(${PROJECT_NAME}_library
"rcpputils"
"rcutils"
"rmw"
"rosidl_runtime_cpp")
"rmw_dds_common_typesupports")
add_dependencies(${PROJECT_NAME}_library
${PROJECT_NAME})
target_include_directories(${PROJECT_NAME}_library
Expand Down
2 changes: 1 addition & 1 deletion rmw_dds_common/rmw_dds_common/package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
<depend>rcutils</depend>
<depend>rcpputils</depend>
<depend>rmw</depend>
<depend>rosidl_runtime_cpp</depend>
<depend>rmw_dds_common_typesupports</depend>

<test_depend>ament_cmake_gmock</test_depend>
<test_depend>ament_lint_auto</test_depend>
Expand Down
45 changes: 45 additions & 0 deletions rmw_dds_common/rmw_dds_common_typesupports/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
cmake_minimum_required(VERSION 3.5)
project(rmw_dds_common_typesupports)

# Default to C99
if(NOT CMAKE_C_STANDARD)
set(CMAKE_C_STANDARD 99)
endif()

# Default to C++14
if(NOT CMAKE_CXX_STANDARD)
set(CMAKE_CXX_STANDARD 14)
endif()

if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
add_compile_options(-Wall -Wextra -Wpedantic)
endif()

# find dependencies
find_package(ament_cmake REQUIRED)

# Load type support packages to make sure that they are installed
find_package(rosidl_typesupport_fastrtps_c REQUIRED)
find_package(rosidl_typesupport_fastrtps_cpp REQUIRED)
find_package(rosidl_typesupport_introspection_c REQUIRED)
find_package(rosidl_typesupport_introspection_cpp REQUIRED)

# This is an hack to have the `rosidl_generate_interfaces()` function consider
# all the type supports required by `rmw_connextdds` even though that RMW
# implementation has not yet been registered.
ament_index_register_resource(rmw_typesupport CONTENT
"rosidl_typesupport_c;rosidl_typesupport_fastrtps_c;rosidl_typesupport_introspection_c;rosidl_typesupport_cpp;rosidl_typesupport_fastrtps_cpp;rosidl_typesupport_introspection_cpp")


if(BUILD_TESTING)
find_package(ament_lint_auto REQUIRED)
# the following line skips the linter which checks for copyrights
# uncomment the line when a copyright and license is not present in all source files
#set(ament_cmake_copyright_FOUND TRUE)
# the following line skips cpplint (only works in a git repo)
# uncomment the line when this package is not in a git repo
#set(ament_cmake_cpplint_FOUND TRUE)
ament_lint_auto_find_test_dependencies()
endif()

ament_package()
23 changes: 23 additions & 0 deletions rmw_dds_common/rmw_dds_common_typesupports/package.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
<?xml version="1.0"?>
<?xml-model href="http://download.ros.org/schema/package_format3.xsd" schematypens="http://www.w3.org/2001/XMLSchema"?>
<package format="3">
<name>rmw_dds_common_typesupports</name>
<version>0.1.0</version>
<description>A meta-package to hack type support generation for backported rmw_dds_common</description>
<maintainer email="asorbini@rti.com">Andrea Sorbini</maintainer>
<license>Apache 2.0</license>

<buildtool_depend>ament_cmake</buildtool_depend>

<depend>rosidl_typesupport_fastrtps_c</depend>
<depend>rosidl_typesupport_fastrtps_cpp</depend>
<depend>rosidl_typesupport_introspection_c</depend>
<depend>rosidl_typesupport_introspection_cpp</depend>

<test_depend>ament_lint_auto</test_depend>
<test_depend>ament_lint_common</test_depend>

<export>
<build_type>ament_cmake</build_type>
</export>
</package>

0 comments on commit a64051f

Please sign in to comment.