123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 |
- // Copyright 2019 Proyectos y Sistemas de Mantenimiento SL (eProsima).
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- /**
- * @file Publisher.hpp
- *
- */
- #ifndef _FASTDDS_PUBLISHER_HPP_
- #define _FASTDDS_PUBLISHER_HPP_
- #include <fastrtps/fastrtps_dll.h>
- #include <fastdds/rtps/common/Time_t.h>
- #include <fastrtps/attributes/PublisherAttributes.h>
- #include <fastrtps/types/TypesBase.h>
- #include <fastdds/dds/core/Entity.hpp>
- #include <fastdds/dds/publisher/qos/PublisherQos.hpp>
- #include <fastdds/dds/publisher/qos/DataWriterQos.hpp>
- using eprosima::fastrtps::types::ReturnCode_t;
- namespace dds {
- namespace pub {
- class Publisher;
- }
- }
- namespace eprosima {
- namespace fastrtps {
- class TopicAttributes;
- } // namespace fastrtps
- namespace fastdds {
- namespace dds {
- class DomainParticipant;
- class PublisherListener;
- class PublisherImpl;
- class DataWriter;
- class DataWriterListener;
- class Topic;
- /**
- * Class Publisher, used to send data to associated subscribers.
- * @ingroup FASTDDS_MODULE
- */
- class Publisher : public DomainEntity
- {
- friend class PublisherImpl;
- friend class DomainParticipantImpl;
- /**
- * Create a publisher, assigning its pointer to the associated writer.
- * Don't use directly, create Publisher using create_publisher from Participant.
- */
- RTPS_DllAPI Publisher(
- PublisherImpl* p,
- const StatusMask& mask = StatusMask::all());
- RTPS_DllAPI Publisher(
- DomainParticipant* dp,
- const PublisherQos& qos = PUBLISHER_QOS_DEFAULT,
- PublisherListener* listener = nullptr,
- const StatusMask& mask = StatusMask::all());
- public:
- /**
- * @brief Destructor
- */
- RTPS_DllAPI virtual ~Publisher();
- /**
- * @brief This operation enables the Publisher
- * @return RETCODE_OK is successfully enabled. RETCODE_PRECONDITION_NOT_MET if the participant creating this
- * Publisher is not enabled.
- */
- RTPS_DllAPI ReturnCode_t enable() override;
- /**
- * Allows accessing the Publisher Qos.
- * @return PublisherQos reference
- */
- RTPS_DllAPI const PublisherQos& get_qos() const;
- /**
- * Retrieves the Publisher Qos.
- * @return RETCODE_OK
- */
- RTPS_DllAPI ReturnCode_t get_qos(
- PublisherQos& qos) const;
- /**
- * Allows modifying the Publisher Qos.
- * The given Qos must be supported by the PublisherQos.
- * @param qos PublisherQos to be set
- * @return RETCODE_IMMUTABLE_POLICY if any of the Qos cannot be changed, RETCODE_INCONSISTENT_POLICY if the Qos is not
- * self consistent and RETCODE_OK if the qos is changed correctly.
- */
- RTPS_DllAPI ReturnCode_t set_qos(
- const PublisherQos& qos);
- /**
- * Retrieves the attached PublisherListener.
- * @return PublisherListener pointer
- */
- RTPS_DllAPI const PublisherListener* get_listener() const;
- /**
- * Modifies the PublisherListener.
- * @param listener PublisherListener pointer
- * @return RETCODE_OK
- */
- RTPS_DllAPI ReturnCode_t set_listener(
- PublisherListener* listener);
- /**
- * This operation creates a DataWriter. The returned DataWriter will be attached and belongs to the Publisher.
- * @param topic Topic the DataWriter will be listening
- * @param qos QoS of the DataWriter.
- * @param listener Pointer to the listener (default: nullptr).
- * @param mask StatusMask (default: all).
- * @return Pointer to the created DataWriter. nullptr if failed.
- */
- RTPS_DllAPI DataWriter* create_datawriter(
- Topic* topic,
- const DataWriterQos& qos,
- DataWriterListener* listener = nullptr,
- const StatusMask& mask = StatusMask::all());
- /**
- * This operation creates a DataWriter. The returned DataWriter will be attached and belongs to the Publisher.
- * @param topic Topic the DataWriter will be listening
- * @param profile_name DataWriter profile name.
- * @param listener Pointer to the listener (default: nullptr).
- * @param mask StatusMask (default: all).
- * @return Pointer to the created DataWriter. nullptr if failed.
- */
- RTPS_DllAPI DataWriter* create_datawriter_with_profile(
- Topic* topic,
- const std::string& profile_name,
- DataWriterListener* listener = nullptr,
- const StatusMask& mask = StatusMask::all());
- /**
- * This operation deletes a DataWriter that belongs to the Publisher.
- *
- * The delete_datawriter operation must be called on the same Publisher object used to create the DataWriter.
- * If delete_datawriter is called on a different Publisher, the operation will have no effect and it will
- * return false.
- *
- * The deletion of the DataWriter will automatically unregister all instances.
- * Depending on the settings of the WRITER_DATA_LIFECYCLE QosPolicy, the deletion of the DataWriter
- * may also dispose all instances.
- * @param writer DataWriter to delete
- * @return RETCODE_PRECONDITION_NOT_MET if it does not belong to this Publisher, RETCODE_OK if it is correctly deleted and
- * RETCODE_ERROR otherwise.
- */
- RTPS_DllAPI ReturnCode_t delete_datawriter(
- DataWriter* writer);
- /**
- * This operation retrieves a previously created DataWriter belonging to the Publisher that is attached to a
- * Topic with a matching topic_name. If no such DataWriter exists, the operation will return nullptr.
- *
- * If multiple DataWriter attached to the Publisher satisfy this condition, then the operation will return
- * one of them. It is not specified which one.
- * @param topic_name Name of the Topic
- * @return Pointer to a previously created DataWriter associated to a Topic with the requested topic_name
- */
- RTPS_DllAPI DataWriter* lookup_datawriter(
- const std::string& topic_name) const;
- /**
- * Fills the given vector with all the datawriters of this publisher.
- * @param writers Vector where the DataWriters are returned
- * @return true
- */
- RTPS_DllAPI bool get_datawriters(
- std::vector<DataWriter*>& writers) const;
- /**
- * This operation checks if the publisher has DataWriters
- * @return true if the publisher has one or several DataWriters, false otherwise
- */
- RTPS_DllAPI bool has_datawriters() const;
- /* TODO
- bool suspend_publications();
- */
- /* TODO
- bool resume_publications();
- */
- /* TODO
- bool begin_coherent_changes();
- */
- /* TODO
- bool end_coherent_changes();
- */
- /**
- * This operation blocks the calling thread until either all data written by the reliable DataWriter entities
- * is acknowledged by all matched reliable DataReader entities, or else the duration specified by the max_wait
- * parameter elapses, whichever happens first. A return value of true indicates that all the samples written
- * have been acknowledged by all reliable matched data readers; a return value of false indicates that max_wait
- * elapsed before all the data was acknowledged.
- * @param max_wait Maximum blocking time for this operation
- * @return RETCODE_TIMEOUT if the function takes more than the maximum blocking time established, RETCODE_OK if the
- * Publisher receives the acknowledgments and RETCODE_ERROR otherwise.
- */
- RTPS_DllAPI ReturnCode_t wait_for_acknowledgments(
- const fastrtps::Duration_t& max_wait);
- /**
- * This operation returns the DomainParticipant to which the Publisher belongs.
- * @return Pointer to the DomainParticipant
- */
- RTPS_DllAPI const DomainParticipant* get_participant() const;
- /* TODO
- bool delete_contained_entities();
- */
- /**
- * This operation sets a default value of the DataWriter QoS policies which will be used for newly created
- * DataWriter entities in the case where the QoS policies are defaulted in the create_datawriter operation.
- *
- * This operation will check that the resulting policies are self consistent; if they are not, the operation
- * will have no effect and return false.
- *
- * The special value DATAWRITER_QOS_DEFAULT may be passed to this operation to indicate that the default QoS
- * should be reset back to the initial values the factory would use, that is the values that would be used
- * if the set_default_datawriter_qos operation had never been called.
- * @param qos DataWriterQos to be set
- * @return RETCODE_INCONSISTENT_POLICY if the Qos is not self consistent and RETCODE_OK if the qos is changed correctly.
- */
- RTPS_DllAPI ReturnCode_t set_default_datawriter_qos(
- const DataWriterQos& qos);
- /**
- * This operation returns the default value of the DataWriter QoS, that is, the QoS policies which will be used
- * for newly created DataWriter entities in the case where the QoS policies are defaulted in the
- * create_datawriter operation.
- *
- * The values retrieved by get_default_datawriter_qos will match the set of values specified on the last
- * successful call to set_default_datawriter_qos, or else, if the call was never made, the default values.
- * @return Current default WriterQos
- */
- RTPS_DllAPI const DataWriterQos& get_default_datawriter_qos() const;
- /**
- * This operation retrieves the default value of the DataWriter QoS, that is, the QoS policies which will be used
- * for newly created DataWriter entities in the case where the QoS policies are defaulted in the
- * create_datawriter operation.
- *
- * The values retrieved by get_default_datawriter_qos will match the set of values specified on the last
- * successful call to set_default_datawriter_qos, or else, if the call was never made, the default values.
- * @param qos Reference to the current default WriterQos.
- * @return RETCODE_OK
- */
- RTPS_DllAPI ReturnCode_t get_default_datawriter_qos(
- DataWriterQos& qos) const;
- /* TODO
- bool copy_from_topic_qos(
- WriterQos& writer_qos,
- const fastrtps::TopicAttributes& topic_qos) const;
- */
- /**
- * Returns the Publisher's handle.
- * @return InstanceHandle of this Publisher.
- */
- RTPS_DllAPI const fastrtps::rtps::InstanceHandle_t& get_instance_handle() const;
- private:
- PublisherImpl* impl_;
- friend class ::dds::pub::Publisher;
- };
- } /* namespace dds */
- } /* namespace fastdds */
- } /* namespace eprosima */
- #endif /* _FASTDDS_PUBLISHER_HPP_ */
|