RTC Toolkit
2.0.0
|
All functionallty needed to create DDS entities for DDS data publishing is concentrated in this class. More...
#include <ddsPub.hpp>
Public Member Functions | |
DdsPub (const std::string &qos_file, std::string qos_profile=DEFAULT_QOS_PROFILE, DomainId_t domain_id=DEFAULT_DOMAIN_ID) | |
DDS Publsiher class that takes care for handling all DDS entities to publish samples. More... | |
virtual | ~DdsPub () |
void | CreatePublisher () |
Creates DDS publisher. More... | |
void | DestroyPublisher () |
Destroys DDS publisher. More... | |
DataWriter * | CreateDataWriter (Topic *topic, DataWriterListener *listener=nullptr) |
Creates DDS writer for particular topic for topic of type: rtctk::AgnosticTopic. More... | |
void | DestroyDataWriter (DataWriter *dw, bool to_be_removed=true, std::chrono::milliseconds wait_acks_timeout=5000ms) |
Destroys DDS data writer, and also its listener. More... | |
void | CreateDataWriters () |
Creates DDS Data Writer for all DDS topics. More... | |
void | DestroyAllDataWriters (std::chrono::milliseconds wait_acks_timeout=5000ms) |
Destroys DDS Data Writer for all DDS topics. More... | |
void | CreateManyDataWriters (std::vector< DdsWriterParams > const &) |
create DDS topics and DDS writers for the given list (vector) of topic names and rtctk::componentFramework::DdsWriterListener Internally it calls for each topic name CreateTopic, and on the created topic CreateDataWriter. More... | |
void | CreateManyDataWriters (std::vector< std::string > const &topic_names) |
create DDS topics and DDS writers for the given list of topic names Internally it calls for each topic name CreateTopic, and on the created topic CreateDataWriter. More... | |
void | DumpDDSstatistics () |
Dumps / logs varios DDS statistic like NACks, ACKs, ... More... | |
std::vector< DataWriter * > & | GetDataWriters () |
returns vector of all DDS Data writers More... | |
void | WaitForAcks (DataWriter *dw, std::chrono::milliseconds wait_acks_timeout=5000ms) |
Wait for ACKs for the given DDS Data Writer. More... | |
Public Member Functions inherited from rtctk::componentFramework::Dds | |
Dds (std::string qos_file, std::string qos_profile=DEFAULT_QOS_PROFILE, DomainId_t domain_id=DEFAULT_DOMAIN_ID) | |
Constructor for Base class for both DDS Publisher and DDS Subscriber. More... | |
virtual | ~Dds () noexcept |
Dds (Dds &&rhs)=delete | |
Dds & | operator= (Dds &&rhs)=delete |
void | SetQosProfile (std::string &qos_profile) |
Set FastDDS QoS profile after creation. More... | |
void | SetInterfaceWhiteList (const std::vector< std::string > &iwl) |
Sets the interfaces that can be used for DDS sample traffic. More... | |
void | CreateParticipant () |
Creates DDS participant. More... | |
void | DestroyParticipant () |
Destroys DDS participant created in CreateParticipant. More... | |
Topic * | CreateTopic (const std::string &topic_name) |
Creates DDS topic. More... | |
void | DestroyTopic (Topic *topic, bool to_be_removed=true) |
Destroys DDS topic. More... | |
void | CreateManyTopics (std::vector< std::string > &topic_names) |
Creates many DDS topics. More... | |
void | DestroyAllTopics () |
Destroys all DDS topics from internal map. More... | |
size_t | GetNumberOfTopics () const noexcept |
const std::string | GetTopicName (size_t index) const noexcept |
Additional Inherited Members | |
Static Public Attributes inherited from rtctk::componentFramework::Dds | |
static const std::string | TELEM_DP_QOS_FILE = "telemDataPathDdsQos.xml" |
default file name for different DDS QoSs More... | |
static const std::string | DEFAULT_QOS_PROFILE = "RtcTk_Default_Profile" |
default profile name for different DDS QoSs More... | |
static const DomainId_t | DEFAULT_DOMAIN_ID = 0 |
default Domain Id for different DDS More... | |
Protected Attributes inherited from rtctk::componentFramework::Dds | |
DomainParticipantFactory * | m_factory |
DomainParticipant * | m_participant |
std::string | m_qos_profile |
DomainId_t | m_domain_id =0 |
std::vector< std::string > | m_interfaceWhiteList |
std::vector< Topic * > | m_topics |
log4cplus::Logger | m_logger |
All functionallty needed to create DDS entities for DDS data publishing is concentrated in this class.
rtctk::componentFramework::DdsPub::DdsPub | ( | const std::string & | qos_file, |
std::string | qos_profile = DEFAULT_QOS_PROFILE , |
||
DomainId_t | domain_id = DEFAULT_DOMAIN_ID |
||
) |
DDS Publsiher class that takes care for handling all DDS entities to publish samples.
qos_file | name of QoS XML file. That needs to be located in subfolder: resource/config/rtctk/dds of $CFGPATH. |
qos_profile | DDS QoS profile (please refer to DDS documentation for details) |
domain_id | DDS domain Id (see FastDDS documentation for details) |
|
virtual |
DataWriter * rtctk::componentFramework::DdsPub::CreateDataWriter | ( | Topic * | topic, |
DataWriterListener * | listener = nullptr |
||
) |
Creates DDS writer for particular topic for topic of type: rtctk::AgnosticTopic.
topic | DDS topic for which DDS writer shall be created |
listener | pointer to DDS Writer Listener (optional). If not specified a default one is created/used: rtctk::componentFramework::DdsWriterListener |
void rtctk::componentFramework::DdsPub::CreateDataWriters | ( | ) |
Creates DDS Data Writer for all DDS topics.
Internal it calls CreateDataWriter for each topic from the internal topic map.
void rtctk::componentFramework::DdsPub::CreateManyDataWriters | ( | std::vector< DdsWriterParams > const & | topics_listeners | ) |
create DDS topics and DDS writers for the given list (vector) of topic names and rtctk::componentFramework::DdsWriterListener Internally it calls for each topic name CreateTopic, and on the created topic CreateDataWriter.
void rtctk::componentFramework::DdsPub::CreateManyDataWriters | ( | std::vector< std::string > const & | topic_names | ) |
create DDS topics and DDS writers for the given list of topic names Internally it calls for each topic name CreateTopic, and on the created topic CreateDataWriter.
void rtctk::componentFramework::DdsPub::CreatePublisher | ( | ) |
Creates DDS publisher.
It is enough to have one publisher, so this shall be called just once. It has to be called after DS particpant has been created.
void rtctk::componentFramework::DdsPub::DestroyAllDataWriters | ( | std::chrono::milliseconds | wait_acks_timeout = 5000ms | ) |
Destroys DDS Data Writer for all DDS topics.
Internal it calls DestroyDataWriter for each data write for each topic from the internal topic map.
wait_acks_timeout | timeout for wait_for_acknowledgments in milliseconds - it makes sure that all reliable subscribers ACKs samples before deleting each DataWriter. Default is 5000ms. Parameter is passed to DestroyDataWriter method. |
void rtctk::componentFramework::DdsPub::DestroyDataWriter | ( | DataWriter * | dw, |
bool | to_be_removed = true , |
||
std::chrono::milliseconds | wait_acks_timeout = 5000ms |
||
) |
Destroys DDS data writer, and also its listener.
dw | DDS Data writter to be destroyed |
to_be_removed | flag that indicates if the data writer should be also removed from internal vector. Default is to be removed. |
wait_acks_timeout | timeout for wait_for_acknowledgments in miliseconds - it makes sure that all reliable subscribers ACKs samples before deleting each DAtaWriter. Default is 5000ms. If 0 wait_for_acknowledgments is not called. |
void rtctk::componentFramework::DdsPub::DestroyPublisher | ( | ) |
Destroys DDS publisher.
As there is just one publisher is should be called at most once.
|
virtual |
Dumps / logs varios DDS statistic like NACks, ACKs, ...
for each DDS writer
Reimplemented from rtctk::componentFramework::Dds.
|
inline |
returns vector of all DDS Data writers
void rtctk::componentFramework::DdsPub::WaitForAcks | ( | DataWriter * | dw, |
std::chrono::milliseconds | wait_acks_timeout = 5000ms |
||
) |
Wait for ACKs for the given DDS Data Writer.
dw | DDS Data writer where wait for ACKs is perfromed. |
wait_acks_timeout | timeout in ms |