-
 
No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

async_comm package from async_comm repo

async_comm

Package Summary

Tags No category tags.
Version 0.2.1
License BSD
Build type CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/dpkoch/async_comm.git
VCS Type git
VCS Version master
Last Updated 2021-05-14
Dev Status DEVELOPED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

A C++ library for asynchronous serial communication

Additional Links

Maintainers

  • Daniel Koch

Authors

No additional authors.

Async Comm Library

CI Status ROS Buildfarm Status Documentation Status

This project provides a C++ library that gives a simple interface for asynchronous serial communications over a serial port or UDP. It uses the Boost.Asio library under the hood, but hides from the user the details of interfacing with the ports or sockets and managing send/receive buffers.

Including in your project

There are three ways to use the async_comm library in your project:

  1. If you’ll be using the library in a ROS package, install from the ROS repositories
  2. Build and install the library on your system, then use CMake’s find_package() functionality
  3. Include the async_comm as a submodule in your project

With the second and third options, you will need to ensure that the Boost library is installed before proceeding:

sudo apt -y install libboost-dev libboost-system-dev

ROS install

The async_comm library is released as a third-party, non-catkin package for ROS following the guidelines in REP 136. To use the library in your ROS package, first install the library from the ROS repositories:

sudo apt install ros-<DISTRO>-async-comm

Replace <DISTRO> with your ROS distribution. The library is currently released for kinetic, lunar, and melodic.

Then, add something like the following lines to your package’s CMakeLists.txt:

# ...

find_package(async_comm REQUIRED)

catkin_package(
  # ...
  DEPENDS async_comm
)

# ...

add_executable(my_node src/my_node.cpp)
target_link_libraries(my_node ${async_comm_LIBRARIES})

Also be sure to list async_comm as a dependency in your package.xml:

<?xml version="1.0"?>
<package format="2">
  ...
  <depend>async_comm</depend>
  ...
</package>

System install

First, download and install the library:

git clone https://github.com/dpkoch/async_comm.git
cd async_comm
mkdir build && cd build/
cmake .. && make
sudo make install

Then, do something like this in your project’s CMakeLists.txt:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

find_package(async_comm REQUIRED)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project ${async_comm_LIBRARIES})

Including as a submodule

If you don’t want to go with the ROS or system install options, the next easiest way to embed the async_comm library in your project is as a Git submodule. The following instructions are for a project using Git for version control and CMake for a build system, but should serve as a starting point for other setups.

For example, to put async_comm in the lib/async_comm directory, run the following from the root of your project:

git submodule add https://github.com/dpkoch/async_comm.git lib/async_comm

Your CMakeLists.txt file would then look something like this:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

add_subdirectory(lib/async_comm)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project async_comm)

Usage

There are three classes that you’ll use directly as a user:

  • async_comm::Serial: for communication over a serial port
  • async_comm::UDP: for communication over a UDP socket
  • async_comm::TCPClient: for communication over a TCP socket (client)

All classes have the same interface and inherit from the async_comm::Comm base class. The constructors for each class require the arguments to specify the details of the serial port, UDP or TCP socket.

The interface consists of the following functions:

  • bool init(): initializes and opens the port or socket
  • void register_receive_callback(std::function<void(const uint8_t*, size_t)> fun): register a user-defined function to handle received bytes; this function will be called by the Serial, UDP or TCPClient object every time a new data is received
  • void send_bytes(const uint8_t * src, size_t len): send the specified number of bytes from the specified source buffer
  • void close(): close the port or socket

More details can be found in the code API documentation. Very simple example programs are provided to illustrate the usage as described below.

One tricky part is registering the member function of a class as the receive callback. This is accomplished using std::bind. For example, if I want to register the receive function of MyClass from within the class, I would use

serial_.register_receive_callback(std::bind(&MyClass::receive, this, std::placeholders::_1, std::placeholders::_2));

where serial_ is an instance of async_comm::Serial.

Message Handlers

It is possible to implement custom handlers for the error messages and other messages produced by the library. To create a message handler, simply inherit from the MessageHandler abstract base class defined in include/async_comm/message_handler.h, and override the pure virtual functions.

Each of the user-facing classes accepts, as an optional final argument, a reference to a class that derives from MessageHandler. To use a custom message handler, simply create an instance of your handler and pass it as that optional argument. When that argument is omitted, the library uses a default message handler that prints to stdout and stderr.

A custom message handler can be especially useful, for example, when the library is used as part of a ROS node and you wish to forward the error messages to the rosconsole logging functionality. A convenience class MessageHandlerROS has been provided for this purpose. To use this handler, do something like the following:

#include <async_comm/serial.h>
#include <async_comm/util/message_handler_ros.h>

#include <ros/ros.h>

// ...

async_comm::util::MessageHandlerROS rosconsole_handler;
async_comm::Serial serial("/dev/ttyUSB0", 115200, rosconsole_handler);

// ...

Examples

There are three examples provided in the repository. The first two are very simple, while the third is more complete. To build the examples, run CMake with the -DASYNC_COMM_BUILD_EXAMPLES=ON flag.

  • examples/serial_loopback.cpp: Designed for use with a USB-to-UART adapter with the RX and TX pins connected together (loopback). Sends a series of bytes out and prints them to the console as they are received back.
  • examples/udp_hello_world.cpp: Opens two UDP objects listening on different ports on the local host, and then uses each to send a simple “hello world” message to the other.
  • examples/serial_protocol.cpp: Implements a simple serial protocol and parser for a message that includes two integer values, including a cyclic reduncancy check. Tests the protocol and async_comm library over a serial loopback.
  • examples/tcp_client_hello_world.cpp: Opens a TCP client that sends “hello world” messages. Example only runs with a valid running TCP/IP server. Server can be started using netcat: nc -l 16140.
CHANGELOG

Changelog for package async_comm

0.2.1 (2021-01-21)

  • Add noetic to ROS prerelease test distribution list
  • Fixes for compatibility with ROS2 workspaces:
    • cmake: Change install paths to basic lib/ and include/
    • package.xml: Remove unneeded catkin dependency
  • Updated CMake examples in README
  • Contributors: Daniel Koch, Maciej Bogusz

0.2.0 (2020-03-16)

  • Fix for UDP/TCP when loopback is only device with an address
  • Added listener interface
  • Added custom message handler functionality
  • TCPClient class implementing an async tcp client
  • Contributors: Daniel Koch, James Jackson, Rein Appeldoorn

0.1.1 (2019-02-21)

  • Some cleanup
  • Process callbacks on a separate thread
  • Made buffer sizes constant, removed faulty mechanism for overriding
  • Removed requirement that bulk write length be no greater than write buffer size
  • Contributors: Daniel Koch

0.1.0 (2018-08-31)

  • Initial release
  • Contributors: Daniel Koch, James Jackson

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

No dependencies on ROS packages.

System Dependencies

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged async_comm at Robotics Stack Exchange

No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.

async_comm package from async_comm repo

async_comm

Package Summary

Tags No category tags.
Version 0.2.1
License BSD
Build type CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/dpkoch/async_comm.git
VCS Type git
VCS Version master
Last Updated 2021-05-14
Dev Status DEVELOPED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

A C++ library for asynchronous serial communication

Additional Links

Maintainers

  • Daniel Koch

Authors

No additional authors.

Async Comm Library

CI Status ROS Buildfarm Status Documentation Status

This project provides a C++ library that gives a simple interface for asynchronous serial communications over a serial port or UDP. It uses the Boost.Asio library under the hood, but hides from the user the details of interfacing with the ports or sockets and managing send/receive buffers.

Including in your project

There are three ways to use the async_comm library in your project:

  1. If you’ll be using the library in a ROS package, install from the ROS repositories
  2. Build and install the library on your system, then use CMake’s find_package() functionality
  3. Include the async_comm as a submodule in your project

With the second and third options, you will need to ensure that the Boost library is installed before proceeding:

sudo apt -y install libboost-dev libboost-system-dev

ROS install

The async_comm library is released as a third-party, non-catkin package for ROS following the guidelines in REP 136. To use the library in your ROS package, first install the library from the ROS repositories:

sudo apt install ros-<DISTRO>-async-comm

Replace <DISTRO> with your ROS distribution. The library is currently released for kinetic, lunar, and melodic.

Then, add something like the following lines to your package’s CMakeLists.txt:

# ...

find_package(async_comm REQUIRED)

catkin_package(
  # ...
  DEPENDS async_comm
)

# ...

add_executable(my_node src/my_node.cpp)
target_link_libraries(my_node ${async_comm_LIBRARIES})

Also be sure to list async_comm as a dependency in your package.xml:

<?xml version="1.0"?>
<package format="2">
  ...
  <depend>async_comm</depend>
  ...
</package>

System install

First, download and install the library:

git clone https://github.com/dpkoch/async_comm.git
cd async_comm
mkdir build && cd build/
cmake .. && make
sudo make install

Then, do something like this in your project’s CMakeLists.txt:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

find_package(async_comm REQUIRED)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project ${async_comm_LIBRARIES})

Including as a submodule

If you don’t want to go with the ROS or system install options, the next easiest way to embed the async_comm library in your project is as a Git submodule. The following instructions are for a project using Git for version control and CMake for a build system, but should serve as a starting point for other setups.

For example, to put async_comm in the lib/async_comm directory, run the following from the root of your project:

git submodule add https://github.com/dpkoch/async_comm.git lib/async_comm

Your CMakeLists.txt file would then look something like this:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

add_subdirectory(lib/async_comm)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project async_comm)

Usage

There are three classes that you’ll use directly as a user:

  • async_comm::Serial: for communication over a serial port
  • async_comm::UDP: for communication over a UDP socket
  • async_comm::TCPClient: for communication over a TCP socket (client)

All classes have the same interface and inherit from the async_comm::Comm base class. The constructors for each class require the arguments to specify the details of the serial port, UDP or TCP socket.

The interface consists of the following functions:

  • bool init(): initializes and opens the port or socket
  • void register_receive_callback(std::function<void(const uint8_t*, size_t)> fun): register a user-defined function to handle received bytes; this function will be called by the Serial, UDP or TCPClient object every time a new data is received
  • void send_bytes(const uint8_t * src, size_t len): send the specified number of bytes from the specified source buffer
  • void close(): close the port or socket

More details can be found in the code API documentation. Very simple example programs are provided to illustrate the usage as described below.

One tricky part is registering the member function of a class as the receive callback. This is accomplished using std::bind. For example, if I want to register the receive function of MyClass from within the class, I would use

serial_.register_receive_callback(std::bind(&MyClass::receive, this, std::placeholders::_1, std::placeholders::_2));

where serial_ is an instance of async_comm::Serial.

Message Handlers

It is possible to implement custom handlers for the error messages and other messages produced by the library. To create a message handler, simply inherit from the MessageHandler abstract base class defined in include/async_comm/message_handler.h, and override the pure virtual functions.

Each of the user-facing classes accepts, as an optional final argument, a reference to a class that derives from MessageHandler. To use a custom message handler, simply create an instance of your handler and pass it as that optional argument. When that argument is omitted, the library uses a default message handler that prints to stdout and stderr.

A custom message handler can be especially useful, for example, when the library is used as part of a ROS node and you wish to forward the error messages to the rosconsole logging functionality. A convenience class MessageHandlerROS has been provided for this purpose. To use this handler, do something like the following:

#include <async_comm/serial.h>
#include <async_comm/util/message_handler_ros.h>

#include <ros/ros.h>

// ...

async_comm::util::MessageHandlerROS rosconsole_handler;
async_comm::Serial serial("/dev/ttyUSB0", 115200, rosconsole_handler);

// ...

Examples

There are three examples provided in the repository. The first two are very simple, while the third is more complete. To build the examples, run CMake with the -DASYNC_COMM_BUILD_EXAMPLES=ON flag.

  • examples/serial_loopback.cpp: Designed for use with a USB-to-UART adapter with the RX and TX pins connected together (loopback). Sends a series of bytes out and prints them to the console as they are received back.
  • examples/udp_hello_world.cpp: Opens two UDP objects listening on different ports on the local host, and then uses each to send a simple “hello world” message to the other.
  • examples/serial_protocol.cpp: Implements a simple serial protocol and parser for a message that includes two integer values, including a cyclic reduncancy check. Tests the protocol and async_comm library over a serial loopback.
  • examples/tcp_client_hello_world.cpp: Opens a TCP client that sends “hello world” messages. Example only runs with a valid running TCP/IP server. Server can be started using netcat: nc -l 16140.
CHANGELOG

Changelog for package async_comm

0.2.1 (2021-01-21)

  • Add noetic to ROS prerelease test distribution list
  • Fixes for compatibility with ROS2 workspaces:
    • cmake: Change install paths to basic lib/ and include/
    • package.xml: Remove unneeded catkin dependency
  • Updated CMake examples in README
  • Contributors: Daniel Koch, Maciej Bogusz

0.2.0 (2020-03-16)

  • Fix for UDP/TCP when loopback is only device with an address
  • Added listener interface
  • Added custom message handler functionality
  • TCPClient class implementing an async tcp client
  • Contributors: Daniel Koch, James Jackson, Rein Appeldoorn

0.1.1 (2019-02-21)

  • Some cleanup
  • Process callbacks on a separate thread
  • Made buffer sizes constant, removed faulty mechanism for overriding
  • Removed requirement that bulk write length be no greater than write buffer size
  • Contributors: Daniel Koch

0.1.0 (2018-08-31)

  • Initial release
  • Contributors: Daniel Koch, James Jackson

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

No dependencies on ROS packages.

System Dependencies

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged async_comm at Robotics Stack Exchange

No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.

async_comm package from async_comm repo

async_comm

Package Summary

Tags No category tags.
Version 0.2.1
License BSD
Build type CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/dpkoch/async_comm.git
VCS Type git
VCS Version master
Last Updated 2021-05-14
Dev Status DEVELOPED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

A C++ library for asynchronous serial communication

Additional Links

Maintainers

  • Daniel Koch

Authors

No additional authors.

Async Comm Library

CI Status ROS Buildfarm Status Documentation Status

This project provides a C++ library that gives a simple interface for asynchronous serial communications over a serial port or UDP. It uses the Boost.Asio library under the hood, but hides from the user the details of interfacing with the ports or sockets and managing send/receive buffers.

Including in your project

There are three ways to use the async_comm library in your project:

  1. If you’ll be using the library in a ROS package, install from the ROS repositories
  2. Build and install the library on your system, then use CMake’s find_package() functionality
  3. Include the async_comm as a submodule in your project

With the second and third options, you will need to ensure that the Boost library is installed before proceeding:

sudo apt -y install libboost-dev libboost-system-dev

ROS install

The async_comm library is released as a third-party, non-catkin package for ROS following the guidelines in REP 136. To use the library in your ROS package, first install the library from the ROS repositories:

sudo apt install ros-<DISTRO>-async-comm

Replace <DISTRO> with your ROS distribution. The library is currently released for kinetic, lunar, and melodic.

Then, add something like the following lines to your package’s CMakeLists.txt:

# ...

find_package(async_comm REQUIRED)

catkin_package(
  # ...
  DEPENDS async_comm
)

# ...

add_executable(my_node src/my_node.cpp)
target_link_libraries(my_node ${async_comm_LIBRARIES})

Also be sure to list async_comm as a dependency in your package.xml:

<?xml version="1.0"?>
<package format="2">
  ...
  <depend>async_comm</depend>
  ...
</package>

System install

First, download and install the library:

git clone https://github.com/dpkoch/async_comm.git
cd async_comm
mkdir build && cd build/
cmake .. && make
sudo make install

Then, do something like this in your project’s CMakeLists.txt:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

find_package(async_comm REQUIRED)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project ${async_comm_LIBRARIES})

Including as a submodule

If you don’t want to go with the ROS or system install options, the next easiest way to embed the async_comm library in your project is as a Git submodule. The following instructions are for a project using Git for version control and CMake for a build system, but should serve as a starting point for other setups.

For example, to put async_comm in the lib/async_comm directory, run the following from the root of your project:

git submodule add https://github.com/dpkoch/async_comm.git lib/async_comm

Your CMakeLists.txt file would then look something like this:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

add_subdirectory(lib/async_comm)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project async_comm)

Usage

There are three classes that you’ll use directly as a user:

  • async_comm::Serial: for communication over a serial port
  • async_comm::UDP: for communication over a UDP socket
  • async_comm::TCPClient: for communication over a TCP socket (client)

All classes have the same interface and inherit from the async_comm::Comm base class. The constructors for each class require the arguments to specify the details of the serial port, UDP or TCP socket.

The interface consists of the following functions:

  • bool init(): initializes and opens the port or socket
  • void register_receive_callback(std::function<void(const uint8_t*, size_t)> fun): register a user-defined function to handle received bytes; this function will be called by the Serial, UDP or TCPClient object every time a new data is received
  • void send_bytes(const uint8_t * src, size_t len): send the specified number of bytes from the specified source buffer
  • void close(): close the port or socket

More details can be found in the code API documentation. Very simple example programs are provided to illustrate the usage as described below.

One tricky part is registering the member function of a class as the receive callback. This is accomplished using std::bind. For example, if I want to register the receive function of MyClass from within the class, I would use

serial_.register_receive_callback(std::bind(&MyClass::receive, this, std::placeholders::_1, std::placeholders::_2));

where serial_ is an instance of async_comm::Serial.

Message Handlers

It is possible to implement custom handlers for the error messages and other messages produced by the library. To create a message handler, simply inherit from the MessageHandler abstract base class defined in include/async_comm/message_handler.h, and override the pure virtual functions.

Each of the user-facing classes accepts, as an optional final argument, a reference to a class that derives from MessageHandler. To use a custom message handler, simply create an instance of your handler and pass it as that optional argument. When that argument is omitted, the library uses a default message handler that prints to stdout and stderr.

A custom message handler can be especially useful, for example, when the library is used as part of a ROS node and you wish to forward the error messages to the rosconsole logging functionality. A convenience class MessageHandlerROS has been provided for this purpose. To use this handler, do something like the following:

#include <async_comm/serial.h>
#include <async_comm/util/message_handler_ros.h>

#include <ros/ros.h>

// ...

async_comm::util::MessageHandlerROS rosconsole_handler;
async_comm::Serial serial("/dev/ttyUSB0", 115200, rosconsole_handler);

// ...

Examples

There are three examples provided in the repository. The first two are very simple, while the third is more complete. To build the examples, run CMake with the -DASYNC_COMM_BUILD_EXAMPLES=ON flag.

  • examples/serial_loopback.cpp: Designed for use with a USB-to-UART adapter with the RX and TX pins connected together (loopback). Sends a series of bytes out and prints them to the console as they are received back.
  • examples/udp_hello_world.cpp: Opens two UDP objects listening on different ports on the local host, and then uses each to send a simple “hello world” message to the other.
  • examples/serial_protocol.cpp: Implements a simple serial protocol and parser for a message that includes two integer values, including a cyclic reduncancy check. Tests the protocol and async_comm library over a serial loopback.
  • examples/tcp_client_hello_world.cpp: Opens a TCP client that sends “hello world” messages. Example only runs with a valid running TCP/IP server. Server can be started using netcat: nc -l 16140.
CHANGELOG

Changelog for package async_comm

0.2.1 (2021-01-21)

  • Add noetic to ROS prerelease test distribution list
  • Fixes for compatibility with ROS2 workspaces:
    • cmake: Change install paths to basic lib/ and include/
    • package.xml: Remove unneeded catkin dependency
  • Updated CMake examples in README
  • Contributors: Daniel Koch, Maciej Bogusz

0.2.0 (2020-03-16)

  • Fix for UDP/TCP when loopback is only device with an address
  • Added listener interface
  • Added custom message handler functionality
  • TCPClient class implementing an async tcp client
  • Contributors: Daniel Koch, James Jackson, Rein Appeldoorn

0.1.1 (2019-02-21)

  • Some cleanup
  • Process callbacks on a separate thread
  • Made buffer sizes constant, removed faulty mechanism for overriding
  • Removed requirement that bulk write length be no greater than write buffer size
  • Contributors: Daniel Koch

0.1.0 (2018-08-31)

  • Initial release
  • Contributors: Daniel Koch, James Jackson

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

No dependencies on ROS packages.

System Dependencies

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged async_comm at Robotics Stack Exchange

async_comm package from async_comm repo

async_comm

Package Summary

Tags No category tags.
Version 0.2.1
License BSD
Build type CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/dpkoch/async_comm.git
VCS Type git
VCS Version master
Last Updated 2021-05-14
Dev Status DEVELOPED
CI status Continuous Integration : 0 / 0
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

A C++ library for asynchronous serial communication

Additional Links

Maintainers

  • Daniel Koch

Authors

No additional authors.

Async Comm Library

CI Status ROS Buildfarm Status Documentation Status

This project provides a C++ library that gives a simple interface for asynchronous serial communications over a serial port or UDP. It uses the Boost.Asio library under the hood, but hides from the user the details of interfacing with the ports or sockets and managing send/receive buffers.

Including in your project

There are three ways to use the async_comm library in your project:

  1. If you’ll be using the library in a ROS package, install from the ROS repositories
  2. Build and install the library on your system, then use CMake’s find_package() functionality
  3. Include the async_comm as a submodule in your project

With the second and third options, you will need to ensure that the Boost library is installed before proceeding:

sudo apt -y install libboost-dev libboost-system-dev

ROS install

The async_comm library is released as a third-party, non-catkin package for ROS following the guidelines in REP 136. To use the library in your ROS package, first install the library from the ROS repositories:

sudo apt install ros-<DISTRO>-async-comm

Replace <DISTRO> with your ROS distribution. The library is currently released for kinetic, lunar, and melodic.

Then, add something like the following lines to your package’s CMakeLists.txt:

# ...

find_package(async_comm REQUIRED)

catkin_package(
  # ...
  DEPENDS async_comm
)

# ...

add_executable(my_node src/my_node.cpp)
target_link_libraries(my_node ${async_comm_LIBRARIES})

Also be sure to list async_comm as a dependency in your package.xml:

<?xml version="1.0"?>
<package format="2">
  ...
  <depend>async_comm</depend>
  ...
</package>

System install

First, download and install the library:

git clone https://github.com/dpkoch/async_comm.git
cd async_comm
mkdir build && cd build/
cmake .. && make
sudo make install

Then, do something like this in your project’s CMakeLists.txt:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

find_package(async_comm REQUIRED)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project ${async_comm_LIBRARIES})

Including as a submodule

If you don’t want to go with the ROS or system install options, the next easiest way to embed the async_comm library in your project is as a Git submodule. The following instructions are for a project using Git for version control and CMake for a build system, but should serve as a starting point for other setups.

For example, to put async_comm in the lib/async_comm directory, run the following from the root of your project:

git submodule add https://github.com/dpkoch/async_comm.git lib/async_comm

Your CMakeLists.txt file would then look something like this:

cmake_minimum_required(VERSION 3.0.2)
project(my_project)

add_subdirectory(lib/async_comm)

add_executable(my_project src/my_project.cpp)
target_link_libraries(my_project async_comm)

Usage

There are three classes that you’ll use directly as a user:

  • async_comm::Serial: for communication over a serial port
  • async_comm::UDP: for communication over a UDP socket
  • async_comm::TCPClient: for communication over a TCP socket (client)

All classes have the same interface and inherit from the async_comm::Comm base class. The constructors for each class require the arguments to specify the details of the serial port, UDP or TCP socket.

The interface consists of the following functions:

  • bool init(): initializes and opens the port or socket
  • void register_receive_callback(std::function<void(const uint8_t*, size_t)> fun): register a user-defined function to handle received bytes; this function will be called by the Serial, UDP or TCPClient object every time a new data is received
  • void send_bytes(const uint8_t * src, size_t len): send the specified number of bytes from the specified source buffer
  • void close(): close the port or socket

More details can be found in the code API documentation. Very simple example programs are provided to illustrate the usage as described below.

One tricky part is registering the member function of a class as the receive callback. This is accomplished using std::bind. For example, if I want to register the receive function of MyClass from within the class, I would use

serial_.register_receive_callback(std::bind(&MyClass::receive, this, std::placeholders::_1, std::placeholders::_2));

where serial_ is an instance of async_comm::Serial.

Message Handlers

It is possible to implement custom handlers for the error messages and other messages produced by the library. To create a message handler, simply inherit from the MessageHandler abstract base class defined in include/async_comm/message_handler.h, and override the pure virtual functions.

Each of the user-facing classes accepts, as an optional final argument, a reference to a class that derives from MessageHandler. To use a custom message handler, simply create an instance of your handler and pass it as that optional argument. When that argument is omitted, the library uses a default message handler that prints to stdout and stderr.

A custom message handler can be especially useful, for example, when the library is used as part of a ROS node and you wish to forward the error messages to the rosconsole logging functionality. A convenience class MessageHandlerROS has been provided for this purpose. To use this handler, do something like the following:

#include <async_comm/serial.h>
#include <async_comm/util/message_handler_ros.h>

#include <ros/ros.h>

// ...

async_comm::util::MessageHandlerROS rosconsole_handler;
async_comm::Serial serial("/dev/ttyUSB0", 115200, rosconsole_handler);

// ...

Examples

There are three examples provided in the repository. The first two are very simple, while the third is more complete. To build the examples, run CMake with the -DASYNC_COMM_BUILD_EXAMPLES=ON flag.

  • examples/serial_loopback.cpp: Designed for use with a USB-to-UART adapter with the RX and TX pins connected together (loopback). Sends a series of bytes out and prints them to the console as they are received back.
  • examples/udp_hello_world.cpp: Opens two UDP objects listening on different ports on the local host, and then uses each to send a simple “hello world” message to the other.
  • examples/serial_protocol.cpp: Implements a simple serial protocol and parser for a message that includes two integer values, including a cyclic reduncancy check. Tests the protocol and async_comm library over a serial loopback.
  • examples/tcp_client_hello_world.cpp: Opens a TCP client that sends “hello world” messages. Example only runs with a valid running TCP/IP server. Server can be started using netcat: nc -l 16140.
CHANGELOG

Changelog for package async_comm

0.2.1 (2021-01-21)

  • Add noetic to ROS prerelease test distribution list
  • Fixes for compatibility with ROS2 workspaces:
    • cmake: Change install paths to basic lib/ and include/
    • package.xml: Remove unneeded catkin dependency
  • Updated CMake examples in README
  • Contributors: Daniel Koch, Maciej Bogusz

0.2.0 (2020-03-16)

  • Fix for UDP/TCP when loopback is only device with an address
  • Added listener interface
  • Added custom message handler functionality
  • TCPClient class implementing an async tcp client
  • Contributors: Daniel Koch, James Jackson, Rein Appeldoorn

0.1.1 (2019-02-21)

  • Some cleanup
  • Process callbacks on a separate thread
  • Made buffer sizes constant, removed faulty mechanism for overriding
  • Removed requirement that bulk write length be no greater than write buffer size
  • Contributors: Daniel Koch

0.1.0 (2018-08-31)

  • Initial release
  • Contributors: Daniel Koch, James Jackson

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

No dependencies on ROS packages.

System Dependencies

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged async_comm at Robotics Stack Exchange