An interface for writing to a network connection. More...
#include <yarp/os/ConnectionWriter.h>
Public Member Functions | |
virtual | ~ConnectionWriter () |
Destructor. | |
virtual void | appendBlock (const char *data, size_t len)=0 |
Send a block of data to the network connection. | |
virtual void | appendInt8 (std::int8_t data)=0 |
Send a representation of a 8-bit integer to the network connection. | |
virtual void | appendInt16 (std::int16_t data)=0 |
Send a representation of a 16-bit integer to the network connection. | |
virtual void | appendInt32 (std::int32_t data)=0 |
Send a representation of a 32-bit integer to the network connection. | |
virtual void | appendInt64 (std::int64_t data)=0 |
Send a representation of a 64-bit integer to the network connection. | |
virtual void | appendFloat32 (yarp::conf::float32_t data)=0 |
Send a representation of a 32-bit floating point number to the network connection. | |
virtual void | appendFloat64 (yarp::conf::float64_t data)=0 |
Send a representation of a 64-bit floating point number to the network connection. | |
virtual void | appendText (const std::string &str, const char terminate='\n')=0 |
Send a terminated string to the network connection. | |
void | appendString (const std::string &str) |
Send a string to the network connection. | |
virtual void | appendExternalBlock (const char *data, size_t len)=0 |
Send a block of data to the network connection, without making a copy. | |
virtual bool | isTextMode () const =0 |
Check if the connection is text mode. | |
virtual bool | isBareMode () const =0 |
Check if the connection is bare mode. | |
virtual void | declareSizes (int argc, int *argv)=0 |
If you can easily determine how many blocks there are in a message, call this first, before anything else. | |
virtual void | setReplyHandler (PortReader &reader)=0 |
This sets a handler to deal with replies to the message. | |
virtual void | setReference (Portable *obj)=0 |
Stores a direct pointer to the object being sent. | |
virtual bool | convertTextMode ()=0 |
Converts a standard description in binary into a textual description, if the connection is in text-mode. | |
virtual bool | isValid () const =0 |
virtual bool | isActive () const =0 |
virtual bool | isError () const =0 |
virtual void | requestDrop ()=0 |
Tag the connection to be dropped after the current message. | |
virtual bool | isNull () const |
virtual SizedWriter * | getBuffer ()=0 |
virtual const SizedWriter * | getBuffer () const =0 |
Static Public Member Functions | |
static ConnectionWriter * | createBufferedConnectionWriter () |
Create a connection writer implementation that stores to a buffer which can be read later using getBuffer() | |
static bool | writeToStream (PortWriter &portable, OutputStream &os) |
An interface for writing to a network connection.
Definition at line 33 of file ConnectionWriter.h.
|
virtualdefault |
Destructor.
Send a block of data to the network connection.
Since communication may not happen immediately, or may happen multiple times, a copy of this data is made. If you know the block of data will remain valid, and it is a large block of data, please call ConnectionWriter::appendExternalBlock instead.
data | the start of the data block |
len | the length of the data block |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
pure virtual |
Send a block of data to the network connection, without making a copy.
If you are not confident that the block of data will remain valid throughout transmission, call ConnectionWriter::appendBlock instead.
data | the start of the data block |
len | the length of the data block |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
pure virtual |
Send a representation of a 32-bit floating point number to the network connection.
data | the floating point number to send |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
pure virtual |
Send a representation of a 64-bit floating point number to the network connection.
data | the floating point number to send |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Send a representation of a 16-bit integer to the network connection.
data | the integer to send |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Send a representation of a 32-bit integer to the network connection.
data | the integer to send |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Send a representation of a 64-bit integer to the network connection.
data | the integer to send |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Send a representation of a 8-bit integer to the network connection.
data | the integer to send |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Send a string to the network connection.
The lenght of string is not specified in advance, therefore the reader should read the number of bytes specified by the first integer. The string terminating character (normally '\0') is not transmitted.
str | the string to send |
Definition at line 113 of file ConnectionWriter.h.
|
pure virtual |
Send a terminated string to the network connection.
The lenght of string is not specified in advance, therefore the reader should read until the terminating character is found.
str | the string to send |
terminate | the terminating character to use |
Implemented in yarp::os::impl::ConnectionRecorder, yarp::os::impl::BufferedConnectionWriter, and yarp::os::NullConnectionWriter.
Converts a standard description in binary into a textual description, if the connection is in text-mode.
Useful if you only operate on the binary description usually, and just want to permit text mode for command-line interaction. If isTextMode would return false, no conversion is done.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
static |
Create a connection writer implementation that stores to a buffer which can be read later using getBuffer()
Definition at line 22 of file ConnectionWriter.cpp.
If you can easily determine how many blocks there are in a message, call this first, before anything else.
This may improve efficiency in some situations.
argc | Number of blocks |
argv | An array of integers, giving the length of each block |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
pure virtual |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
pure virtual |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Check if the connection is bare mode.
If it is, you are encouraged to omit type information from your serialization.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
|
virtual |
Reimplemented in yarp::os::NullConnectionWriter.
Definition at line 16 of file ConnectionWriter.cpp.
Check if the connection is text mode.
If it is, you are encouraged (but by no means required) to use a human-readable representation of your data structure.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Tag the connection to be dropped after the current message.
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::impl::ConnectionRecorder, and yarp::os::NullConnectionWriter.
Stores a direct pointer to the object being sent.
This is useful for local communication, to bypass serialization.
Implemented in yarp::os::NullConnectionWriter, yarp::os::impl::BufferedConnectionWriter, and yarp::os::impl::ConnectionRecorder.
|
pure virtual |
This sets a handler to deal with replies to the message.
The handler will be called once per connection. There will be problems for connections using carriers that don't support replies.
reader | the object that handles replies. |
Implemented in yarp::os::impl::BufferedConnectionWriter, yarp::os::NullConnectionWriter, and yarp::os::impl::ConnectionRecorder.
|
static |
Definition at line 27 of file ConnectionWriter.cpp.