A stream abstraction for unix socket communication. More...
#include <unix/UnixSockTwoWayStream.h>
Inheritance diagram for UnixSockTwoWayStream:Public Member Functions | |
| UnixSockTwoWayStream (const std::string &_socketPath="") | |
| ~UnixSockTwoWayStream () override | |
| InputStream & | getInputStream () override |
| Get an InputStream to read from. More... | |
| OutputStream & | getOutputStream () override |
| Get an OutputStream to write to. More... | |
| const yarp::os::Contact & | getLocalAddress () const override |
| Get the address of the local side of the stream. More... | |
| const yarp::os::Contact & | getRemoteAddress () const override |
| Get the address of the remote side of the stream. More... | |
| void | interrupt () override |
| Interrupt the stream. More... | |
| void | close () override |
| Terminate the stream. More... | |
| yarp::conf::ssize_t | read (yarp::os::Bytes &b) override |
| Read a block of data from the stream. More... | |
| void | write (const yarp::os::Bytes &b) override |
| Write a block of bytes to the stream. More... | |
| bool | isOk () const override |
| Check if the stream is ok or in an error state. More... | |
| void | reset () override |
| Reset the stream. More... | |
| void | beginPacket () override |
| Mark the beginning of a logical packet. More... | |
| void | endPacket () override |
| Mark the end of a logical packet (see beginPacket). More... | |
| bool | open (bool sender=false) |
| void | setLocalAddress (yarp::os::Contact &_localAddress) |
| void | setRemoteAddress (yarp::os::Contact &_remoteAddress) |
Public Member Functions inherited from yarp::os::TwoWayStream | |
| virtual | ~TwoWayStream () |
| Destructor. More... | |
Public Member Functions inherited from yarp::os::InputStream | |
| InputStream () | |
| Constructor. More... | |
| virtual | ~InputStream () |
| Destructor. More... | |
| virtual void | check () |
| Perform maintenance actions, if needed. More... | |
| virtual int | read () |
| Read and return a single byte. More... | |
| virtual yarp::conf::ssize_t | read (Bytes &b, size_t offset, yarp::conf::ssize_t len) |
| Read a block of data from the stream. More... | |
| virtual yarp::conf::ssize_t | partialRead (yarp::os::Bytes &b) |
| Like read, but solicit partial responses. More... | |
| virtual bool | setReadTimeout (double timeout) |
| Set activity timeout. More... | |
| std::string | readLine (const char terminal='\n', bool *success=nullptr) |
| Read a block of text terminated with a specific marker (or EOF). More... | |
| yarp::conf::ssize_t | readFull (Bytes &b) |
| Keep reading until buffer is full. More... | |
| yarp::conf::ssize_t | readDiscard (size_t len) |
| Read and discard a fixed number of bytes. More... | |
| virtual bool | setReadEnvelopeCallback (readEnvelopeCallbackType callback, void *data) |
| Install a callback that the InputStream will have to call when the envelope is read from a message in carriers that cannot be escaped. More... | |
Public Member Functions inherited from yarp::os::OutputStream | |
| virtual | ~OutputStream () |
| Destructor. More... | |
| virtual void | write (char ch) |
| Write a single byte to the stream. More... | |
| virtual void | write (const Bytes &b, int offset, int len) |
| Write a block of bytes to the stream. More... | |
| virtual void | flush () |
| Make sure all pending write operations are finished. More... | |
| virtual void | writeLine (const char *data, int len) |
| Write some text followed by a line feed. More... | |
| virtual bool | setWriteTimeout (double timeout) |
| Set activity timeout. More... | |
| virtual bool | setTypeOfService (int tos) |
| virtual int | getTypeOfService () |
Additional Inherited Members | |
Public Types inherited from yarp::os::InputStream | |
| typedef void(* | readEnvelopeCallbackType) (void *, const yarp::os::Bytes &envelope) |
| Callback type for setting the envelope from a message in carriers that cannot be escaped. More... | |
A stream abstraction for unix socket communication.
Definition at line 21 of file UnixSockTwoWayStream.h.
| UnixSockTwoWayStream::UnixSockTwoWayStream | ( | const std::string & | _socketPath = "" | ) |
Definition at line 27 of file UnixSockTwoWayStream.cpp.
|
override |
Definition at line 93 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Mark the beginning of a logical packet.
This is a unit that should be treated in an atomic fashion by YARP. If any part is corrupted, the whole should be dropped.
Implements yarp::os::TwoWayStream.
Definition at line 198 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Terminate the stream.
Implements yarp::os::InputStream.
Definition at line 134 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Mark the end of a logical packet (see beginPacket).
Implements yarp::os::TwoWayStream.
Definition at line 202 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Get an InputStream to read from.
Implements yarp::os::TwoWayStream.
Definition at line 98 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Get the address of the local side of the stream.
Implements yarp::os::TwoWayStream.
Definition at line 108 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Get an OutputStream to write to.
Implements yarp::os::TwoWayStream.
Definition at line 103 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Get the address of the remote side of the stream.
Implements yarp::os::TwoWayStream.
Definition at line 113 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Interrupt the stream.
If the stream is currently in a blocked state, it must be unblocked.
Reimplemented from yarp::os::InputStream.
Definition at line 128 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Check if the stream is ok or in an error state.
Implements yarp::os::InputStream.
Definition at line 189 of file UnixSockTwoWayStream.cpp.
| bool UnixSockTwoWayStream::open | ( | bool | sender = false | ) |
Definition at line 32 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Read a block of data from the stream.
Should block and wait for data.
| b[out] | the block of data to read to |
Implements yarp::os::InputStream.
Definition at line 155 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Reset the stream.
Implements yarp::os::TwoWayStream.
Definition at line 194 of file UnixSockTwoWayStream.cpp.
| void UnixSockTwoWayStream::setLocalAddress | ( | yarp::os::Contact & | _localAddress | ) |
Definition at line 118 of file UnixSockTwoWayStream.cpp.
| void UnixSockTwoWayStream::setRemoteAddress | ( | yarp::os::Contact & | _remoteAddress | ) |
Definition at line 123 of file UnixSockTwoWayStream.cpp.
|
overridevirtual |
Write a block of bytes to the stream.
| b | the bytes to write |
Implements yarp::os::OutputStream.
Definition at line 173 of file UnixSockTwoWayStream.cpp.