dfx 0.1.0
Linux-based dynamic dataflow executor
Loading...
Searching...
No Matches
dfx::Core::LocalSource Class Reference

A synchronous, in-process source transport. More...

#include <dfx-core/transports/sources/LocalSource.hpp>

Inheritance diagram for dfx::Core::LocalSource:
[legend]
Collaboration diagram for dfx::Core::LocalSource:
[legend]

Public Member Functions

bool send (MessagePtr message)
 Synchronously pushes a message into the channel.
void start (FdWatch::Poller &) override
 Activates the transport and begins I/O operations.
void stop () noexcept override
 Deactivates the transport and releases system resources.
 SourceTransport (Endpoint endpoint, nlohmann::json config)
 Constructs a SourceTransport with the Role::Source role.
Public Member Functions inherited from dfx::Core::SourceTransport
 SourceTransport (Endpoint endpoint, nlohmann::json config)
 Constructs a SourceTransport with the Role::Source 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.
Channelchannel () const noexcept
 Gets the channel which this transport is attached to if any.
Portport () 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 Member Functions inherited from dfx::Core::SourceTransport
bool transmitMessage (MessagePtr message)
 Forwards a message to the attached Channel for orchestration.
Protected Attributes inherited from dfx::Core::Transport
Role const _role
Endpoint _endpoint
nlohmann::json _config

Detailed Description

A synchronous, in-process source transport.

LocalSource is used by OutputPort to send messages to a Channel within the same process. It acts as a direct pass-through, converting a method call into a channel transmission without intermediate buffering or context switching.

Note
This transport has no asynchronous components and therefore start() and stop() are no-ops.

Member Function Documentation

◆ send()

bool dfx::Core::LocalSource::send ( MessagePtr message)
inline

Synchronously pushes a message into the channel.

This is the primary entry point used by OutputPort::sendMessage.

Parameters
messageThe message pointer to transmit.
Returns
true if the message was accepted by the channel.

◆ SourceTransport()

dfx::Core::SourceTransport::SourceTransport ( Endpoint endpoint,
nlohmann::json config )
inline

Constructs a SourceTransport with the Role::Source role.

Parameters
endpointThe originating endpoint descriptor.
configAdditional JSON configuration specific to this transport instance.

◆ start()

void dfx::Core::LocalSource::start ( FdWatch::Poller & poller)
inlineoverridevirtual

Activates the transport and begins I/O operations.

Parameters
pollerThe event loop poller used to watch File Descriptors.

Implements dfx::Core::Transport.

◆ stop()

void dfx::Core::LocalSource::stop ( )
inlineoverridevirtualnoexcept

Deactivates the transport and releases system resources.

Implements dfx::Core::Transport.


The documentation for this class was generated from the following file: