|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.3.1 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | kilted | 
| Last Updated | 2025-04-18 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.3.1 (2025-04-18)
- Switch to ament_cmake_ros_core package (#15)
- Bump minimum CMake version to 3.20 (#14)
- Contributors: Michael Carroll, mosfet80
0.3.0 (2024-11-20)
- Drop support for long double/float128. (#12)
- Contributors: Chris Lalancette
0.2.0 (2024-04-26)
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.4.0 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | rolling | 
| Last Updated | 2025-04-24 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.4.0 (2025-04-24)
0.3.1 (2025-04-18)
- Switch to ament_cmake_ros_core package (#15)
- Bump minimum CMake version to 3.20 (#14)
- Contributors: Michael Carroll, mosfet80
0.3.0 (2024-11-20)
- Drop support for long double/float128. (#12)
- Contributors: Chris Lalancette
0.2.0 (2024-04-26)
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.0.5 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | iron | 
| Last Updated | 2023-11-17 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.0.5 (2023-11-17)
- uchar: use __has_include(..) on separate line (#9)
- Contributors: G.A. vd. Hoorn
0.0.4 (2023-09-08)
- Add C++ version check to char16 definition (#6)
- Contributors: Antonio Cuadros
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c | 
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged rosidl_dynamic_typesupport at Robotics Stack Exchange
|   | rosidl_dynamic_typesupport package from rosidl_dynamic_typesupport reporosidl_dynamic_typesupport |  ROS Distro | 
Package Summary
| Version | 0.1.2 | 
| License | Apache License 2.0 | 
| Build type | AMENT_CMAKE | 
| Use | RECOMMENDED | 
Repository Summary
| Checkout URI | https://github.com/ros2/rosidl_dynamic_typesupport.git | 
| VCS Type | git | 
| VCS Version | jazzy | 
| Last Updated | 2023-09-07 | 
| Dev Status | MAINTAINED | 
| Released | RELEASED | 
| Contributing | Help Wanted (-) Good First Issues (-) Pull Requests to Review (-) | 
Package Description
Maintainers
- Brandon Ong
Authors
- Brandon Ong
rosidl_dynamic_typesupport
Unified Interface for Dynamic (Runtime) Typesupport and Serialization
This library provides a unified interface for creating and reflecting dynamic types and dynamic data based off those types at runtime, as well as the utilities that support those objects.
It is meant to be used with serialization support libraries that fulfill the interface. Properly implemented, a user should be able to, given a serialized buffer, the serialization library used to serialize it, and the buffer’s message/type description, obtain a way to introspect/reflect its contents.
Example Usage
// Init Serialization Support (in this case, using FastRTPS)
rosidl_dynamic_typesupport_serialization_support_t serialization_support;
  rosidl_dynamic_typesupport_serialization_support_init(
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_impl(),
    rosidl_dynamic_typesupport_fastrtps_init_serialization_support_interface(),
    rcutils_get_default_allocator(),
    &serialization_support);
// Configure Dynamic Type Builder
rosidl_dynamic_typesupport_dynamic_type_builder_t * flat_builder =
  rosidl_dynamic_typesupport_dynamic_type_builder_init(&serialization_support, "flat");
rosidl_dynamic_typesupport_dynamic_type_builder_add_bool_member(flat_builder, 0, "bool_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_int32_member(flat_builder, 1, "int32_field");
rosidl_dynamic_typesupport_dynamic_type_builder_add_string_member(flat_builder, 2, "string_field");
// Create Dynamic Type
rosidl_dynamic_typesupport_dynamic_type_t * flat_type =
  rosidl_dynamic_typesupport_dynamic_type_builder_build(flat_builder);
rosidl_dynamic_typesupport_dynamic_type_builder_fini(flat_builder);
// Create Dynamic Data
rosidl_dynamic_typesupport_dynamic_data_t * flat_data =
  rosidl_dynamic_typesupport_dynamic_data_init_from_dynamic_type(flat_type);
// Dynamic Data Setters
rosidl_dynamic_typesupport_dynamic_data_set_bool_value(flat_data, 0, true);
rosidl_dynamic_typesupport_dynamic_data_set_int32_value(flat_data, 1, 42);
rosidl_dynamic_typesupport_dynamic_data_set_string_value(flat_data, 2, "rar");
// Dynamic Data Getters
bool a;
int32_t b;
char * c;
rosidl_dynamic_typesupport_dynamic_data_get_bool_value(flat_data, 0, &a);  // true
rosidl_dynamic_typesupport_dynamic_data_get_int32_value(flat_data, 1, &b);  // 42
rosidl_dynamic_typesupport_dynamic_data_get_string_value(flat_data, 2, &c);  // "rar"
// Cleanup
free(c);
rosidl_dynamic_typesupport_dynamic_data_fini(flat_data);
Some Terminology
- Serialization support: What this library provides; A unified, serialization library agnostic interface
- Serialization support library: The implementation of the serialization support interface, which this library calls into
- Type description (aka message description): A description of the buffer that fulfills the rosidl spec (this typically takes the form of the TypeDescriptionstruct generated from the type_descripion_interfaces package)
- Dynamic type: The serialization support library’s best-effort internal representation of the type description
- Dynamic type builder: The serialization support library’s means of constructing the dynamic type (on a field-by-field basis)
- Dynamic data: The serialization support library’s internal representation of the serialized buffer, informed by the dynamic type
Why Dynamic Typesupport?
- Dynamic: This library dynamically changes its internal behavior based off its runtime input (e.g. what serialization library is loaded to be used with it)
- Typesupport: And it supports the creation of, and access of types
This package differs from the usual ROS 2 notion of “dynamic” typesupport in that it offers runtime functionalities that change based off its input (hence dynamic), rather than compile-time code generation like the “dynamic” rosidl_typesupport_introspection package does (which generates introspectable typesupports at compile time.)
Furthermore, since this package does not actually generate any code, it is stored separately from the rosidl repository.
The Serialization Support Interface
The serialization support interface is supposed to be an interface that is generic enough to support run-time type reflection (or in other words, dynamic type support), and is written in C to allow for easy language binding with any downstream libraries that use it.
Its interface is inspired by rosidl, and the DDS XTypes 1.3 language bindings spec (pg. 175), but is still intended to be generic, and so should support non-DDS middlewares.
The Serialization Support includes, for each supported middleware:
- Setting type members (dynamic type)
    - Note the lack of ability to get type members
 
- Getting and setting data members based off that type (dynamic data)
- Support for sequences and nested members
- Utilities
The interface makes heavy use of void * casting to abstract away any necessary objects used with each serialization library.
A Note On Proper Usage
The serialization support capabilities of this library are meant to be used alongside a rosidl-compliant description of the message a buffer is meant to represent (the type description).
This is because there is a distinction between the rosidl description of a message, and what a serialization library can describe or express (in its dynamic type.) As such, the rosidl description should be the sole source of determine what specific dynamic data getter functions are called during the unpacking of the message. And the serialization support library is in charge of supporting mapping to and from what types it can support, and the rosidl types.
Consider the following, contrived example, where you have a message layout like so:
```
File truncated at 100 lines see the full file
Changelog for package rosidl_dynamic_typesupport
0.1.2 (2023-09-07)
- uchar: fix conditional include/typedef (#10)
- uchar: use __has_include(..) on separate line (#8)
- Refactor the handling of nested types. (#7)
- Contributors: Chris Lalancette, G.A. vd. Hoorn
0.1.1 (2023-07-11)
- Add C++ version check to char16 definition (#3)
- Contributors: Antonio Cuadros
0.1.0 (2023-04-28)
0.0.3 (2023-04-12)
- Fix up the exports for rosidl_dynamic_typesupport. (#5)
- Contributors: Chris Lalancette
0.0.2 (2023-04-11)
Package Dependencies
| Deps | Name | 
|---|---|
| ament_cmake_ros | |
| rcutils | |
| rosidl_runtime_c |