RTI Connext Modern C++ API
Version 7.0.0
|
<<reference-type>> A publisher is the object responsible for the actual dissemination of publications. More...
#include <dds/pub/Publisher.hpp>
Public Member Functions | |
Publisher (const dds::domain::DomainParticipant &the_participant) | |
Create a Publisher. More... | |
Publisher (const dds::domain::DomainParticipant &the_participant, const dds::pub::qos::PublisherQos &the_qos, dds::pub::PublisherListener *the_listener=NULL, const dds::core::status::StatusMask &mask=dds::core::status::StatusMask::all()) | |
Create a Publisher with the desired QoS policies and attaches to it the specified PublisherListener. More... | |
Publisher (const ::dds::domain::DomainParticipant &the_participant, const dds::pub::qos::PublisherQos &the_qos, std::shared_ptr< Listener > the_listener, const dds::core::status::StatusMask &mask=dds::core::status::StatusMask::all()) | |
Create a Publisher with the desired QoS policies and attaches to it the specified PublisherListener. More... | |
const dds::pub::qos::PublisherQos | qos () const |
Gets the PublisherQos. More... | |
void | qos (const dds::pub::qos::PublisherQos &the_qos) |
Set the PublisherQos. More... | |
Publisher & | operator<< (const dds::pub::qos::PublisherQos &the_qos) |
Sets the PublisherQos. More... | |
Publisher & | operator>> (dds::pub::qos::PublisherQos &the_qos) |
Gets the PublisherQos. More... | |
Publisher & | default_datawriter_qos (const dds::pub::qos::DataWriterQos &dwqos) |
Sets the default DataWriterQos. More... | |
dds::pub::qos::DataWriterQos | default_datawriter_qos () const |
Gets the default DataWriterQos. More... | |
void | listener (Listener *plistener, const dds::core::status::StatusMask &event_mask) |
Sets the Publisher listener. More... | |
Listener * | listener () const |
Returns the listener currently associated with this Publisher. More... | |
void | set_listener (std::shared_ptr< Listener > the_listener, const dds::core::status::StatusMask &event_mask) |
Sets the listener associated with this publisher. More... | |
void | set_listener (std::shared_ptr< Listener > the_listener) |
Sets the listener associated with this publisher. More... | |
std::shared_ptr< Listener > | get_listener () const |
Returns the listener currently associated with this Publisher. More... | |
void | wait_for_acknowledgments (const dds::core::Duration &max_wait) |
Blocks the calling thread until all data written by this Publisher's reliable DataWriters is acknowledged, or until timeout expires. More... | |
const dds::domain::DomainParticipant & | participant () const |
Gets the DomainParticipant to which this Publisher belongs. More... | |
void | wait_for_asynchronous_publishing (const dds::core::Duration &max_wait) |
<<extension>> Blocks the calling thread until asynchronous sending is complete. More... | |
void | close_contained_entities () |
<<extension>> Closes all the entities created from this Publisher More... | |
Public Member Functions inherited from dds::core::Entity | |
void | enable () |
Enables this entity (if it was created disabled) More... | |
const dds::core::status::StatusMask | status_changes () |
Retrieves the list of communication statuses that are triggered. More... | |
const dds::core::InstanceHandle | instance_handle () const |
Get the instance handle that represents this entity. More... | |
void | close () |
Forces the destruction of this entity. More... | |
void | retain () |
Disables the automatic destruction of this entity. More... | |
Related Functions | |
(Note that these are not member functions.) | |
template<typename PublisherForwardIterator > | |
uint32_t | find_publishers (const dds::domain::DomainParticipant participant, PublisherForwardIterator begin, uint32_t max_size) |
<<extension>> Retrieve all of the dds::pub::Publisher created from this dds::domain::DomainParticipant More... | |
template<typename PublisherBackInsertIterator > | |
uint32_t | find_publishers (const dds::domain::DomainParticipant participant, PublisherBackInsertIterator begin) |
Retrieve all the dds::pub::Publisher created from this dds::domain::DomainParticipant. More... | |
dds::pub::Publisher | find_publisher (const dds::domain::DomainParticipant participant, const std::string &publisher_name) |
<<extension>> Looks up a dds::pub::Publisher by its entity name within the dds::domain::DomainParticipant. More... | |
dds::pub::Publisher | implicit_publisher (const dds::domain::DomainParticipant &dp) |
<<extension>> Get the implicit dds::pub::Publisher for a given dds::domain::DomainParticipant. More... | |
Related Functions inherited from dds::core::Entity | |
template<typename TO , typename FROM > | |
TO | polymorphic_cast (const FROM &from) |
Downcasts an Entity to a subclass. More... | |
<<reference-type>> A publisher is the object responsible for the actual dissemination of publications.
A publisher acts on the behalf of one or several dds::pub::DataWriter objects that belong to it. When it is informed of a change to the data associated with one of its dds::pub::DataWriter objects, it decides when it is appropriate to actually send the data-update message. In making this decision, it considers any extra information that goes with the data (timestamp, writer, etc.) as well as the QoS of the dds::pub::Publisher and the dds::pub::DataWriter.
The following operations may be called even if the dds::pub::Publisher is not enabled. Other operations will fail with the value dds::core::NotEnabledError if called on a disabled dds::pub::Publisher:
|
inlineexplicit |
Create a Publisher.
It uses default qos::PublisherQos and no listener.
the_participant | The DomainParticipant where this Publisher will be created |
|
inline |
Create a Publisher
with the desired QoS policies and attaches to it the specified PublisherListener.
[DEPRECATED] When using a listener, prefer the constructor that receives a shared_ptr<Listener>
instead of a regular Listener*
pointer.
the_participant | The DomainParticipant where this Publisher will be created |
the_qos | The PublisherQos |
the_listener | The PublisherListener |
mask | Indicates which status updates the listener will receive |
dds::core::Error | If there is any error creating the Publisher |
|
inline |
Create a Publisher
with the desired QoS policies and attaches to it the specified PublisherListener.
the_participant | The DomainParticipant where this Publisher will be created |
the_qos | The PublisherQos |
the_listener | A shared_ptr to the listener. See set_listener() for more information. |
mask | Indicates which status updates the listener will receive |
dds::core::Error | If there is any error creating the Publisher |
|
inline |
Gets the PublisherQos.
|
inline |
Set the PublisherQos.
This operation modifies the QoS of the dds::pub::Publisher.
The dds::core::policy::GroupData, dds::core::policy::Partition and dds::core::policy::EntityFactory can be changed. The other policies are immutable.
the_qos | <<in>> dds::pub::qos::PublisherQos to be set to. Policies must be consistent. Immutable policies cannot be changed after dds::pub::Publisher is enabled. The special value PUBLISHER_QOS_DEFAULT can be used to indicate that the QoS of the dds::pub::Publisher should be changed to match the current default dds::pub::qos::PublisherQos set in the dds::domain::DomainParticipant. |
One | of the Standard Exceptions, dds::core::ImmutablePolicyError, or dds::core::InconsistentPolicyError. |
|
inline |
Sets the PublisherQos.
|
inline |
Gets the PublisherQos.
|
inline |
Sets the default DataWriterQos.
|
inline |
Gets the default DataWriterQos.
The retrieved DataWriterQos will match the set of values specified on the last call to default_datawriter_qos(const dds::pub::qos::DataWriterQos&). If the application never called that function, the default value comes from the dds::domain::DomainParticipant.
|
inline |
Sets the Publisher listener.
[DEPRECATED] The use of set_listener()
is recommended. Unlike this function, set_listener
receives a shared_ptr
which simplifies the management of listener's lifecycle.
One | of the Standard Exceptions |
plistener | the topic listener |
event_mask | Changes of communication status to be invoked on the listener |
|
inline |
Returns the listener currently associated with this Publisher.
[DEPRECATED] Use get_listener
instead of this function.
If there's no listener it returns NULL.
|
inline |
Sets the listener associated with this publisher.
The Publisher will hold a shared_ptr
to the listener argument, ensuring that it is not deleted at least until this Publisher is deleted or the listener is reset with set_listener(nullptr)
.
the_listener | A shared pointer to the listener to receive status updates or nullptr to reset the current listener and stop receiving status updates. |
event_mask | A mask that indicates which status updates will be notified to the listener |
|
inline |
Sets the listener associated with this publisher.
If the_listener
is not nullptr
, this overload is equivalent to:
If the_listener
is nullptr
, it is equivalent to:
the_listener | A shared pointer to the listener to receive status updates or nullptr to reset the current listener and stop receiving status updates. |
|
inline |
Returns the listener currently associated with this Publisher.
nullptr
if there is currently no listener associated to this entity.
|
inline |
Blocks the calling thread until all data written by this Publisher's reliable DataWriters is acknowledged, or until timeout expires.
This operation blocks the calling thread until either all data written by the reliable DataWriters entities is acknowledged by (a) all reliable dds::sub::DataReader entities that are matched and alive and (b) by all required subscriptions, or until the duration specified by the max_wait
parameter elapses, whichever happens first. A successful completion indicates that all the samples written have been acknowledged; a timeout indicates that max_wait elapsed before all the data was acknowledged.
Note that if a thread is blocked in the call to this operation on a dds::pub::Publisher and a different thread writes new samples on any of the reliable DataWriters that belong to this Publisher, the new samples must be acknowledged before unblocking the thread that is waiting on this operation.
If none of the dds::pub::DataWriter instances have dds::core::policy::Reliability kind set to RELIABLE, the operation will complete successfully.
One | of the Standard Exceptions, dds::core::NotEnabledError, dds::core::TimeoutError |
|
inline |
Gets the DomainParticipant to which this Publisher belongs.
void wait_for_asynchronous_publishing | ( | const dds::core::Duration & | max_wait | ) |
<<extension>> Blocks the calling thread until asynchronous sending is complete.
This operation blocks the calling thread (up to max_wait
) until all data written by the asynchronous dds::pub::DataWriter entities is sent and acknowledged (if reliable) by all matched dds::sub::DataReader entities. A successful completion indicates that all the samples written have been sent and acknowledged where applicable; if it times out, this indicates that max_wait
elapsed before all the data was sent and/or acknowledged.
In other words, this guarantees that sending to best effort dds::sub::DataReader is complete in addition to what dds::pub::Publisher::wait_for_acknowledgments provides.
If none of the dds::pub::DataWriter instances have rti::core::policy::PublishMode::kind set to rti::core::policy::PublishModeKind_def::ASYNCHRONOUS, the operation will complete immediately .
max_wait | <<in>> Specifies maximum time to wait for acknowledgements dds::core::Duration. |
One | of the Standard Exceptions, dds::core::NotEnabledError, dds::core::TimeoutError |
void close_contained_entities | ( | ) |
<<extension>> Closes all the entities created from this Publisher
Deletes all contained dds::pub::DataWriter objects. Once dds::pub::Publisher::close_contained_entities completes successfully, the application may delete the dds::pub::Publisher, knowing that it has no contained dds::pub::DataWriter objects.
The operation will fail with dds::core::PreconditionNotMetError if any of the contained entities is in a state where it cannot be deleted.
One | of the Standard Exceptions or dds::core::PreconditionNotMetError. |
|
related |
<<extension>> Retrieve all of the dds::pub::Publisher created from this dds::domain::DomainParticipant
PublisherForwardIterator | A forward iterator whose value type is dds::pub::Publisher |
participant | The dds::domain::DomainParticipant the Publishers belong to |
begin | A forward iterator to the position in the destination container to insert the found Publishers into |
max_size | The maximum number of Publishers to add |
|
related |
Retrieve all the dds::pub::Publisher created from this dds::domain::DomainParticipant.
PublisherBackInsertIterator | A back-inserting iterator whose value type is dds::pub::Publisher |
participant | The dds::domain::DomainParticipant the Publishers belong to |
begin | A back-inserting iterator to the position in the destination container to insert the found Publishers in |
|
related |
<<extension>> Looks up a dds::pub::Publisher by its entity name within the dds::domain::DomainParticipant.
Every dds::pub::Publisher in the system has an entity name which is configured and stored in the EntityName policy, ENTITY_NAME.
This operation retrieves a dds::pub::Publisher within the dds::domain::DomainParticipant given the entity's name. If there are several dds::pub::Publisher with the same name within the dds::domain::DomainParticipant, this function returns the first matching occurrence.
participant | The dds::domain::DomainParticipant to look for the dds::pub::Publisher in. |
publisher_name | Entity name of the Publisher |
|
related |
<<extension>> Get the implicit dds::pub::Publisher for a given dds::domain::DomainParticipant.
If an implicit Publisher does not already exist, this creates one.
The implicit Publisher is created with default dds::pub::qos::PublisherQos and no listener. When a DomainParticipant is deleted, if there are no attached dds::pub::DataWriter that belong to the implicit Publisher, the implicit Publisher will be implicitly deleted.
dp | The DomainParticipant that the implicit publisher belongs to |