PTLib
Version 2.14.3
|
This is a channel that operates indirectly through another channel(s). More...
#include <indchan.h>
Public Member Functions | |
Construction | |
PIndirectChannel () | |
Create a new indirect channel without any channels to redirect to. More... | |
~PIndirectChannel () | |
Close the indirect channel, deleting read/write channels if desired. More... | |
Overrides from class PObject | |
Comparison | Compare (const PObject &obj) const |
Determine if the two objects refer to the same indirect channel. More... | |
Overrides from class PChannel | |
virtual PString | GetName () const |
Get the name of the channel. More... | |
virtual P_INT_PTR | GetHandle () const |
Get the OS specific handle for the PSoundChannel. More... | |
virtual PBoolean | Close () |
Close the channel. More... | |
virtual PBoolean | IsOpen () const |
Determine if the channel is currently open and read and write operations can be executed on it. More... | |
virtual PBoolean | Read (void *buf, PINDEX len) |
Low level read from the channel. More... | |
virtual int | ReadChar () |
Read a single character from the channel. More... | |
virtual PBoolean | Write (const void *buf, PINDEX len) |
Low level write to the channel. More... | |
virtual PBoolean | Shutdown (ShutdownValue option) |
Close one or both of the data streams associated with a channel. More... | |
virtual bool | SetLocalEcho (bool localEcho) |
Set local echo mode. More... | |
virtual PChannel * | GetBaseReadChannel () const |
This function returns the eventual base channel for reading of a series of indirect channels provided by descendents of PIndirectChannel . More... | |
virtual PChannel * | GetBaseWriteChannel () const |
This function returns the eventual base channel for writing of a series of indirect channels provided by descendents of PIndirectChannel . More... | |
virtual PString | GetErrorText (ErrorGroup group=NumErrorGroups) const |
Get error message description. More... | |
Channel establish functions | |
PBoolean | Open (PChannel &channel) |
Set the channel for both read and write operations. More... | |
PBoolean | Open (PChannel *channel, PBoolean autoDelete=true) |
Set the channel for both read and write operations. More... | |
PBoolean | Open (PChannel *readChannel, PChannel *writeChannel, PBoolean autoDeleteRead=true, PBoolean autoDeleteWrite=true) |
Set the channel for both read and write operations. More... | |
PChannel * | Detach (ShutdownValue option=ShutdownReadAndWrite) |
Detach without closing the read/write channel. More... | |
PChannel * | GetReadChannel () const |
Get the channel used for read operations. More... | |
bool | SetReadChannel (PChannel *channel, bool autoDelete=true, bool closeExisting=false) |
Set the channel for read operations. More... | |
PChannel * | GetWriteChannel () const |
Get the channel used for write operations. More... | |
PBoolean | SetWriteChannel (PChannel *channel, bool autoDelete=true, bool closeExisting=false) |
Set the channel for read operations. More... | |
![]() | |
PBoolean | SetErrorValues (Errors errorCode, int osError, ErrorGroup group=LastGeneralError) |
Set error values to those specified. More... | |
virtual PINDEX | HashFunction () const |
Calculate a hash value for use in sets and dictionaries. More... | |
FILE * | FDOpen (const char *mode) |
Re-open the device using the stdio library. More... | |
void | SetReadTimeout (const PTimeInterval &time) |
Set the timeout for read operations. More... | |
PTimeInterval | GetReadTimeout () const |
Get the timeout for read operations. More... | |
PINDEX | GetLastReadCount () const |
Get the number of bytes read by the last Read() call. More... | |
PBoolean | ReadBlock (void *buf, PINDEX len) |
Read len bytes into the buffer from the channel. More... | |
PString | ReadString (PINDEX len) |
Read len character into a string from the channel. More... | |
void | SetWriteTimeout (const PTimeInterval &time) |
Set the timeout for write operations to complete. More... | |
PTimeInterval | GetWriteTimeout () const |
Get the timeout for write operations to complete. More... | |
virtual PBoolean | Write (const void *buf, PINDEX len, const void *) |
Low level write to the channel with marker. More... | |
virtual PINDEX | GetLastWriteCount () const |
Get the number of bytes written by the last Write() call. More... | |
PBoolean | WriteChar (int c) |
Write a single character to the channel. More... | |
PBoolean | WriteString (const PString &str) |
Write a string to the channel. More... | |
~PChannel () | |
Close down the channel. More... | |
Errors | GetErrorCode (ErrorGroup group=NumErrorGroups) const |
Get normalised error code. More... | |
int | GetErrorNumber (ErrorGroup group=NumErrorGroups) const |
Get OS errro code. More... | |
virtual bool | ReadAsync (AsyncContext &context) |
Begin an asynchronous read from channel. More... | |
virtual void | OnReadComplete (AsyncContext &context) |
User callback function for when a ReadAsync() call has completed or timed out. More... | |
virtual bool | WriteAsync (AsyncContext &context) |
Begin an asynchronous write from channel. More... | |
virtual void | OnWriteComplete (AsyncContext &context) |
User callback function for when a WriteAsync() call has completed or timed out. More... | |
virtual bool | FlowControl (const void *flowData) |
Flow Control information Pass data to the channel for flowControl determination. More... | |
PBoolean | SetBufferSize (PINDEX newSize) |
Set the iostream buffer size for reads and writes. More... | |
PBoolean | SendCommandString (const PString &command) |
Send a command meta-string. More... | |
void | AbortCommandString () |
Abort a command string that is in progress. More... | |
![]() | |
unsigned | GetTraceContextIdentifier () const |
Get PTRACE context identifier. More... | |
void | SetTraceContextIdentifier (unsigned id) |
void | GetTraceContextIdentifier (PObject &obj) |
void | GetTraceContextIdentifier (PObject *obj) |
void | SetTraceContextIdentifier (const PObject &obj) |
void | SetTraceContextIdentifier (const PObject *obj) |
virtual | ~PObject () |
virtual PObject * | Clone () const |
Create a copy of the class on the heap. More... | |
template<class CLS > | |
CLS * | CloneAs () const |
As for Clone() but converts to specified type. More... | |
virtual Comparison | CompareObjectMemoryDirect (const PObject &obj) const |
Determine the byte wise comparison of two objects. More... | |
bool | operator== (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator!= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator< (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator> (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator<= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator>= (const PObject &obj) const |
Compare the two objects. More... | |
virtual const char * | GetClass (unsigned ancestor=0) const |
Get the current dynamic type of the object instance. More... | |
PBoolean | IsClass (const char *cls) const |
virtual PBoolean | InternalIsDescendant (const char *clsName) const |
Determine if the dynamic type of the current instance is a descendent of the specified class. More... | |
__inline const PObject * | PTraceObjectInstance () const |
virtual void | PrintOn (ostream &strm) const |
Output the contents of the object to the stream. More... | |
virtual void | ReadFrom (istream &strm) |
Input the contents of the object from the stream. More... | |
Protected Member Functions | |
virtual PBoolean | OnOpen () |
This callback is executed when the Open() function is called with open channels. More... | |
![]() | |
PChannel (const PChannel &) | |
PChannel & | operator= (const PChannel &) |
virtual PBoolean | ConvertOSError (P_INT_PTR libcReturnValue, ErrorGroup group=LastGeneralError) |
Convert an operating system error into platform independent error. More... | |
int | ReadCharWithTimeout (PTimeInterval &timeout) |
Read a character with specified timeout. More... | |
PBoolean | ReceiveCommandString (int nextChar, const PString &reply, PINDEX &pos, PINDEX start) |
virtual int | os_errno () const |
PBoolean | PXSetIOBlock (PXBlockType type, const PTimeInterval &timeout) |
P_INT_PTR | GetOSHandleAsInt () const |
int | PXClose () |
PChannel () | |
Create the channel. More... | |
![]() | |
PObject () | |
Constructor for PObject, made protected so cannot ever create one on its own. More... | |
Protected Attributes | |
PChannel * | readChannel |
Channel for read operations. More... | |
PBoolean | readAutoDelete |
Automatically delete read channel on destruction. More... | |
PChannel * | writeChannel |
Channel for write operations. More... | |
PBoolean | writeAutoDelete |
Automatically delete write channel on destruction. More... | |
PReadWriteMutex | channelPointerMutex |
Race condition prevention on closing channel. More... | |
![]() | |
P_INT_PTR | os_handle |
The operating system file handle return by standard open() function. More... | |
Errors | lastErrorCode [NumErrorGroups+1] |
The platform independant error code. More... | |
int | lastErrorNumber [NumErrorGroups+1] |
The operating system error number (eg as returned by errno). More... | |
PINDEX | lastReadCount |
Number of byte last read by the Read() function. More... | |
PINDEX | lastWriteCount |
Number of byte last written by the Write() function. More... | |
PTimeInterval | readTimeout |
Timeout for read operations. More... | |
PTimeInterval | writeTimeout |
Timeout for write operations. More... | |
PString | channelName |
Name of channel. More... | |
PMutex | px_threadMutex |
PXBlockType | px_lastBlockType |
PThread * | px_readThread |
PThread * | px_writeThread |
PMutex | px_writeMutex |
PThread * | px_selectThread [3] |
PMutex | px_selectMutex [3] |
![]() | |
unsigned | m_traceContextIdentifier |
This is a channel that operates indirectly through another channel(s).
This allows for a protocol to operate through a "channel" mechanism and for its low level byte exchange (Read and Write) to operate via a completely different channel, eg TCP or Serial port etc.
PIndirectChannel::PIndirectChannel | ( | ) |
Create a new indirect channel without any channels to redirect to.
If an attempt to read or write is made before Open() is called the the functions will assert.
PIndirectChannel::~PIndirectChannel | ( | ) |
Close the indirect channel, deleting read/write channels if desired.
|
virtual |
Close the channel.
This will detach itself from the read and write channels and delete both of them if they are auto delete.
Reimplemented from PChannel.
Reimplemented in PRFC822Channel, PSSLChannel, PVXMLChannel, PPOP3Client, PVXMLSession, XMPP::Stream, XMPP::Transport, PSMTPClient, PFTPClient, PSSDP, XMPP::C2S::TCPTransport, and PSoundChannelPortAudio.
|
virtual |
Determine if the two objects refer to the same indirect channel.
This actually compares the channel pointers.
obj | Another indirect channel to compare against. |
Reimplemented from PChannel.
PChannel* PIndirectChannel::Detach | ( | ShutdownValue | option = ShutdownReadAndWrite | ) |
Detach without closing the read/write channel.
If option
is ShutdownReadAndWrite and the read and write channels are different, then the channels are not detached and NULL is returned.
option | Flag for detach of read, write or both. |
|
virtual |
This function returns the eventual base channel for reading of a series of indirect channels provided by descendents of PIndirectChannel
.
The behaviour for this function is to return "this".
Reimplemented from PChannel.
|
virtual |
This function returns the eventual base channel for writing of a series of indirect channels provided by descendents of PIndirectChannel
.
The behaviour for this function is to return "this".
Reimplemented from PChannel.
|
virtual |
Get error message description.
Return a string indicating the error message that may be displayed to the user. The error for the last I/O operation in this object is used.
group | Error group to get |
Reimplemented from PChannel.
Reimplemented in PSSLChannel, and PSoundChannelPortAudio.
|
virtual |
Get the OS specific handle for the PSoundChannel.
Reimplemented from PChannel.
|
virtual |
Get the name of the channel.
This is a combination of the channel pointers names (or simply the channel pointers name if the read and write channels are the same) or empty string if both null.
Reimplemented from PChannel.
Reimplemented in PSoundChannelPortAudio.
PChannel* PIndirectChannel::GetReadChannel | ( | ) | const |
Get the channel used for read operations.
PChannel* PIndirectChannel::GetWriteChannel | ( | ) | const |
Get the channel used for write operations.
|
virtual |
Determine if the channel is currently open and read and write operations can be executed on it.
For example, in the PFile
class it returns if the file is currently open.
Reimplemented from PChannel.
Reimplemented in PVXMLChannel, and PSoundChannelPortAudio.
|
protectedvirtual |
This callback is executed when the Open() function is called with open channels.
It may be used by descendent channels to do any handshaking required by the protocol that channel embodies.
The default behaviour is to simply return true.
Reimplemented in PRFC822Channel, PSSLChannel, PPOP3Server, PPOP3Client, PFTPServer, PSMTPServer, PFTPClient, PSMTPClient, and XMPP::Stream.
Set the channel for both read and write operations.
This then checks that they are open and then calls the OnOpen() virtual function. If it in turn returns true then the Open() function returns success.
channel | Channel to be used for both read and write operations. |
Set the channel for both read and write operations.
This then checks that they are open and then calls the OnOpen() virtual function. If it in turn returns true then the Open() function returns success.
The channel pointed to by channel
may be automatically deleted when the PIndirectChannel is destroyed or a new subchannel opened.
channel | Channel to be used for both read and write operations. |
autoDelete | Automatically delete the channel |
PBoolean PIndirectChannel::Open | ( | PChannel * | readChannel, |
PChannel * | writeChannel, | ||
PBoolean | autoDeleteRead = true , |
||
PBoolean | autoDeleteWrite = true |
||
) |
Set the channel for both read and write operations.
This then checks that they are open and then calls the OnOpen() virtual function. If it in turn returns true then the Open() function returns success.
The channels pointed to by readChannel
and writeChannel
may be automatically deleted when the PIndirectChannel is destroyed or a new subchannel opened.
readChannel | Channel to be used for both read operations. |
writeChannel | Channel to be used for both write operations. |
autoDeleteRead | Automatically delete the read channel |
autoDeleteWrite | Automatically delete the write channel |
|
virtual |
Low level read from the channel.
This function may block until the requested number of characters were read or the read timeout was reached. The GetLastReadCount() function returns the actual number of bytes read.
This will use the readChannel
pointer to actually do the read. If readChannel
is null the this asserts.
The GetErrorCode() function should be consulted after Read() returns false to determine what caused the failure.
buf | Pointer to a block of memory to receive the read bytes. |
len | Maximum number of bytes to read into the buffer. |
Reimplemented from PChannel.
Reimplemented in PSSLChannel, PVXMLChannel, PDelayChannel, PInternetProtocol, and PSoundChannelPortAudio.
|
virtual |
Read a single character from the channel.
If one was not available within the read timeout period, or an I/O error occurred, then the function gives with a -1 return value.
Note, normally the character read will be an 8 bit value, but for some derived classes, e.g. PConsoleChannel, this may be a code for special input.
Reimplemented from PChannel.
Reimplemented in PInternetProtocol.
|
virtual |
Set local echo mode.
For some classes of channel, e.g. PConsoleChannel, data read by this channel is automatically echoed. This disables the function so things like password entry can work.
Default behaviour does nothing and return true if the channel is open.
Reimplemented from PChannel.
bool PIndirectChannel::SetReadChannel | ( | PChannel * | channel, |
bool | autoDelete = true , |
||
bool | closeExisting = false |
||
) |
Set the channel for read operations.
channel | Channel to be used for both read operations. |
autoDelete | Automatically delete the channel |
closeExisting | Close (and auto-delete) the existing read channel |
PBoolean PIndirectChannel::SetWriteChannel | ( | PChannel * | channel, |
bool | autoDelete = true , |
||
bool | closeExisting = false |
||
) |
Set the channel for read operations.
channel | Channel to be used for both read operations. |
autoDelete | Automatically delete the channel |
closeExisting | Close (and auto-delete) the existing read channel |
|
virtual |
Close one or both of the data streams associated with a channel.
The behavour here is to pass the shutdown on to its read and write channels.
option | Flag for shut down of read, write or both. |
Reimplemented from PChannel.
Reimplemented in PSSLChannel.
|
virtual |
Low level write to the channel.
This function will block until the requested number of characters are written or the write timeout is reached. The GetLastWriteCount() function returns the actual number of bytes written.
This will use the writeChannel
pointer to actually do the write. If writeChannel
is null the this asserts.
The GetErrorCode() function should be consulted after Write() returns false to determine what caused the failure.
buf | Pointer to a block of memory to write. |
len | Number of bytes to write. |
Reimplemented from PChannel.
Reimplemented in PRFC822Channel, PSSLChannel, PVXMLChannel, PDelayChannel, XMPP::Stream, PInternetProtocol, and PSoundChannelPortAudio.
|
protected |
Race condition prevention on closing channel.
|
protected |
Automatically delete read channel on destruction.
|
protected |
Channel for read operations.
Referenced by PSoundChannel::GetSoundChannel(), and PVXMLSession::GetVXMLChannel().
|
protected |
Automatically delete write channel on destruction.
|
protected |
Channel for write operations.