![]() |
TSDuck v3.45-4686
MPEG Transport Stream Toolkit
|
Line oriented Telnet connection for use in a Reactor environment. More...
#include <tsReactiveTelnetConnection.h>


Public Member Functions | |
| ReactiveTelnetConnection (ReactiveTCPConnection &socket, Object *owner=nullptr) | |
| Constructor. | |
| virtual | ~ReactiveTelnetConnection () override |
| Destructor. | |
| bool | isOwned () |
| Check if the object is owned. | |
| template<class OBJECT > requires std::derived_from<OBJECT, ts::Object> | |
| bool | isOwned () |
| Check if the object is owned by an object of a given type. | |
| Object * | owner () |
| Get the address of the optional "owner" object which was specified in the constructor. | |
| template<class OBJECT > requires std::derived_from<OBJECT, ts::Object> | |
| OBJECT * | owner () |
| Get the address of the "owner" object which was specified in the constructor. | |
| Reactor & | reactor () |
| Get a reference to the associated reactor. | |
| Report & | report () |
| Get a reference to the associated report. | |
| ReactiveTCPConnection & | socket () |
| Get a reference to the associated socket. | |
| bool | startReceive (ReactiveTelnetConnectionHandlerInterface *handler, size_t buffer_size=ReactiveTCPConnection::DEFAULT_RECEIVE_BUFFER_SIZE) |
| Start the operation of receiving messages from the socket. | |
| bool | startSendLine (const std::string &line, bool flush=true) |
| Start the operation of sending a line of text over the TCP connection. | |
| bool | startSendLine (const UString &line, bool flush=true) |
| Start the operation of sending a line of text over the TCP connection. | |
| bool | startSendText (const std::string &text, bool flush=true) |
| Start the operation of sending text over the TCP connection. | |
| bool | startSendText (const UString &text, bool flush=true) |
| Start the operation of sending text over the TCP connection. | |
Protected Types | |
| using | IOQueue = std::list< std::shared_ptr< IOSB > > |
| Queues of I/O requests are queues of shared_ptr to IOSB. | |
| using | IOSB = NonBlockingDevice::IOSB |
| IOSB shortcut fpr subclasses. | |
| using | IOSet = std::set< std::shared_ptr< IOSB > > |
| Unordered set of I/O requests, set of shared_ptr to IOSB. | |
Protected Member Functions | |
| bool | activateAsynchronousIO () |
| Activate notification for asynchronous I/O. | |
| bool | activateReadReady () |
| Activate read-ready notification for non-blocking I/O. | |
| bool | activateWriteReady () |
| Activate write-ready notification for non-blocking I/O. | |
| bool | cancelAndWaitAsynchronousIO (NonBlockingDevice::IOSB &iosb, bool silent) |
| Cancel one specific pending asynchronous I/O and wait for its completion. | |
| void | cancelAsynchronousIO (bool silent) |
| Cancel all asynchronous I/O in progress. | |
| template<class REQUEST > requires std::derived_from<REQUEST, ts::Object> | |
| void | cancelQueue (IOQueue &inqueue, IOQueue &outqueue) |
| Transfer all requests from one queue to another and mark all I/O as canceled. | |
| void | deactivateAll (bool silent) |
| Deactivate all registrations for non-blocking and asynchronous I/O. | |
| void | deactivateAsynchronousIO (bool silent) |
| Deactivate notification for asynchronous I/O. | |
| void | deactivateCompletedIO (bool silent) |
| Deactivate the execution of processCompletedIO() in the context of a Reactor handler. | |
| void | deactivateReadReady (bool silent) |
| Deactivate read-ready notification for non-blocking I/O. | |
| void | deactivateWriteReady (bool silent) |
| Deactivate write-ready notification for non-blocking I/O. | |
| virtual void | handleAsynchronousIO (Reactor &reactor, EventId id, NonBlockingDevice::IOSB &iosb, size_t io_size) |
| Handle an asynchronous I/O completion event in a Reactor. | |
| virtual void | handleReadReady (Reactor &reactor, EventId id, int error_code) |
| Handle a read-ready event in a Reactor. | |
| virtual void | handleTimer (Reactor &reactor, EventId id) |
| Handle a timer in a Reactor. | |
| virtual void | handleUserEvent (Reactor &, EventId) override |
| Handle a user-defined event in a Reactor. | |
| virtual void | handleWriteReady (Reactor &reactor, EventId id, int error_code) |
| Handle a write-ready event in a Reactor. | |
| virtual void | processCompletedIO () |
| This virtual method process completed I/O operations in the context of a Reactor handler. | |
| std::shared_ptr< IOSB > | removeFromQueue (IOQueue &queue, IOSB *iosb) |
| Search and remove a shared_ptr to IOSB, based on an IOSB address. | |
| bool | signalCompletedIO () |
| Trigger the execution of processCompletedIO() in the context of a Reactor handler. | |
Line oriented Telnet connection for use in a Reactor environment.
The class ReactiveTelnetConnection is a wrapper around ReactiveTCPConnection to handle reactive I/O.
|
protectedinherited |
Queues of I/O requests are queues of shared_ptr to IOSB.
This is typically used with non-blocking I/O where we must process requests in order. Send and receive requests are structures which are stored in the react_data of the IOSB.
|
protectedinherited |
Unordered set of I/O requests, set of shared_ptr to IOSB.
This is typically used with asynchronous I/O. The ordering is enforced because I/O are started in order of calls from applications. The completion processing is likely the same, but driven by the system I/O Completion Ports and we must not assume any order. Send and receive requests are structures which are stored in the react_data of the IOSB.
| ts::ReactiveTelnetConnection::ReactiveTelnetConnection | ( | ReactiveTCPConnection & | socket, |
| Object * | owner = nullptr |
||
| ) |
Constructor.
| [in,out] | socket | Associated reactive TCP socket. The socket object must remain valid as long as this object is valid. |
| [in] | owner | Optional address of an "owner" object, typically an instance of class containing this object. |
|
inline |
Get a reference to the associated socket.
| bool ts::ReactiveTelnetConnection::startSendLine | ( | const std::string & | line, |
| bool | flush = true |
||
| ) |
Start the operation of sending a line of text over the TCP connection.
There is no completion handler because the sent data is kept in a dedicated buffer.
| [in] | line | Text line to send. The corresponding memory area is no longer used upon return. An end-of-line marker is automatically added. |
| [in] | flush | If false, data are buffered into the ReactiveTelnetConnection and no completion handler will be called. When true, all previously buffered data are sent with data from this call. |
| bool ts::ReactiveTelnetConnection::startSendLine | ( | const UString & | line, |
| bool | flush = true |
||
| ) |
Start the operation of sending a line of text over the TCP connection.
There is no completion handler because the sent data is kept in a dedicated buffer.
| [in] | line | Text line to send. The corresponding memory area is no longer used upon return. An end-of-line marker is automatically added. |
| [in] | flush | If false, data are buffered into the ReactiveTelnetConnection and no completion handler will be called. When true, all previously buffered data are sent with data from this call. |
| bool ts::ReactiveTelnetConnection::startSendText | ( | const std::string & | text, |
| bool | flush = true |
||
| ) |
Start the operation of sending text over the TCP connection.
There is no completion handler because the sent data is kept in a dedicated buffer.
| [in] | text | Text to send. The corresponding memory area is no longer used upon return. No end-of-line marker is added. |
| [in] | flush | If false, data are buffered into the ReactiveTelnetConnection and no completion handler will be called. When true, all previously buffered data are sent with data from this call. |
| bool ts::ReactiveTelnetConnection::startSendText | ( | const UString & | text, |
| bool | flush = true |
||
| ) |
Start the operation of sending text over the TCP connection.
There is no completion handler because the sent data is kept in a dedicated buffer.
| [in] | text | Text to send. The corresponding memory area is no longer used upon return. No end-of-line marker is added. |
| [in] | flush | If false, data are buffered into the ReactiveTelnetConnection and no completion handler will be called. When true, all previously buffered data are sent with data from this call. |
| bool ts::ReactiveTelnetConnection::startReceive | ( | ReactiveTelnetConnectionHandlerInterface * | handler, |
| size_t | buffer_size = ReactiveTCPConnection::DEFAULT_RECEIVE_BUFFER_SIZE |
||
| ) |
Start the operation of receiving messages from the socket.
| [in] | handler | Handler class to call each time a text line is received. The method handleTelnetLine() will be called on each received line. Cannot be null. If a previous receive handler was registered, it is replaced. |
| [in] | buffer_size | Size of input buffers to receive data. |
|
inlineinherited |
Get a reference to the associated reactor.
|
inlineinherited |
Get a reference to the associated report.
|
protectedinherited |
Search and remove a shared_ptr to IOSB, based on an IOSB address.
Search from the front (end) of the queue since a completed I/O is likely on the front.
| [in,out] | queue | The queue from which to remove iosb. |
| [in] | iosb | Standard pointer to an IOSB to search and remove. |
|
protectedinherited |
Transfer all requests from one queue to another and mark all I/O as canceled.
| REQUEST | The subclass of Object which is set in react_data of all requests in inqueue. |
| [in,out] | inqueue | The queue from which all requests are removed. |
| [in,out] | outqueue | The queue which receives all canceled requests. |
|
protectedinherited |
Trigger the execution of processCompletedIO() in the context of a Reactor handler.
Create if necessary and then signal a dedicated user event.
|
protectedinherited |
Deactivate the execution of processCompletedIO() in the context of a Reactor handler.
Deactivate and delete the dedicated user event.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedvirtualinherited |
This virtual method process completed I/O operations in the context of a Reactor handler.
The default implementation does nothing. A subclass should override it if it calls signalCompletedIO().
|
protectedinherited |
Activate read-ready notification for non-blocking I/O.
|
protectedinherited |
Deactivate read-ready notification for non-blocking I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Activate write-ready notification for non-blocking I/O.
|
protectedinherited |
Deactivate write-ready notification for non-blocking I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Activate notification for asynchronous I/O.
|
protectedinherited |
Deactivate notification for asynchronous I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Cancel all asynchronous I/O in progress.
The cancelation occurs in the background and end of canceled asynchronous I/O will be notified.
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Cancel one specific pending asynchronous I/O and wait for its completion.
Warning: This is a blocking call. It shall be used in case of trouble only.
| [in,out] | iosb | The asynchronous I/O status block. |
| [in] | silent | If true, do not report errors through the logger. |
|
protectedinherited |
Deactivate all registrations for non-blocking and asynchronous I/O.
| [in] | silent | If true, do not report errors through the logger. |
|
overrideprotectedvirtualinherited |
Handle a user-defined event in a Reactor.
| [in,out] | reactor | Reactor into which the handler is invoked. |
| [in] | id | Id of the event which was signaled. |
Reimplemented from ts::ReactorHandlerInterface.
|
inlineinherited |
Get the address of the optional "owner" object which was specified in the constructor.
|
inherited |
Get the address of the "owner" object which was specified in the constructor.
This template version requires that the owner objet is set and of type OBJECT, or some subclass of it. If there is no owner object or if it is not compatible with the template class OBJECT, this is a fatal error and the application is terminated.
| OBJECT | A subclass of Object |
|
inlineinherited |
Check if the object is owned.
|
inlineinherited |
Check if the object is owned by an object of a given type.
| OBJECT | A subclass of Object |
|
virtualinherited |
Handle a read-ready event in a Reactor.
This handler is only invoked in the non-blocking I/O model.
| [in,out] | reactor | Reactor into which the handler is invoked. |
| [in] | id | Id of the event which was signaled. |
| [in] | error_code | System-specific error code, zero on success, SYS_ERROR in case of unknown error. |
|
virtualinherited |
Handle a write-ready event in a Reactor.
This handler is only invoked in the non-blocking I/O model.
| [in,out] | reactor | Reactor into which the handler is invoked. |
| [in] | id | Id of the event which was signaled. |
| [in] | error_code | System-specific error code, zero on success, SYS_ERROR in case of unknown error. |
|
virtualinherited |
Handle an asynchronous I/O completion event in a Reactor.
This handler is only invoked in the asynchronous I/O model.
| [in,out] | reactor | Reactor into which the handler is invoked. |
| [in] | id | Id of the event which was signaled. |
| [in,out] | iosb | IOSB structure which was used when the asynchronous I/O was started. A system-specific error code is in iosb, SYS_CANCELED if the I/O was canceled before completion. |
| [in] | io_size | Size of the I/O in bytes. |