17 #ifndef IOX_POSH_POPO_PORTS_PUBLISHER_PORT_ROUDI_HPP
18 #define IOX_POSH_POPO_PORTS_PUBLISHER_PORT_ROUDI_HPP
20 #include "iceoryx_posh/internal/capro/capro_message.hpp"
21 #include "iceoryx_posh/internal/popo/building_blocks/chunk_distributor.hpp"
22 #include "iceoryx_posh/internal/popo/building_blocks/chunk_sender.hpp"
23 #include "iceoryx_posh/internal/popo/ports/base_port.hpp"
24 #include "iceoryx_posh/internal/popo/ports/publisher_port_data.hpp"
25 #include "iceoryx_utils/cxx/optional.hpp"
40 explicit PublisherPortRouDi(cxx::not_null<MemberType_t* const> publisherPortDataPtr) noexcept;
59 cxx::optional<capro::CaproMessage>
this class is the base for all ports. it is constructed from a member pointer and is only movable....
Definition: base_port.hpp:43
The ChunkSender is a building block of the shared memory communication infrastructure....
Definition: chunk_sender.hpp:49
The PublisherPortRouDi provides the API for accessing a publisher port from the RouDi middleware daem...
Definition: publisher_port_roudi.hpp:36
void releaseAllChunks() noexcept
cleanup the publisher and release all the chunks it currently holds Caution: Contract is that user pr...
cxx::optional< capro::CaproMessage > tryGetCaProMessage() noexcept
get an optional CaPro message that changes the offer state of the publisher
cxx::optional< capro::CaproMessage > dispatchCaProMessageAndGetPossibleResponse(const capro::CaproMessage &caProMessage) noexcept
dispatch a CaPro message to the publisher for processing
SubscriberTooSlowPolicy getSubscriberTooSlowPolicy() const noexcept
Returns behaviour in case of a full delivery queue.
Definition: service_description.hpp:29
Defines different base port data.
Definition: base_port_data.hpp:34
Definition: publisher_port_data.hpp:39