• Skip to content
  • Skip to link menu
Trinity API Reference
  • Trinity API Reference
  • tdecore
 

tdecore

  • KNetwork
  • TDESocketBase
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Friends | List of all members
KNetwork::TDESocketBase Class Reference

#include <tdesocketbase.h>

Inheritance diagram for KNetwork::TDESocketBase:
KNetwork::KActiveSocketBase KNetwork::KPassiveSocketBase KNetwork::KClientSocketBase KNetwork::TDESocketDevice KNetwork::TDEServerSocket KNetwork::TDESocketDevice KNetwork::KDatagramSocket KNetwork::KStreamSocket KNetwork::KHttpProxySocketDevice KNetwork::KMulticastSocketImpl KNetwork::KSocksSocketDevice KNetwork::KHttpProxySocketDevice KNetwork::KMulticastSocketImpl KNetwork::KSocksSocketDevice

Public Types

enum  SocketOptions {
  Blocking = 0x01 , AddressReuseable = 0x02 , IPv6Only = 0x04 , Keepalive = 0x08 ,
  Broadcast = 0x10
}
 
enum  SocketError {
  NoError = 0 , LookupFailure , AddressInUse , AlreadyCreated ,
  AlreadyBound , AlreadyConnected , NotConnected , NotBound ,
  NotCreated , WouldBlock , ConnectionRefused , ConnectionTimedOut ,
  InProgress , NetFailure , NotSupported , Timeout ,
  UnknownError , RemotelyDisconnected
}
 

Public Member Functions

 TDESocketBase ()
 
virtual ~TDESocketBase ()
 
virtual bool setBlocking (bool enable)
 
bool blocking () const
 
virtual bool setAddressReuseable (bool enable)
 
bool addressReuseable () const
 
virtual bool setIPv6Only (bool enable)
 
bool isIPv6Only () const
 
virtual bool setBroadcast (bool enable)
 
bool broadcast () const
 
TDESocketDevice * socketDevice () const
 
virtual void setSocketDevice (TDESocketDevice *device)
 
int setRequestedCapabilities (int add, int remove=0)
 
SocketError error () const
 
TQString errorString () const
 
TQMutex * mutex () const
 

Static Public Member Functions

static TQString errorString (SocketError code)
 
static bool isFatalError (int code)
 

Protected Member Functions

virtual bool setSocketOptions (int opts)
 
virtual int socketOptions () const
 
bool hasDevice () const
 
void setError (SocketError error)
 

Friends

class TDESocketDevice
 

Detailed Description

Basic socket functionality.

This class provides the basic socket functionlity for descended classes. Socket classes are thread-safe and provide a recursive mutex should it be needed.

Note
This class is abstract.
Author
Thiago Macieira thiag.nosp@m.o.ma.nosp@m.cieir.nosp@m.a@kd.nosp@m.email.nosp@m..net

Definition at line 97 of file tdesocketbase.h.

Member Enumeration Documentation

◆ SocketError

enum KNetwork::TDESocketBase::SocketError

Possible socket error codes.

This is a list of possible error conditions that socket classes may be expected to find.

  • NoError: no error has been detected
  • LookupFailure: if a name lookup has failed
  • AddressInUse: address is already in use
  • AlreadyBound: cannot bind again
  • AlreadyCreated: cannot recreate the socket
  • NotBound: operation required socket to be bound and it isn't
  • NotCreated: operation required socket to exist and it doesn't
  • WouldBlock: requested I/O operation would block
  • ConnectionRefused: connection actively refused
  • ConnectionTimedOut: connection timed out
  • InProgress: operation (connection) is already in progress
  • NetFailure: a network failure occurred (no route, host down, host unreachable or similar)
  • NotSupported: requested operation is not supported
  • Timeout: a timed operation timed out
  • UnknownError: an unknown/unexpected error has happened
  • RemotelyDisconnected: when a connection is disconnected by the other end (since 3.4)
See also
error, errorString

Definition at line 152 of file tdesocketbase.h.

◆ SocketOptions

enum KNetwork::TDESocketBase::SocketOptions

Possible socket options.

These are the options that may be set on a socket:

  • Blocking: whether the socket shall operate in blocking or non-blocking mode. This flag defaults to on. See setBlocking.
  • AddressReusable: whether the address used by this socket will be available for reuse by other sockets. This flag defaults to off. See setAddressReuseable.
  • IPv6Only: whether an IPv6 socket will accept IPv4 connections through a mapped address. This flag defaults to off. See setIPv6Only.
  • KeepAlive: whether TCP should send keepalive probes when a connection has gone idle for far too long.
  • Broadcast: whether this socket is allowed to send broadcast packets and will receive packets sent to broadcast.

Definition at line 118 of file tdesocketbase.h.

Constructor & Destructor Documentation

◆ TDESocketBase()

TDESocketBase::TDESocketBase ( )

Default constructor.

Definition at line 50 of file tdesocketbase.cpp.

◆ ~TDESocketBase()

TDESocketBase::~TDESocketBase ( )
virtual

Destructor.

Definition at line 59 of file tdesocketbase.cpp.

Member Function Documentation

◆ addressReuseable()

bool TDESocketBase::addressReuseable ( ) const

Retrieves this socket's address reuseability flag.

Returns
true if this socket's address can be reused, false if it can't.

Definition at line 91 of file tdesocketbase.cpp.

◆ blocking()

bool TDESocketBase::blocking ( ) const

Retrieves this socket's blocking mode.

Returns
true if this socket is/will be operated in blocking mode, false if non-blocking.

Definition at line 81 of file tdesocketbase.cpp.

◆ broadcast()

bool TDESocketBase::broadcast ( ) const

Retrieves this socket's Broadcast flag.

Returns
true if this socket can send and receive broadcast packets, false if it can't.

Definition at line 111 of file tdesocketbase.cpp.

◆ error()

TDESocketBase::SocketError TDESocketBase::error ( ) const

Retrieves the socket error code.

See also
errorString

Definition at line 160 of file tdesocketbase.cpp.

◆ errorString() [1/2]

TQString KNetwork::TDESocketBase::errorString ( ) const
inline

Returns the error string corresponding to this error condition.

Definition at line 383 of file tdesocketbase.h.

◆ errorString() [2/2]

TQString TDESocketBase::errorString ( TDESocketBase::SocketError  code)
static

Returns the string describing the given error code, i18n'ed.

Parameters
codethe error code

Definition at line 166 of file tdesocketbase.cpp.

◆ hasDevice()

bool TDESocketBase::hasDevice ( ) const
protected

Returns true if the socket device has been initialised in this object, either by calling socketDevice() or setSocketDevice.

Definition at line 150 of file tdesocketbase.cpp.

◆ isFatalError()

bool TDESocketBase::isFatalError ( int  code)
static

Returns true if the given error code is a fatal one, false otherwise.

The parameter here is of type int so that casting isn't necessary when using the parameter to signal QClientSocketBase::gotError.

Parameters
codethe code to test

Definition at line 259 of file tdesocketbase.cpp.

◆ isIPv6Only()

bool TDESocketBase::isIPv6Only ( ) const

Retrieves this socket's IPv6 Only flag.

Returns
true if this socket will ignore IPv4-compatible and IPv4-mapped addresses, false if it will accept them.

Definition at line 101 of file tdesocketbase.cpp.

◆ mutex()

TQMutex * TDESocketBase::mutex ( ) const

Returns the internal mutex for this class.

Note on multithreaded use of sockets: the socket classes are thread-safe by design, but you should be aware of problems regarding socket creation, connection and destruction in multi-threaded programs. The classes are guaranteed to work while the socket exists, but it's not wise to call connect in multiple threads.

Also, this mutex must be unlocked before the object is destroyed, which means you cannot use it to guard against other threads accessing the object while destroying it. You must ensure there are no further references to this object when deleting it.

Definition at line 278 of file tdesocketbase.cpp.

◆ setAddressReuseable()

bool TDESocketBase::setAddressReuseable ( bool  enable)
virtual

Sets this socket's address reuseable flag.

When the address reuseable flag is active, the address used by this socket is left reuseable for other sockets to bind. If the flag is not active, no other sockets may reuse the same address.

The default implementation toggles the AddressReuseable flag with the current socket options and calls setSocketOptions.

Parameters
enablewhether to set the flag on or off
Returns
true if setting this flag was successful

Definition at line 86 of file tdesocketbase.cpp.

◆ setBlocking()

bool TDESocketBase::setBlocking ( bool  enable)
virtual

Sets this socket's blocking mode.

In blocking operation, all I/O functions are susceptible to blocking – i.e., will not return unless the I/O can be satisfied. In non-blocking operation, if the I/O would block, the function will return an error and set the corresponding error code.

The default implementation toggles the Blocking flag with the current socket options and calls setSocketOptions.

Parameters
enablewhether to set this socket to blocking mode
Returns
whether setting this value was successful; it is NOT the final blocking mode.

Definition at line 76 of file tdesocketbase.cpp.

◆ setBroadcast()

bool TDESocketBase::setBroadcast ( bool  enable)
virtual

Sets this socket Broadcast flag.

Datagram-oriented sockets cannot normally send packets to broadcast addresses, nor will they receive packets that were sent to a broadcast address. To do so, you need to enable the Broadcast flag.

This option has no effect on stream-oriented sockets.

Returns
true if setting this flag was successful.

Definition at line 106 of file tdesocketbase.cpp.

◆ setError()

void TDESocketBase::setError ( SocketError  error)
protected

Sets the socket's error code.

Parameters
errorthe error code

Definition at line 155 of file tdesocketbase.cpp.

◆ setIPv6Only()

bool TDESocketBase::setIPv6Only ( bool  enable)
virtual

Sets this socket's IPv6 Only flag.

When this flag is on, an IPv6 socket will only accept, connect, send to or receive from IPv6 addresses. When it is off, it will also talk to IPv4 addresses through v4-mapped addresses.

This option has no effect on non-IPv6 sockets.

The default implementation toggles the IPv6Only flag with the current socket options and calls setSocketOptions.

Parameters
enablewhether to set the flag on or off
Returns
true if setting this flag was successful

Definition at line 96 of file tdesocketbase.cpp.

◆ setRequestedCapabilities()

int TDESocketBase::setRequestedCapabilities ( int  add,
int  remove = 0 
)

Sets the internally requested capabilities for a socket device.

Most socket classes can use any back-end implementation. However, a few may require specific capabilities not provided in the default implementation. By using this function, derived classes can request that a backend with those capabilities be created when necessary.

For the possible flags, see TDESocketDevice::Capabilities. However, note that only the Can* flags make sense in this context.

Note
Since socketDevice must always return a valid backend object, it is is possible that the created device does not conform to all requirements requested. Implementations sensitive to this fact should test the object returned by socketDevice (through TDESocketDevice::capabilities, for instance) the availability.
Parameters
addmask of TDESocketDevice::Capabilities to add
removemask of bits to remove from the requirements
Returns
the current mask of requested capabilities

Definition at line 143 of file tdesocketbase.cpp.

◆ setSocketDevice()

void TDESocketBase::setSocketDevice ( TDESocketDevice *  device)
virtual

Sets the socket implementation to be used on this socket.

Note: it is an error to set this if the socket device has already been set once.

This function is provided virtual so that derived classes can catch the setting of a device and properly set their own states and internal variables. The parent class must be called.

This function is called by socketDevice above when the socket is first created.

Reimplemented in KNetwork::TDEBufferedSocket.

Definition at line 136 of file tdesocketbase.cpp.

◆ setSocketOptions()

bool TDESocketBase::setSocketOptions ( int  opts)
protectedvirtual

Set the given socket options.

The default implementation does nothing but store the mask internally. Descended classes must override this function to achieve functionality and must also call this implementation.

Parameters
optsa mask of SocketOptions or-ed bits of options to set or unset
Returns
true on success
Note
this function sets the options corresponding to the bits enabled in opts but will also unset the optiosn corresponding to the bits not set.

Reimplemented in KNetwork::TDEBufferedSocket, KNetwork::KClientSocketBase, KNetwork::TDEServerSocket, and KNetwork::TDESocketDevice.

Definition at line 65 of file tdesocketbase.cpp.

◆ socketDevice()

TDESocketDevice * TDESocketBase::socketDevice ( ) const

Retrieves the socket implementation used on this socket.

This function creates the device if none has been set using the default factory.

Definition at line 116 of file tdesocketbase.cpp.

◆ socketOptions()

int TDESocketBase::socketOptions ( ) const
protectedvirtual

Retrieves the socket options that have been set.

The default implementation just retrieves the mask from an internal variable. Descended classes may choose to override this function to read the values from the operating system.

Returns
the mask of the options set

Definition at line 71 of file tdesocketbase.cpp.

Friends And Related Function Documentation

◆ TDESocketDevice

friend class TDESocketDevice
friend

Definition at line 431 of file tdesocketbase.h.


The documentation for this class was generated from the following files:
  • tdesocketbase.h
  • tdesocketbase.cpp

tdecore

Skip menu "tdecore"
  • Main Page
  • Modules
  • Namespace List
  • Class Hierarchy
  • Alphabetical List
  • Class List
  • File List
  • Namespace Members
  • Class Members
  • Related Pages

tdecore

Skip menu "tdecore"
  • arts
  • dcop
  • dnssd
  • interfaces
  •   kspeech
  •     interface
  •     library
  •   tdetexteditor
  • kate
  • kded
  • kdoctools
  • kimgio
  • kjs
  • libtdemid
  • libtdescreensaver
  • tdeabc
  • tdecmshell
  • tdecore
  • tdefx
  • tdehtml
  • tdeinit
  • tdeio
  •   bookmarks
  •   httpfilter
  •   kpasswdserver
  •   kssl
  •   tdefile
  •   tdeio
  •   tdeioexec
  • tdeioslave
  •   http
  • tdemdi
  •   tdemdi
  • tdenewstuff
  • tdeparts
  • tdeprint
  • tderandr
  • tderesources
  • tdespell2
  • tdesu
  • tdeui
  • tdeunittest
  • tdeutils
  • tdewallet
Generated for tdecore by doxygen 1.9.4
This website is maintained by Timothy Pearson.