YARP
Yet Another Robot Platform
yarp::os::MpiP2PCarrier Class Reference

Carrier for port communicating via MPI point-to-point send/receive. More...

#include <mpi_carrier/include/yarp/os/MpiP2PCarrier.h>

+ Inheritance diagram for yarp::os::MpiP2PCarrier:

Detailed Description

Carrier for port communicating via MPI point-to-point send/receive.

Generic communication for arbitrary topology. Allows replies.

Warning
Probably all processes terminate if one terminates without proper disconnect.
Seems to work, but still experimental.

Definition at line 31 of file MpiP2PCarrier.h.

Public Member Functions

 MpiP2PCarrier ()
 
virtual ~MpiP2PCarrier ()
 
virtual void close () override
 Close the carrier. More...
 
virtual Carriercreate () const override
 Factory method. More...
 
virtual void createStream (bool sender) override
 
virtual std::string getName () const override
 Get the name of this connection type ("tcp", "mcast", "shmem", ...) More...
 
virtual bool supportReply () const override
 This flag is used by YARP to determine whether the connection can carry RPC traffic, that is, messages with replies. More...
 
- Public Member Functions inherited from yarp::os::MpiCarrier
 MpiCarrier ()
 
virtual ~MpiCarrier ()
 
virtual bool isConnectionless () const override
 Check if this carrier is connectionless (like udp, mcast) or connection based (like tcp). More...
 
virtual bool canEscape () const override
 Check if carrier can encode administrative messages, as opposed to just user data. More...
 
virtual void getHeader (Bytes &header) const override
 Provide 8 bytes describing this connection sufficiently to allow the other side of a connection to select it. More...
 
virtual bool checkHeader (const Bytes &header) override
 Given the first 8 bytes received on a connection, decide if this is the right carrier type to use for the rest of the connection. More...
 
virtual bool sendHeader (ConnectionState &proto) override
 Write a header appropriate to the carrier to the connection, followed by any carrier-specific data. More...
 
virtual bool expectSenderSpecifier (ConnectionState &proto) override
 Expect the name of the sending port. More...
 
virtual bool respondToHeader (ConnectionState &proto) override
 Respond to the header. More...
 
virtual bool expectReplyToHeader (ConnectionState &proto) override
 Process reply to header, if one is expected for this carrier. More...
 
bool write (ConnectionState &proto, SizedWriter &writer) override
 Write a message. More...
 
virtual bool sendIndex (ConnectionState &proto, SizedWriter &writer) override
 
virtual bool expectIndex (ConnectionState &proto) override
 Expect a message header, if there is one for this carrier. More...
 
virtual bool sendAck (ConnectionState &proto) override
 Send an acknowledgement, if needed for this carrier. More...
 
virtual bool expectAck (ConnectionState &proto) override
 Receive an acknowledgement, if expected for this carrier. More...
 
- Public Member Functions inherited from yarp::os::AbstractCarrier
virtual void setParameters (const yarp::os::Bytes &header) override
 Configure this carrier based on the first 8 bytes of the connection. More...
 
virtual void setCarrierParams (const yarp::os::Property &params) override
 Configure carrier from port administrative commands. More...
 
virtual void getCarrierParams (yarp::os::Property &params) const override
 Get carrier configuration and deliver it by port administrative commands. More...
 
virtual bool canAccept () const override
 Check if reading is implemented for this carrier. More...
 
virtual bool canOffer () const override
 Check if writing is implemented for this carrier. More...
 
virtual bool isTextMode () const override
 Check if carrier is textual in nature. More...
 
virtual bool requireAck () const override
 Check if carrier has flow control, requiring sent messages to be acknowledged by recipient. More...
 
virtual bool isLocal () const override
 Check if carrier operates within a single process. More...
 
virtual std::string toString () const override
 Get name of carrier. More...
 
virtual bool isActive () const override
 Check if carrier is alive and error free. More...
 
virtual bool prepareSend (ConnectionState &proto) override
 Perform any initialization needed before writing on a connection. More...
 
virtual bool expectExtraHeader (ConnectionState &proto) override
 Receive any carrier-specific header. More...
 
bool defaultSendHeader (ConnectionState &proto)
 Default implementation for the sendHeader method. More...
 
bool defaultExpectIndex (ConnectionState &proto)
 Default implementation for the expectIndex method. More...
 
bool defaultSendIndex (ConnectionState &proto, SizedWriter &writer)
 Default implementation for the sendIndex method. More...
 
bool defaultExpectAck (ConnectionState &proto)
 Default implementation for the expectAck method. More...
 
bool defaultSendAck (ConnectionState &proto)
 Default implementation for the sendAck method. More...
 
int readYarpInt (ConnectionState &proto)
 Read 8 bytes and interpret them as a YARP number. More...
 
void writeYarpInt (int n, ConnectionState &proto)
 Write n as an 8 bytes yarp number. More...
 
- Public Member Functions inherited from yarp::os::Carrier
virtual bool isBroadcast () const override
 Check if this carrier uses a broadcast mechanism. More...
 
virtual void handleEnvelope (const std::string &envelope) override
 Carriers that do not distinguish data from administrative headers (i.e. More...
 
virtual bool isPush () const override
 Check if carrier is "push" or "pull" style. More...
 
virtual bool reply (ConnectionState &proto, SizedWriter &writer)
 
virtual void prepareDisconnect () override
 Do cleanup and preparation for the coming disconnect, if necessary. More...
 
virtual ~Carrier ()
 Destructor. More...
 
virtual std::string getBootstrapCarrierName () const
 Get the name of the carrier that should be used prior to handshaking, if a port is registered with this carrier as its default carrier. More...
 
virtual int connect (const Contact &src, const Contact &dest, const ContactStyle &style, int mode, bool reversed)
 Some carrier types may require special connection logic. More...
 
virtual bool modifiesIncomingData () const override
 Check if this carrier modifies incoming data through the Carrier::modifyIncomingData method. More...
 
virtual ConnectionReadermodifyIncomingData (ConnectionReader &reader) override
 Modify incoming payload data, if appropriate. More...
 
virtual bool acceptIncomingData (ConnectionReader &reader) override
 Determine whether incoming data should be accepted. More...
 
virtual bool modifiesOutgoingData () const override
 Check if this carrier modifies outgoing data through the Carrier::modifyOutgoingData method. More...
 
virtual const PortWritermodifyOutgoingData (const PortWriter &writer) override
 Modify outgoing payload data, if appropriate. More...
 
virtual bool modifiesReply () const override
 Check if this carrier modifies outgoing data through the Carrier::modifyReply method. More...
 
virtual PortReadermodifyReply (PortReader &reader) override
 Modify reply payload data, if appropriate. More...
 
virtual bool acceptOutgoingData (const PortWriter &writer) override
 Determine whether outgoing data should be accepted. More...
 
virtual bool configure (ConnectionState &proto)
 Give carrier a shot at looking at how the connection is set up. More...
 
virtual bool configureFromProperty (yarp::os::Property &options)
 
virtual yarp::os::FacecreateFace () const
 Create new Face object that the carrier needs. More...
 
- Public Member Functions inherited from yarp::os::Connection
virtual ~Connection ()
 Destructor. More...
 
virtual bool isValid () const
 Check if this object is really a connection, or just an empty placeholder. More...
 
virtual bool isBareMode () const
 Check if carrier excludes type information from payload. More...
 

Additional Inherited Members

- Protected Member Functions inherited from yarp::os::AbstractCarrier
int getSpecifier (const Bytes &b) const
 
void createStandardHeader (int specifier, yarp::os::Bytes &header) const
 
bool sendConnectionStateSpecifier (ConnectionState &proto)
 
bool sendSenderSpecifier (ConnectionState &proto)
 
- Static Protected Member Functions inherited from yarp::os::AbstractCarrier
static int interpretYarpNumber (const yarp::os::Bytes &b)
 
static void createYarpNumber (int x, yarp::os::Bytes &header)
 
- Protected Attributes inherited from yarp::os::MpiCarrier
MpiStreamstream
 
MpiCommcomm
 
std::string port
 
std::string name
 
std::string other
 
std::string route
 
std::string target
 

Constructor & Destructor Documentation

◆ MpiP2PCarrier()

yarp::os::MpiP2PCarrier::MpiP2PCarrier ( )
inline

Definition at line 33 of file MpiP2PCarrier.h.

◆ ~MpiP2PCarrier()

virtual yarp::os::MpiP2PCarrier::~MpiP2PCarrier ( )
inlinevirtual

Definition at line 37 of file MpiP2PCarrier.h.

Member Function Documentation

◆ close()

virtual void yarp::os::MpiP2PCarrier::close ( void  )
inlineoverridevirtual

Close the carrier.

Implements yarp::os::MpiCarrier.

Definition at line 40 of file MpiP2PCarrier.h.

◆ create()

virtual Carrier* yarp::os::MpiP2PCarrier::create ( ) const
inlineoverridevirtual

Factory method.

Get a new object of the same type as this one.

Returns
a new object of the same type as this one.

Implements yarp::os::MpiCarrier.

Definition at line 47 of file MpiP2PCarrier.h.

◆ createStream()

virtual void yarp::os::MpiP2PCarrier::createStream ( bool  sender)
inlineoverridevirtual

Implements yarp::os::MpiCarrier.

Definition at line 51 of file MpiP2PCarrier.h.

◆ getName()

virtual std::string yarp::os::MpiP2PCarrier::getName ( ) const
inlineoverridevirtual

Get the name of this connection type ("tcp", "mcast", "shmem", ...)

Returns
the name of this connection type

Implements yarp::os::MpiCarrier.

Definition at line 56 of file MpiP2PCarrier.h.

◆ supportReply()

virtual bool yarp::os::MpiP2PCarrier::supportReply ( ) const
inlineoverridevirtual

This flag is used by YARP to determine whether the connection can carry RPC traffic, that is, messages with replies.

Returns
true if carrier supports replies

Implements yarp::os::MpiCarrier.

Definition at line 60 of file MpiP2PCarrier.h.


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