![]() |
dfx 0.1.0
Linux-based dynamic dataflow executor
|
An in-process destination transport using a thread-safe queue. More...
#include <dfx-core/transports/destinations/LocalDestination.hpp>
Public Member Functions | |
| void | start (FdWatch::Poller &) override |
| Activates the transport and begins I/O operations. | |
| void | stop () noexcept override |
| Deactivates the transport and releases system resources. | |
| bool | deliver (MessagePtr message) override |
| Pushes the message into the internal synchronous queue. | |
| int64_t | pendingMessageCount () const noexcept override |
| Returns the current occupancy of the internal queue. | |
| std::optional< MessagePtr > | pop () |
| Retrieves and removes the oldest message from the queue. | |
| DestinationTransport (Endpoint endpoint, nlohmann::json config) | |
| Constructs a DestinationTransport with the Role::Destination role. | |
| Public Member Functions inherited from dfx::Core::DestinationTransport | |
| DestinationTransport (Endpoint endpoint, nlohmann::json config) | |
| Constructs a DestinationTransport with the Role::Destination role. | |
| Public Member Functions inherited from dfx::Core::Transport | |
| Transport (Role role, Endpoint endpoint, nlohmann::json config) | |
| Constructs a transport instance. | |
| DFX_DISABLE_COPY_AND_MOVE (Transport) | |
| Transport is not copiable nor movable. | |
| virtual | ~Transport ()=default |
| Virtual destructor ensuring proper cleanup of derived transports. | |
| template<DerivedFromTransport T> | |
| bool | is () const noexcept |
| Check whether this transport is of a given derived type. | |
| template<DerivedFromTransport T> | |
| T & | as () noexcept |
| Cast this transport to a derived type (unchecked). | |
| template<DerivedFromTransport T> | |
| T const & | as () const noexcept |
| Cast this transport to a derived type (unchecked). | |
| Role | role () const noexcept |
| Returns the Role (Source or Destination) of this transport. | |
| bool | isSource () const noexcept |
| Returns true if this transport is a source. | |
| bool | isDestination () const noexcept |
| Returns true if this transport is a destination. | |
| Endpoint const & | endpoint () const noexcept |
| Gets the endpoint descriptor associated with this transport. | |
| Channel * | channel () const noexcept |
| Gets the channel which this transport is attached to if any. | |
| Port * | port () const noexcept |
| Gets the port associated with this transport. | |
| NodePtr | node () const noexcept |
| Gets the node associated with this transport. | |
| nlohmann::json const & | config () const noexcept |
| Gets the JSON configuration used to initialize this transport. | |
Additional Inherited Members | |
| Public Types inherited from dfx::Core::Transport | |
| enum class | Role { Source , Destination } |
| Defines the operational role of a transport relative to a channel. More... | |
| Protected Attributes inherited from dfx::Core::Transport | |
| Role const | _role |
| Endpoint | _endpoint |
| nlohmann::json | _config |
An in-process destination transport using a thread-safe queue.
LocalDestination serves as the destination point for InputPort. It stores messages in an internal queue.
|
inlineoverridevirtual |
Pushes the message into the internal synchronous queue.
| message | The message handed over by the Channel. |
true if there was space in the queue; false if full. Implements dfx::Core::DestinationTransport.
|
inline |
Constructs a DestinationTransport with the Role::Destination role.
| endpoint | The target endpoint descriptor. |
| config | Additional JSON configuration specific to this transport instance. |
|
inlineoverridevirtualnoexcept |
Returns the current occupancy of the internal queue.
Reimplemented from dfx::Core::DestinationTransport.
|
inline |
Retrieves and removes the oldest message from the queue.
std::nullopt otherwise.
|
inlineoverridevirtual |
Activates the transport and begins I/O operations.
| poller | The event loop poller used to watch File Descriptors. |
Implements dfx::Core::Transport.
|
inlineoverridevirtualnoexcept |
Deactivates the transport and releases system resources.
Implements dfx::Core::Transport.