]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/socket.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface of wxIP*address, wxSocket* classes 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows licence 
   7 ///////////////////////////////////////////////////////////////////////////// 
  13     wxIPaddress is an abstract base class for all internet protocol address 
  14     objects. Currently, only wxIPV4address is implemented. An experimental 
  15     implementation for IPV6, wxIPV6address, is being developed. 
  20 class wxIPaddress 
: public wxSockAddress
 
  24         Internally, this is the same as setting the IP address to @b INADDR_ANY. 
  26         On IPV4 implementations, 0.0.0.0 
  28         On IPV6 implementations, :: 
  30         @return @true on success, @false if something went wrong. 
  35         Internally, this is the same as setting the IP address to @b INADDR_BROADCAST. 
  37         On IPV4 implementations, 255.255.255.255 
  39         @return @true on success, @false if something went wrong. 
  41     virtual bool BroadcastAddress() = 0; 
  44         Set the address to hostname, which can be a host name or an IP-style address 
  45         in a format dependent on implementation. 
  47         @return @true on success, @false if something goes wrong (invalid 
  48                 hostname or invalid IP address). 
  50     bool Hostname(const wxString
& hostname
); 
  53         Returns the hostname which matches the IP address. 
  55     wxString 
Hostname() const; 
  58         Returns a wxString containing the IP address. 
  60     virtual wxString 
IPAddress() const = 0; 
  63         Determines if current address is set to localhost. 
  65         @return @true if address is localhost, @false if internet address. 
  67     virtual bool IsLocalHost() const = 0; 
  70         Set address to localhost. 
  72         On IPV4 implementations, 127.0.0.1 
  74         On IPV6 implementations, ::1 
  76         @return @true on success, @false if something went wrong. 
  81         Set the port to that corresponding to the specified service. 
  83         @return @true on success, @false if something goes wrong (invalid @a service). 
  85     bool Service(const wxString
& service
); 
  88         Set the port to that corresponding to the specified service. 
  90         @return @true on success, @false if something goes wrong (invalid @a service). 
  92     bool Service(unsigned short service
); 
  95         Returns the current service. 
  97     unsigned short Service() const; 
 104     A class for working with IPv4 network addresses. 
 109 class wxIPV4address 
: public wxIPaddress
 
 113         Set address to any of the addresses of the current machine. 
 115         Whenever possible, use this function instead of LocalHost(), 
 116         as this correctly handles multi-homed hosts and avoids other small 
 117         problems. Internally, this is the same as setting the IP address 
 120         @return @true on success, @false if something went wrong. 
 125         Set the address to hostname, which can be a host name or an IP-style address 
 126         in dot notation(<tt>a.b.c.d</tt>). 
 128         @return @true on success, @false if something goes wrong (invalid 
 129                 hostname or invalid IP address). 
 131     bool Hostname(const wxString
& hostname
); 
 134         Returns the hostname which matches the IP address. 
 136     virtual wxString 
Hostname() const; 
 139         Returns a wxString containing the IP address in dot quad (127.0.0.1) format. 
 141     virtual wxString 
IPAddress() const; 
 144         Set address to localhost (127.0.0.1). 
 146         Whenever possible, use AnyAddress() instead of this one, as that one will 
 147         correctly handle multi-homed hosts and avoid other small problems. 
 149         @return @true on success, @false if something went wrong. 
 154         Set the port to that corresponding to the specified @a service. 
 156         @return @true on success, @false if something goes wrong (invalid @a service). 
 158     bool Service(const wxString
& service
); 
 161         Set the port to that corresponding to the specified @a service. 
 163         @return @true on success, @false if something goes wrong (invalid @a service). 
 165     bool Service(unsigned short service
); 
 168         Returns the current service. 
 170     unsigned short Service() const; 
 176     @class wxSocketServer 
 183 class wxSocketServer 
: public wxSocketBase
 
 187         Constructs a new server and tries to bind to the specified @e address. 
 189         Before trying to accept new connections, remember to test whether it succeeded 
 190         with wxSocketBase:IsOk(). 
 193             Specifies the local address for the server (e.g. port number). 
 195             Socket flags (See wxSocketBase::SetFlags()). 
 197     wxSocketServer(const wxSockAddress
& address
, 
 198                    wxSocketFlags flags 
= wxSOCKET_NONE
); 
 201         Destructor (it doesn't close the accepted connections). 
 203     virtual ~wxSocketServer(); 
 206         Accepts an incoming connection request, and creates a new wxSocketBase 
 207         object which represents the server-side of the connection. 
 209         If @a wait is @true and there are no pending connections to be 
 210         accepted, it will wait for the next incoming connection to 
 213         @warning This method will block the GUI. 
 215         If @a wait is @false, it will try to accept a pending connection 
 216         if there is one, but it will always return immediately without blocking 
 217         the GUI. If you want to use Accept() in this way, you can either check for 
 218         incoming connections with WaitForAccept() or catch @b wxSOCKET_CONNECTION events, 
 219         then call Accept() once you know that there is an incoming connection waiting 
 222         @return Returns an opened socket connection, or @NULL if an error 
 223                 occurred or if the wait parameter was @false and there 
 224                 were no pending connections. 
 226         @see WaitForAccept(), wxSocketBase::SetNotify(), 
 227              wxSocketBase::Notify(), AcceptWith() 
 229     wxSocketBase
* Accept(bool wait 
= true); 
 232         Accept an incoming connection using the specified socket object. 
 235             Socket to be initialized 
 237             See Accept() for more info. 
 239         @return Returns @true on success, or @false if an error occurred or 
 240                 if the wait parameter was @false and there were no pending 
 243         @see WaitForAccept(), wxSocketBase::SetNotify(), 
 244              wxSocketBase::Notify(), Accept() 
 246     bool AcceptWith(wxSocketBase
& socket
, bool wait 
= true); 
 249         Wait for an incoming connection. 
 251         Use it if you want to call Accept() or AcceptWith() with @e wait set 
 252         to @false, to detect when an incoming connection is waiting to be accepted. 
 255             Number of seconds to wait. If -1, it will wait for the default 
 256             timeout, as set with wxSocketBase::SetTimeout(). 
 258             Number of milliseconds to wait. 
 260         @return @true if an incoming connection arrived, @false if the timeout 
 263         @see Accept(), AcceptWith(), wxSocketBase::InterruptWait() 
 265     bool WaitForAccept(long seconds 
= -1, long millisecond 
= 0); 
 270     @class wxSocketClient 
 277 class wxSocketClient 
: public wxSocketBase
 
 284             Socket flags (See wxSocketBase::SetFlags()) 
 286     wxSocketClient(wxSocketFlags flags 
= wxSOCKET_NONE
); 
 289         Destructor. Please see wxSocketBase::Destroy(). 
 291     virtual ~wxSocketClient(); 
 294         Connects to a server using the specified address. 
 296         If @a wait is @true, Connect() will wait until the connection 
 299         @warning This method will block the GUI. 
 301         If @a wait is @false, Connect() will try to establish the connection 
 302         and return immediately, without blocking the GUI. When used this way, 
 303         even if Connect() returns @false, the connection request can be 
 304         completed later. To detect this, use WaitOnConnect(), or catch 
 305         @b wxSOCKET_CONNECTION events (for successful establishment) and 
 306         @b wxSOCKET_LOST events (for connection failure). 
 309             Address of the server. 
 311             If @true, waits for the connection to complete. 
 313         @return @true if the connection is established and no error occurs. 
 314                 If @a wait was true, and Connect() returns @false, an error 
 315                 occurred and the connection failed. 
 316                 If @a wait was @false, and Connect() returns @false, you should 
 317                 still be prepared to handle the completion of this connection request, 
 318                 either with WaitOnConnect() or by watching wxSOCKET_CONNECTION 
 319                 and wxSOCKET_LOST events. 
 321         @see WaitOnConnect(), wxSocketBase::SetNotify(), wxSocketBase::Notify() 
 323     virtual bool Connect(const wxSockAddress
& address
, bool wait 
= true); 
 326         Connects to a server using the specified address. 
 328         If @a wait is @true, Connect() will wait until the connection 
 329         completes. @b Warning: This will block the GUI. 
 331         If @a wait is @false, Connect() will try to establish the connection 
 332         and return immediately, without blocking the GUI. When used this way, 
 333         even if Connect() returns @false, the connection request can be 
 334         completed later. To detect this, use WaitOnConnect(), or catch 
 335         @b wxSOCKET_CONNECTION events (for successful establishment) and 
 336         @b wxSOCKET_LOST events (for connection failure). 
 339             Address of the server. 
 341             Bind to the specified local address and port before connecting. 
 342             The local address and port can also be set using SetLocal(), 
 343             and then using the 2-parameter Connect() method. 
 345             If @true, waits for the connection to complete. 
 347         @return @true if the connection is established and no error occurs. 
 348                 If @a wait was true, and Connect() returns @false, an error 
 349                 occurred and the connection failed. 
 350                 If @a wait was @false, and Connect() returns @false, you should 
 351                 still be prepared to handle the completion of this connection request, 
 352                 either with WaitOnConnect() or by watching wxSOCKET_CONNECTION 
 353                 and wxSOCKET_LOST events. 
 355         @see WaitOnConnect(), wxSocketBase::SetNotify(), wxSocketBase::Notify() 
 357     bool Connect(const wxSockAddress
& address
, const wxSockAddress
& local
, 
 361         Wait until a connection request completes, or until the specified timeout 
 362         elapses. Use this function after issuing a call to Connect() with 
 363         @e wait set to @false. 
 366             Number of seconds to wait. 
 367             If -1, it will wait for the default timeout, as set with wxSocketBase::SetTimeout(). 
 369             Number of milliseconds to wait. 
 372             WaitOnConnect() returns @true if the connection request completes. 
 373             This does not necessarily mean that the connection was 
 374             successfully established; it might also happen that the 
 375             connection was refused by the peer. Use wxSocketBase::IsConnected() 
 376             to distinguish between these two situations. 
 377             @n @n If the timeout elapses, WaitOnConnect() returns @false. 
 378             @n @n These semantics allow code like this: 
 380             // Issue the connection request 
 381             client->Connect(addr, false); 
 383             // Wait until the request completes or until we decide to give up 
 384             bool waitmore = true; 
 385             while ( !client->WaitOnConnect(seconds, millis) && waitmore ) 
 387                 // possibly give some feedback to the user, 
 388                 // and update waitmore as needed. 
 390             bool success = client->IsConnected(); 
 393     bool WaitOnConnect(long seconds 
= -1, long milliseconds 
= 0); 
 401     You are unlikely to need to use this class: only wxSocketBase uses it. 
 406     @see wxSocketBase, wxIPaddress, wxIPV4address 
 408 class wxSockAddress 
: public wxObject
 
 419     virtual ~wxSockAddress(); 
 422         Delete all informations about the address. 
 424     virtual void Clear(); 
 427         Returns the length of the socket address. 
 432         Returns the pointer to the low-level representation of the address. 
 434         This can be used to pass socket address information to a 3rd party 
 438             Pointer to a sockaddr-derived struct. 
 440     const sockaddr 
*GetAddressData() const; 
 443         Returns the length of the buffer retrieved by GetAddressData(). 
 446             The size of the sockaddr-derived struct corresponding to this 
 449     int GetAddressDataLen() const; 
 457     This event class contains information about socket events. 
 458     This kind of events are sent to the event handler specified with 
 459     wxSocketBase::SetEventHandler. 
 461     @beginEventTable{wxSocketEvent} 
 462     @event{EVT_SOCKET(id, func)} 
 463         Process a socket event, supplying the member function. 
 469     @see wxSocketBase, wxSocketClient, wxSocketServer 
 471 class wxSocketEvent 
: public wxEvent
 
 477     wxSocketEvent(int id 
= 0); 
 480         Gets the client data of the socket which generated this event, as 
 481         set with wxSocketBase::SetClientData(). 
 483     void* GetClientData() const; 
 486         Returns the socket object to which this event refers to. 
 487         This makes it possible to use the same event handler for different sockets. 
 489     wxSocketBase
* GetSocket() const; 
 492         Returns the socket event type. 
 494     wxSocketNotify 
GetSocketEvent() const; 
 499     wxSocket error return values. 
 503     wxSOCKET_NOERROR
,       ///< No error happened. 
 504     wxSOCKET_INVOP
,         ///< Invalid operation. 
 505     wxSOCKET_IOERR
,         ///< Input/Output error. 
 506     wxSOCKET_INVADDR
,       ///< Invalid address passed to wxSocket. 
 507     wxSOCKET_INVSOCK
,       ///< Invalid socket (uninitialized). 
 508     wxSOCKET_NOHOST
,        ///< No corresponding host. 
 509     wxSOCKET_INVPORT
,       ///< Invalid port. 
 510     wxSOCKET_WOULDBLOCK
,    ///< The socket is non-blocking and the operation would block. 
 511     wxSOCKET_TIMEDOUT
,      ///< The timeout for this operation expired. 
 512     wxSOCKET_MEMERR         
///< Memory exhausted. 
 517     @anchor wxSocketEventFlags 
 519     wxSocket Event Flags. 
 521     A brief note on how to use these events: 
 523     The @b wxSOCKET_INPUT event will be issued whenever there is data available 
 524     for reading. This will be the case if the input queue was empty and new data 
 525     arrives, or if the application has read some data yet there is still more data 
 526     available. This means that the application does not need to read all available 
 527     data in response to a @b wxSOCKET_INPUT event, as more events will be produced 
 530     The @b wxSOCKET_OUTPUT event is issued when a socket is first connected with 
 531     Connect() or accepted with Accept(). After that, new events will be generated 
 532     only after an output operation fails with @b wxSOCKET_WOULDBLOCK and buffer space 
 533     becomes available again. This means that the application should assume that it can 
 534     write data to the socket until an @b wxSOCKET_WOULDBLOCK error occurs; after this, 
 535     whenever the socket becomes writable again the application will be notified with 
 536     another @b wxSOCKET_OUTPUT event. 
 538     The @b wxSOCKET_CONNECTION event is issued when a delayed connection request completes 
 539     successfully (client) or when a new connection arrives at the incoming queue (server). 
 541     The @b wxSOCKET_LOST event is issued when a close indication is received for the socket. 
 542     This means that the connection broke down or that it was closed by the peer. Also, this 
 543     event will be issued if a connection request fails. 
 545 enum wxSocketEventFlags
 
 547     wxSOCKET_INPUT
,         ///< There is data available for reading. 
 548     wxSOCKET_OUTPUT
,        ///< The socket is ready to be written to. 
 549     wxSOCKET_CONNECTION
,    ///< Incoming connection request (server), or 
 550                             ///< successful connection establishment (client). 
 551     wxSOCKET_LOST           
///< The connection has been closed. 
 556     @anchor wxSocketFlags 
 560     A brief overview on how to use these flags follows. 
 562     If no flag is specified (this is the same as @b wxSOCKET_NONE), 
 563     IO calls will return after some data has been read or written, even 
 564     when the transfer might not be complete. This is the same as issuing 
 565     exactly one blocking low-level call to @b recv() or @b send(). Note 
 566     that @e blocking here refers to when the function returns, not 
 567     to whether the GUI blocks during this time. 
 569     If @b wxSOCKET_NOWAIT is specified, IO calls will return immediately. 
 570     Read operations will retrieve only available data. Write operations will 
 571     write as much data as possible, depending on how much space is available 
 572     in the output buffer. This is the same as issuing exactly one nonblocking 
 573     low-level call to @b recv() or @b send(). Note that @e nonblocking here 
 574     refers to when the function returns, not to whether the GUI blocks during 
 577     If @b wxSOCKET_WAITALL is specified, IO calls won't return until ALL 
 578     the data has been read or written (or until an error occurs), blocking if 
 579     necessary, and issuing several low level calls if necessary. This is the 
 580     same as having a loop which makes as many blocking low-level calls to 
 581     @b recv() or @b send() as needed so as to transfer all the data. Note 
 582     that @e blocking here refers to when the function returns, not 
 583     to whether the GUI blocks during this time. 
 585     The @b wxSOCKET_BLOCK flag controls whether the GUI blocks during 
 586     IO operations. If this flag is specified, the socket will not yield 
 587     during IO calls, so the GUI will remain blocked until the operation 
 588     completes. If it is not used, then the application must take extra 
 589     care to avoid unwanted reentrance. 
 591     The @b wxSOCKET_REUSEADDR flag controls the use of the @b SO_REUSEADDR standard 
 592     @b setsockopt() flag. This flag allows the socket to bind to a port that is 
 593     already in use. This is mostly used on UNIX-based systems to allow rapid starting 
 594     and stopping of a server, otherwise you may have to wait several minutes for the 
 595     port to become available. 
 597     @b wxSOCKET_REUSEADDR can also be used with socket clients to (re)bind to a 
 598     particular local port for an outgoing connection. 
 599     This option can have surprising platform dependent behaviour, so check the 
 600     documentation for your platform's implementation of setsockopt(). 
 602     Note that on BSD-based systems(e.g. Mac OS X), use of 
 603     @b wxSOCKET_REUSEADDR implies @b SO_REUSEPORT in addition to 
 604     @b SO_REUSEADDR to be consistent with Windows. 
 606     The @b wxSOCKET_BROADCAST flag controls the use of the @b SO_BROADCAST standard 
 607     @b setsockopt() flag. This flag allows the socket to use the broadcast address, 
 608     and is generally used in conjunction with @b wxSOCKET_NOBIND and 
 609     wxIPaddress::BroadcastAddress(). 
 612     - @b wxSOCKET_NONE will try to read at least SOME data, no matter how much. 
 613     - @b wxSOCKET_NOWAIT will always return immediately, even if it cannot 
 614       read or write ANY data. 
 615     - @b wxSOCKET_WAITALL will only return when it has read or written ALL 
 617     - @b wxSOCKET_BLOCK has nothing to do with the previous flags and 
 618       it controls whether the GUI blocks. 
 619     - @b wxSOCKET_REUSEADDR controls special platform-specific behaviour for 
 620       reusing local addresses/ports. 
 624     wxSOCKET_NONE 
= 0,      ///< Normal functionality. 
 625     wxSOCKET_NOWAIT 
= 1,    ///< Read/write as much data as possible and return immediately. 
 626     wxSOCKET_WAITALL 
= 2,   ///< Wait for all required data to be read/written unless an error occurs. 
 627     wxSOCKET_BLOCK 
= 4,     ///< Block the GUI (do not yield) while reading/writing data. 
 628     wxSOCKET_REUSEADDR 
= 8, ///< Allows the use of an in-use port. 
 629     wxSOCKET_BROADCAST 
= 16, ///< Switches the socket to broadcast mode 
 630     wxSOCKET_NOBIND 
= 32    ///< Stops the socket from being bound to a specific 
 631                             ///< adapter (normally used in conjunction with 
 632                             ///< @b wxSOCKET_BROADCAST) 
 639     wxSocketBase is the base class for all socket-related objects, and it 
 640     defines all basic IO functionality. 
 643     When using wxSocket from multiple threads, even implicitly (e.g. by using 
 644     wxFTP or wxHTTP in another thread) you must initialize the sockets from the 
 645     main thread by calling Initialize() before creating the other ones. 
 647     @beginEventEmissionTable{wxSocketEvent} 
 648     @event{EVT_SOCKET(id, func)} 
 649         Process a @c wxEVT_SOCKET event. 
 650         See @ref wxSocketEventFlags and @ref wxSocketFlags for more info. 
 656     @see wxSocketEvent, wxSocketClient, wxSocketServer, @sample{sockets}, 
 657          @ref wxSocketFlags, ::wxSocketEventFlags, ::wxSocketError 
 659 class wxSocketBase 
: public wxObject
 
 664         @name Construction and Destruction 
 671         Don't use it directly; instead, use wxSocketClient to construct a socket client, 
 672         or wxSocketServer to construct a socket server. 
 679         Do not destroy a socket using the delete operator directly; 
 680         use Destroy() instead. Also, do not create socket objects in the stack. 
 682     virtual ~wxSocketBase(); 
 685         Destroys the socket safely. 
 687         Use this function instead of the delete operator, since otherwise socket events 
 688         could reach the application even after the socket has been destroyed. To prevent 
 689         this problem, this function appends the wxSocket to a list of object to be deleted 
 690         on idle time, after all events have been processed. For the same reason, you should 
 691         avoid creating socket objects in the stack. 
 693         Destroy() calls Close() automatically. 
 695         @return Always @true. 
 700         Perform the initialization needed in order to use the sockets. 
 702         This function is called from wxSocket constructor implicitly and so 
 703         normally doesn't need to be called explicitly. There is however one 
 704         important exception: as this function must be called from the main 
 705         (UI) thread, if you use wxSocket from multiple threads you must call 
 706         Initialize() from the main thread before creating wxSocket objects in 
 709         It is safe to call this function multiple times (only the first call 
 710         does anything) but you must call Shutdown() exactly once for every call 
 713         This function should only be called from the main thread. 
 716             @true if the sockets can be used, @false if the initialization 
 717             failed and sockets are not available at all. 
 719     static bool Initialize(); 
 722         Shut down the sockets. 
 724         This function undoes the call to Initialize() and must be called after 
 725         every successful call to Initialize(). 
 727         This function should only be called from the main thread, just as 
 730     static void Shutdown(); 
 741         Returns @true if an error occurred in the last IO operation. 
 743         Use this function to check for an error condition after one of the 
 744         following calls: Discard(), Peek(), Read(), ReadMsg(), Unread(), Write(), WriteMsg(). 
 749         Return the local address of the socket. 
 751         @return @true if no error happened, @false otherwise. 
 753     virtual bool GetLocal(wxSockAddress
& addr
) const; 
 756         Return the peer address field of the socket. 
 758         @return @true if no error happened, @false otherwise. 
 760     virtual bool GetPeer(wxSockAddress
& addr
) const; 
 763         Return the socket timeout in seconds. 
 765         The timeout can be set using SetTimeout() and is 10 minutes by default. 
 767     long GetTimeout() const; 
 770         Returns @true if the socket is connected. 
 772     bool IsConnected() const; 
 775         Check if the socket can be currently read or written. 
 777         This might mean that queued data is available for reading or, for streamed 
 778         sockets, that the connection has been closed, so that a read operation will 
 779         complete immediately without blocking (unless the @b wxSOCKET_WAITALL flag 
 780         is set, in which case the operation might still block). 
 785         Returns @true if the socket is not connected. 
 787     bool IsDisconnected() const; 
 790         Returns @true if the socket is initialized and ready and @false in other 
 794         For wxSocketClient, IsOk() won't return @true unless the client is connected to a server. 
 795         For wxSocketServer, IsOk() will return @true if the server could bind to the specified address 
 796         and is already listening for new connections. 
 797         IsOk() does not check for IO errors; use Error() instead for that purpose. 
 802         Returns the number of bytes read or written by the last IO call. 
 804         Use this function to get the number of bytes actually transferred 
 805         after using one of the following IO calls: Discard(), Peek(), Read(), 
 806         ReadMsg(), Unread(), Write(), WriteMsg(). 
 808     wxUint32 
LastCount() const; 
 811         Returns the last wxSocket error. See @ref wxSocketError . 
 814         This function merely returns the last error code, 
 815         but it should not be used to determine if an error has occurred (this 
 816         is because successful operations do not change the LastError value). 
 817         Use Error() first, in order to determine if the last IO call failed. 
 818         If this returns @true, use LastError() to discover the cause of the error. 
 820     wxSocketError 
LastError() const; 
 823         Restore the previous state of the socket, as saved with SaveState(). 
 825         Calls to SaveState() and RestoreState() can be nested. 
 832         Save the current state of the socket in a stack. 
 834         Socket state includes flags, as set with SetFlags(), event mask, as set 
 835         with SetNotify() and Notify(), user data, as set with SetClientData(). 
 836         Calls to SaveState and RestoreState can be nested. 
 848         See also: wxSocketServer::WaitForAccept(), wxSocketClient::WaitOnConnect() 
 853         Shut down the socket, disabling further transmission and reception of 
 854         data and disable events for the socket and frees the associated system 
 857         Upon socket destruction, Close() is automatically called, so in most cases 
 858         you won't need to do it yourself, unless you explicitly want to shut down 
 859         the socket, typically to notify the peer that you are closing the connection. 
 862         Although Close() immediately disables events for the socket, it is possible 
 863         that event messages may be waiting in the application's event queue. 
 864         The application must therefore be prepared to handle socket event messages even 
 865         after calling Close(). 
 867     virtual bool Close(); 
 870         Shuts down the writing end of the socket. 
 872         This function simply calls the standard shutdown() function on the 
 873         underlying socket, indicating that nothing will be written to this 
 876     void ShutdownOutput(); 
 879         Delete all bytes in the incoming queue. 
 881         This function always returns immediately and its operation is not 
 882         affected by IO flags. 
 884         Use LastCount() to verify the number of bytes actually discarded. 
 886         If you use Error(), it will always return @false. 
 888     wxSocketBase
& Discard(); 
 891         Returns current IO flags, as set with SetFlags() 
 893     wxSocketFlags 
GetFlags() const; 
 896         Use this function to interrupt any wait operation currently in progress. 
 898         Note that this is not intended as a regular way to interrupt a Wait call, 
 899         but only as an escape mechanism for exceptional situations where it is 
 900         absolutely necessary to use it, for example to abort an operation due to 
 901         some exception or abnormal problem. InterruptWait is automatically called 
 902         when you Close() a socket (and thus also upon 
 903         socket destruction), so you don't need to use it in these cases. 
 905         @see  Wait(), WaitForLost(), WaitForRead(), WaitForWrite(), 
 906               wxSocketServer::WaitForAccept(), wxSocketClient::WaitOnConnect() 
 908     void InterruptWait(); 
 911         Peek into the socket by copying the next bytes which would be read by 
 912         Read() into the provided buffer. 
 914         Peeking a buffer doesn't delete it from the socket input queue, i.e. 
 915         calling Read() will return the same data. 
 917         Use LastCount() to verify the number of bytes actually peeked. 
 919         Use Error() to determine if the operation succeeded. 
 922             Buffer where to put peeked data. 
 926         @return Returns a reference to the current object. 
 929             The exact behaviour of Peek() depends on the combination of flags being used. 
 930             For a detailed explanation, see SetFlags() 
 932         @see Error(), LastError(), LastCount(), SetFlags() 
 934     wxSocketBase
& Peek(void* buffer
, wxUint32 nbytes
); 
 937         Read up to the given number of bytes from the socket. 
 939         Use LastCount() to verify the number of bytes actually read. 
 940         Use Error() to determine if the operation succeeded. 
 943             Buffer where to put read data. 
 947         @return Returns a reference to the current object. 
 950             The exact behaviour of Read() depends on the combination of flags being used. 
 951             For a detailed explanation, see SetFlags() 
 953         @see Error(), LastError(), LastCount(), 
 956     wxSocketBase
& Read(void* buffer
, wxUint32 nbytes
); 
 959         Receive a message sent by WriteMsg(). 
 961         If the buffer passed to the function isn't big enough, the remaining 
 962         bytes will be discarded. This function always waits for the buffer to 
 963         be entirely filled, unless an error occurs. 
 965         Use LastCount() to verify the number of bytes actually read. 
 967         Use Error() to determine if the operation succeeded. 
 970             Buffer where to put read data. 
 974         @return Returns a reference to the current object. 
 977             ReadMsg() will behave as if the @b wxSOCKET_WAITALL flag was always set 
 978             and it will always ignore the @b wxSOCKET_NOWAIT flag. 
 979             The exact behaviour of ReadMsg() depends on the @b wxSOCKET_BLOCK flag. 
 980             For a detailed explanation, see SetFlags(). 
 982         @see Error(), LastError(), LastCount(), SetFlags(), WriteMsg() 
 984     wxSocketBase
& ReadMsg(void* buffer
, wxUint32 nbytes
); 
 987         Use SetFlags to customize IO operation for this socket. 
 989         The @a flags parameter may be a combination of flags ORed together. 
 990         Notice that not all combinations of flags affecting the IO calls 
 991         (Read() and Write()) make sense, e.g. @b wxSOCKET_NOWAIT can't be 
 992         combined with @b wxSOCKET_WAITALL nor with @b wxSOCKET_BLOCK. 
 994         The following flags can be used: 
 997             Default mode: the socket will read some data in the IO calls and 
 998             will process events to avoid blocking UI while waiting for the data 
1000         @flag{wxSOCKET_NOWAIT} 
1001             Don't wait for the socket to become ready in IO calls, read as much 
1002             data as is available -- potentially 0 bytes -- and return 
1004         @flag{wxSOCKET_WAITALL} 
1005             Don't return before the entire amount of data specified in IO calls 
1006             is read or written unless an error occurs. If this flag is not 
1007             specified, the IO calls return as soon as any amount of data, even 
1008             less than the total number of bytes, is processed. 
1009         @flag{wxSOCKET_BLOCK} 
1010             Don't process the UI events while waiting for the socket to become 
1011             ready. This means that UI will be unresponsive during socket IO. 
1012         @flag{wxSOCKET_REUSEADDR} 
1013             Allows the use of an in-use port (wxServerSocket only). 
1014         @flag{wxSOCKET_BROADCAST} 
1015             Switches the socket to broadcast mode. 
1016         @flag{wxSOCKET_NOBIND} 
1017             Stops the socket from being bound to a specific adapter (normally 
1018             used in conjunction with @b wxSOCKET_BROADCAST). 
1021         For more information on socket events see @ref wxSocketFlags . 
1023     void SetFlags(wxSocketFlags flags
); 
1026         Set the local address and port to use. 
1028         This function must always be called for the server sockets but may also 
1029         be called for client sockets, if it is, @b bind() is called before @b 
1032     virtual bool SetLocal(const wxIPV4address
& local
); 
1035         Set the default socket timeout in seconds. 
1037         This timeout applies to all IO calls, and also to the Wait() family of 
1038         functions if you don't specify a wait interval. Initially, the default 
1039         timeout is 10 minutes. 
1041     void SetTimeout(long seconds
); 
1044         Put the specified data into the input queue. 
1046         The data in the buffer will be returned by the next call to Read(). 
1048         This function is not affected by wxSocket flags. 
1050         If you use LastCount(), it will always return @a nbytes. 
1052         If you use Error(), it will always return @false. 
1055             Buffer to be unread. 
1059         @return Returns a reference to the current object. 
1061         @see Error(), LastCount(), LastError() 
1063     wxSocketBase
& Unread(const void* buffer
, wxUint32 nbytes
); 
1066         Wait for any socket event. 
1068         Possible socket events are: 
1069         @li The socket becomes readable. 
1070         @li The socket becomes writable. 
1071         @li An ongoing connection request has completed (wxSocketClient only) 
1072         @li An incoming connection request has arrived (wxSocketServer only) 
1073         @li The connection has been closed. 
1075         Note that it is recommended to use the individual @b WaitForXXX() 
1076         functions to wait for the required condition, instead of this one. 
1079             Number of seconds to wait. 
1080             If -1, it will wait for the default timeout, 
1081             as set with SetTimeout(). 
1083             Number of milliseconds to wait. 
1086            @true when any of the above conditions is satisfied or @false if the 
1087            timeout was reached. 
1089         @see InterruptWait(), wxSocketServer::WaitForAccept(), 
1090              WaitForLost(), WaitForRead(), 
1091              WaitForWrite(), wxSocketClient::WaitOnConnect() 
1093     bool Wait(long seconds 
= -1, long millisecond 
= 0); 
1096         Wait until the connection is lost. 
1098         This may happen if the peer gracefully closes the connection or if the 
1102             Number of seconds to wait. 
1103             If -1, it will wait for the default timeout, 
1104             as set with SetTimeout(). 
1106             Number of milliseconds to wait. 
1108         @return Returns @true if the connection was lost, @false if the timeout 
1111         @see InterruptWait(), Wait() 
1113     bool WaitForLost(long seconds 
= -1, long millisecond 
= 0); 
1116         Wait until the socket is readable. 
1118         This might mean that queued data is available for reading or, for streamed 
1119         sockets, that the connection has been closed, so that a read operation will 
1120         complete immediately without blocking (unless the @b wxSOCKET_WAITALL flag 
1121         is set, in which case the operation might still block). 
1123         Notice that this function should not be called if there is already data 
1124         available for reading on the socket. 
1127             Number of seconds to wait. 
1128             If -1, it will wait for the default timeout, 
1129             as set with SetTimeout(). 
1131             Number of milliseconds to wait. 
1133         @return Returns @true if the socket becomes readable, @false on timeout. 
1135         @see InterruptWait(), Wait() 
1137     bool WaitForRead(long seconds 
= -1, long millisecond 
= 0); 
1140         Wait until the socket becomes writable. 
1142         This might mean that the socket is ready to send new data, or for streamed 
1143         sockets, that the connection has been closed, so that a write operation is 
1144         guaranteed to complete immediately (unless the @b wxSOCKET_WAITALL flag is set, 
1145         in which case the operation might still block). 
1147         Notice that this function should not be called if the socket is already 
1151             Number of seconds to wait. 
1152             If -1, it will wait for the default timeout, 
1153             as set with SetTimeout(). 
1155             Number of milliseconds to wait. 
1157         @return Returns @true if the socket becomes writable, @false on timeout. 
1159         @see InterruptWait(), Wait() 
1161     bool WaitForWrite(long seconds 
= -1, long millisecond 
= 0); 
1164         Write up to the given number of bytes to the socket. 
1166         Use LastCount() to verify the number of bytes actually written. 
1168         Use Error() to determine if the operation succeeded. 
1171             Buffer with the data to be sent. 
1175         @return Returns a reference to the current object. 
1179         The exact behaviour of Write() depends on the combination of flags being used. 
1180         For a detailed explanation, see SetFlags(). 
1182         @see Error(), LastError(), LastCount(), SetFlags() 
1184     wxSocketBase
& Write(const void* buffer
, wxUint32 nbytes
); 
1187         Sends a buffer which can be read using ReadMsg(). 
1189         WriteMsg() sends a short header before the data so that ReadMsg() 
1190         knows how much data should be actually read. 
1192         This function always waits for the entire buffer to be sent, unless an 
1195         Use LastCount() to verify the number of bytes actually written. 
1197         Use Error() to determine if the operation succeeded. 
1200             Buffer with the data to be sent. 
1202             Number of bytes to send. 
1204         @return Returns a reference to the current object. 
1208         WriteMsg() will behave as if the @b wxSOCKET_WAITALL flag was always set and 
1209         it will always ignore the @b wxSOCKET_NOWAIT flag. The exact behaviour of 
1210         WriteMsg() depends on the @b wxSOCKET_BLOCK flag. For a detailed explanation, 
1213         @see  Error(), LastError(), LastCount(), SetFlags(), ReadMsg() 
1216     wxSocketBase
& WriteMsg(const void* buffer
, wxUint32 nbytes
); 
1222         @name Handling Socket Events 
1227         Returns a pointer of the client data for this socket, as set with 
1230     void* GetClientData() const; 
1233         According to the @a notify value, this function enables 
1234         or disables socket events. If @a notify is @true, the events 
1235         configured with SetNotify() will 
1236         be sent to the application. If @a notify is @false; no events 
1239     void Notify(bool notify
); 
1242         Sets user-supplied client data for this socket. All socket events will 
1243         contain a pointer to this data, which can be retrieved with 
1244         the wxSocketEvent::GetClientData() function. 
1246     void SetClientData(void* data
); 
1249         Sets an event handler to be called when a socket event occurs. The 
1250         handler will be called for those events for which notification is 
1251         enabled with SetNotify() and 
1255             Specifies the event handler you want to use. 
1257             The id of socket event. 
1259         @see SetNotify(), Notify(), wxSocketEvent, wxEvtHandler 
1261     void SetEventHandler(wxEvtHandler
& handler
, int id 
= -1); 
1264         Specifies which socket events are to be sent to the event handler. 
1265         The @a flags parameter may be combination of flags ORed together. The 
1266         following flags can be used: 
1269         @flag{wxSOCKET_INPUT_FLAG} to receive @b wxSOCKET_INPUT. 
1270         @flag{wxSOCKET_OUTPUT_FLAG} to receive @b wxSOCKET_OUTPUT. 
1271         @flag{wxSOCKET_CONNECTION_FLAG} to receive @b wxSOCKET_CONNECTION. 
1272         @flag{wxSOCKET_LOST_FLAG} to receive @b wxSOCKET_LOST. 
1278         sock.SetNotify(wxSOCKET_INPUT_FLAG | wxSOCKET_LOST_FLAG); 
1282         In this example, the user will be notified about incoming socket data and 
1283         whenever the connection is closed. 
1285         For more information on socket events see @ref wxSocketEventFlags . 
1287     void SetNotify(wxSocketEventFlags flags
); 
1295     @class wxDatagramSocket 
1302 class wxDatagramSocket 
: public wxSocketBase
 
1311             Socket flags (See wxSocketBase::SetFlags()). 
1313     wxDatagramSocket(const wxSockAddress
& addr
, 
1314                      wxSocketFlags flags 
= wxSOCKET_NONE
); 
1317         Destructor. Please see wxSocketBase::Destroy(). 
1319     virtual ~wxDatagramSocket(); 
1322         Write a buffer of @a nbytes bytes to the socket. 
1324         Use wxSocketBase::LastCount() to verify the number of bytes actually wrote. 
1325         Use wxSocketBase::Error() to determine if the operation succeeded. 
1328             The address of the destination peer for this data. 
1330             Buffer where read data is. 
1334         @return Returns a reference to the current object. 
1336         @see wxSocketBase::LastError(), wxSocketBase::SetFlags() 
1338     wxDatagramSocket
& SendTo(const wxSockAddress
& address
, 
1339                              const void* buffer
, wxUint32 nbytes
);