1 /* ------------------------------------------------------------------------- 
   2  * Project:     GSocket (Generic Socket) for WX 
   4  * Copyright:   (c) Guilhem Lavaux 
   5  * Licence:     wxWindows Licence 
   6  * Authors:     David Elliott (C++ conversion, maintainer) 
   8  *              Guillermo Rodriguez Garcia <guille@iies.es> 
   9  * Purpose:     GSocket main Unix and OS/2 file 
  10  * Licence:     The wxWindows licence 
  12  * ------------------------------------------------------------------------- 
  16  * PLEASE don't put C++ comments here - this is a C source file. 
  19 #if defined(__WATCOMC__) 
  20 #include "wx/wxprec.h" 
  25 #ifndef __GSOCKET_STANDALONE__ 
  29 #if defined(__VISAGECPP__) 
  30 #define BSD_SELECT /* use Berkley Sockets select */ 
  33 #if wxUSE_SOCKETS || defined(__GSOCKET_STANDALONE__) 
  36 #include <sys/types.h> 
  41 #include <netinet/in.h> 
  44 #include <sys/ioctl.h> 
  50     u_char  sun_len
;        /* sockaddr len including null */ 
  51     u_char  sun_family
;     /* AF_UNIX */ 
  52     char    sun_path
[108];  /* path name (gag) */ 
  55 #include <sys/socket.h> 
  61 #include <netinet/in.h> 
  62 #include <arpa/inet.h> 
  69 #include <machine/endian.h> 
  75 #define EBADF   SOCEBADF 
  81 #include <sys/socket.h> 
  82 #include <sys/ioctl.h> 
  83 #include <sys/select.h> 
  85 #define close(a) soclose(a) 
  86 #define select(a,b,c,d,e) bsdselect(a,b,c,d,e) 
  87 int _System 
bsdselect(int, 
  92 int _System 
soclose(int); 
  96 #include <sys/select.h> 
 104 #  include <sys/filio.h> 
 107 #  include <bstring.h> 
 110 #  include <strings.h> 
 117 #  define WX_SOCKLEN_T unsigned int 
 121 #      define WX_SOCKLEN_T socklen_t 
 123 #  elif defined(__WXMAC__) 
 124 #    define WX_SOCKLEN_T socklen_t 
 126 #    define WX_SOCKLEN_T int 
 130 #endif /* SOCKLEN_T */ 
 133 #define SOCKOPTLEN_T WX_SOCKLEN_T 
 137  * MSW defines this, Unices don't. 
 139 #ifndef INVALID_SOCKET 
 140 #define INVALID_SOCKET -1 
 143 /* UnixWare reportedly needs this for FIONBIO definition */ 
 145 #include <sys/filio.h> 
 149  * INADDR_BROADCAST is identical to INADDR_NONE which is not defined 
 150  * on all systems. INADDR_BROADCAST should be fine to indicate an error. 
 153 #define INADDR_NONE INADDR_BROADCAST 
 156 #if defined(__VISAGECPP__) || defined(__WATCOMC__) 
 158     #define MASK_SIGNAL() { 
 159     #define UNMASK_SIGNAL() } 
 162     extern "C" { typedef void (*wxSigHandler
)(int); } 
 164     #define MASK_SIGNAL()                       \ 
 166         wxSigHandler old_handler = signal(SIGPIPE, SIG_IGN); 
 168     #define UNMASK_SIGNAL()                     \ 
 169         signal(SIGPIPE, old_handler);           \ 
 174 /* If a SIGPIPE is issued by a socket call on a remotely closed socket, 
 175    the program will "crash" unless it explicitly handles the SIGPIPE. 
 176    By using MSG_NOSIGNAL, the SIGPIPE is suppressed. Later, we will 
 177    use SO_NOSIGPIPE (if available), the BSD equivalent. */ 
 179 #  define GSOCKET_MSG_NOSIGNAL MSG_NOSIGNAL 
 180 #else /* MSG_NOSIGNAL not available (FreeBSD including OS X) */ 
 181 #  define GSOCKET_MSG_NOSIGNAL 0 
 182 #endif /* MSG_NOSIGNAL */ 
 184 #ifndef __GSOCKET_STANDALONE__ 
 185 #  include "wx/unix/gsockunx.h" 
 186 #  include "wx/gsocket.h" 
 188 #  include "gsockunx.h" 
 189 #  include "gsocket.h" 
 193 #endif /* __GSOCKET_STANDALONE__ */ 
 195 /* debugging helpers */ 
 196 #ifdef __GSOCKET_DEBUG__ 
 197 #  define GSocket_Debug(args) printf args 
 199 #  define GSocket_Debug(args) 
 200 #endif /* __GSOCKET_DEBUG__ */ 
 202 /* Table of GUI-related functions. We must call them indirectly because 
 203  * of wxBase and GUI separation: */ 
 205 static GSocketGUIFunctionsTable 
*gs_gui_functions
; 
 207 class GSocketGUIFunctionsTableNull
: public GSocketGUIFunctionsTable
 
 210     virtual bool OnInit(); 
 211     virtual void OnExit(); 
 212     virtual bool CanUseEventLoop(); 
 213     virtual bool Init_Socket(GSocket 
*socket
); 
 214     virtual void Destroy_Socket(GSocket 
*socket
); 
 215     virtual void Install_Callback(GSocket 
*socket
, GSocketEvent event
); 
 216     virtual void Uninstall_Callback(GSocket 
*socket
, GSocketEvent event
); 
 217     virtual void Enable_Events(GSocket 
*socket
); 
 218     virtual void Disable_Events(GSocket 
*socket
); 
 221 bool GSocketGUIFunctionsTableNull::OnInit() 
 223 void GSocketGUIFunctionsTableNull::OnExit() 
 225 bool GSocketGUIFunctionsTableNull::CanUseEventLoop() 
 227 bool GSocketGUIFunctionsTableNull::Init_Socket(GSocket 
*WXUNUSED(socket
)) 
 229 void GSocketGUIFunctionsTableNull::Destroy_Socket(GSocket 
*WXUNUSED(socket
)) 
 231 void GSocketGUIFunctionsTableNull::Install_Callback(GSocket 
*WXUNUSED(socket
), GSocketEvent 
WXUNUSED(event
)) 
 233 void GSocketGUIFunctionsTableNull::Uninstall_Callback(GSocket 
*WXUNUSED(socket
), GSocketEvent 
WXUNUSED(event
)) 
 235 void GSocketGUIFunctionsTableNull::Enable_Events(GSocket 
*WXUNUSED(socket
)) 
 237 void GSocketGUIFunctionsTableNull::Disable_Events(GSocket 
*WXUNUSED(socket
)) 
 239 /* Global initialisers */ 
 241 void GSocket_SetGUIFunctions(GSocketGUIFunctionsTable 
*guifunc
) 
 243   gs_gui_functions 
= guifunc
; 
 246 int GSocket_Init(void) 
 248   if (!gs_gui_functions
) 
 250     static GSocketGUIFunctionsTableNull table
; 
 251     gs_gui_functions 
= &table
; 
 253   if ( !gs_gui_functions
->OnInit() ) 
 258 void GSocket_Cleanup(void) 
 260   if (gs_gui_functions
) 
 262       gs_gui_functions
->OnExit(); 
 266 /* Constructors / Destructors for GSocket */ 
 272   m_fd                  
= INVALID_SOCKET
; 
 273   for (i
=0;i
<GSOCK_MAX_EVENT
;i
++) 
 280   m_error               
= GSOCK_NOERROR
; 
 283   m_gui_dependent       
= NULL
; 
 284   m_non_blocking        
= false; 
 286   m_timeout             
= 10*60*1000; 
 287                                 /* 10 minutes * 60 sec * 1000 millisec */ 
 288   m_establishing        
= false; 
 290   assert(gs_gui_functions
); 
 291   /* Per-socket GUI-specific initialization */ 
 292   m_ok 
= gs_gui_functions
->Init_Socket(this); 
 295 void GSocket::Close() 
 297     gs_gui_functions
->Disable_Events(this); 
 298     /* gsockosx.c calls CFSocketInvalidate which closes the socket for us */ 
 299 #if !(defined(__DARWIN__) && (defined(__WXMAC__) || defined(__WXCOCOA__))) 
 302     m_fd 
= INVALID_SOCKET
; 
 309   /* Check that the socket is really shutdowned */ 
 310   if (m_fd 
!= INVALID_SOCKET
) 
 313   /* Per-socket GUI-specific cleanup */ 
 314   gs_gui_functions
->Destroy_Socket(this); 
 316   /* Destroy private addresses */ 
 318     GAddress_destroy(m_local
); 
 321     GAddress_destroy(m_peer
); 
 325  *  Disallow further read/write operations on this socket, close 
 326  *  the fd and disable all callbacks. 
 328 void GSocket::Shutdown() 
 334   /* If socket has been created, shutdown it */ 
 335   if (m_fd 
!= INVALID_SOCKET
) 
 341   /* Disable GUI callbacks */ 
 342   for (evt 
= 0; evt 
< GSOCK_MAX_EVENT
; evt
++) 
 343     m_cbacks
[evt
] = NULL
; 
 345   m_detected 
= GSOCK_LOST_FLAG
; 
 348 /* Address handling */ 
 354  *  Set or get the local or peer address for this socket. The 'set' 
 355  *  functions return GSOCK_NOERROR on success, an error code otherwise. 
 356  *  The 'get' functions return a pointer to a GAddress object on success, 
 357  *  or NULL otherwise, in which case they set the error code of the 
 358  *  corresponding GSocket. 
 361  *    GSOCK_INVSOCK - the socket is not valid. 
 362  *    GSOCK_INVADDR - the address is not valid. 
 364 GSocketError 
GSocket::SetLocal(GAddress 
*address
) 
 368   /* the socket must be initialized, or it must be a server */ 
 369   if ((m_fd 
!= INVALID_SOCKET 
&& !m_server
)) 
 371     m_error 
= GSOCK_INVSOCK
; 
 372     return GSOCK_INVSOCK
; 
 376   if (address 
== NULL 
|| address
->m_family 
== GSOCK_NOFAMILY
) 
 378     m_error 
= GSOCK_INVADDR
; 
 379     return GSOCK_INVADDR
; 
 383     GAddress_destroy(m_local
); 
 385   m_local 
= GAddress_copy(address
); 
 387   return GSOCK_NOERROR
; 
 390 GSocketError 
GSocket::SetPeer(GAddress 
*address
) 
 395   if (address 
== NULL 
|| address
->m_family 
== GSOCK_NOFAMILY
) 
 397     m_error 
= GSOCK_INVADDR
; 
 398     return GSOCK_INVADDR
; 
 402     GAddress_destroy(m_peer
); 
 404   m_peer 
= GAddress_copy(address
); 
 406   return GSOCK_NOERROR
; 
 409 GAddress 
*GSocket::GetLocal() 
 412   struct sockaddr addr
; 
 413   WX_SOCKLEN_T size 
= sizeof(addr
); 
 418   /* try to get it from the m_local var first */ 
 420     return GAddress_copy(m_local
); 
 422   /* else, if the socket is initialized, try getsockname */ 
 423   if (m_fd 
== INVALID_SOCKET
) 
 425     m_error 
= GSOCK_INVSOCK
; 
 429   if (getsockname(m_fd
, &addr
, (WX_SOCKLEN_T 
*) &size
) < 0) 
 431     m_error 
= GSOCK_IOERR
; 
 435   /* got a valid address from getsockname, create a GAddress object */ 
 436   address 
= GAddress_new(); 
 439     m_error 
= GSOCK_MEMERR
; 
 443   err 
= _GAddress_translate_from(address
, &addr
, size
); 
 444   if (err 
!= GSOCK_NOERROR
) 
 446     GAddress_destroy(address
); 
 454 GAddress 
*GSocket::GetPeer() 
 458   /* try to get it from the m_peer var */ 
 460     return GAddress_copy(m_peer
); 
 465 /* Server specific parts */ 
 467 /* GSocket_SetServer: 
 468  *  Sets up this socket as a server. The local address must have been 
 469  *  set with GSocket_SetLocal() before GSocket_SetServer() is called. 
 470  *  Returns GSOCK_NOERROR on success, one of the following otherwise: 
 473  *    GSOCK_INVSOCK - the socket is in use. 
 474  *    GSOCK_INVADDR - the local address has not been set. 
 475  *    GSOCK_IOERR   - low-level error. 
 477 GSocketError 
GSocket::SetServer() 
 483   /* must not be in use */ 
 484   if (m_fd 
!= INVALID_SOCKET
) 
 486     m_error 
= GSOCK_INVSOCK
; 
 487     return GSOCK_INVSOCK
; 
 490   /* the local addr must have been set */ 
 493     m_error 
= GSOCK_INVADDR
; 
 494     return GSOCK_INVADDR
; 
 497   /* Initialize all fields */ 
 501   /* Create the socket */ 
 502   m_fd 
= socket(m_local
->m_realfamily
, SOCK_STREAM
, 0); 
 504   if (m_fd 
== INVALID_SOCKET
) 
 506     m_error 
= GSOCK_IOERR
; 
 510   /* FreeBSD variants can't use MSG_NOSIGNAL, and instead use a socket option */ 
 512   setsockopt(m_fd
, SOL_SOCKET
, SO_NOSIGPIPE
, (const char*)&arg
, sizeof(u_long
)); 
 515   ioctl(m_fd
, FIONBIO
, &arg
); 
 516   gs_gui_functions
->Enable_Events(this); 
 518   /* allow a socket to re-bind if the socket is in the TIME_WAIT 
 519      state after being previously closed. 
 522     setsockopt(m_fd
, SOL_SOCKET
, SO_REUSEADDR
, (const char*)&arg
, sizeof(u_long
)); 
 524   /* Bind to the local address, 
 525    * retrieve the actual address bound, 
 526    * and listen up to 5 connections. 
 528   if ((bind(m_fd
, m_local
->m_addr
, m_local
->m_len
) != 0) || 
 531                    (WX_SOCKLEN_T 
*) &m_local
->m_len
) != 0) || 
 532       (listen(m_fd
, 5) != 0)) 
 535     m_error 
= GSOCK_IOERR
; 
 539   return GSOCK_NOERROR
; 
 542 /* GSocket_WaitConnection: 
 543  *  Waits for an incoming client connection. Returns a pointer to 
 544  *  a GSocket object, or NULL if there was an error, in which case 
 545  *  the last error field will be updated for the calling GSocket. 
 547  *  Error codes (set in the calling GSocket) 
 548  *    GSOCK_INVSOCK    - the socket is not valid or not a server. 
 549  *    GSOCK_TIMEDOUT   - timeout, no incoming connections. 
 550  *    GSOCK_WOULDBLOCK - the call would block and the socket is nonblocking. 
 551  *    GSOCK_MEMERR     - couldn't allocate memory. 
 552  *    GSOCK_IOERR      - low-level error. 
 554 GSocket 
*GSocket::WaitConnection() 
 556   struct sockaddr from
; 
 557   WX_SOCKLEN_T fromlen 
= sizeof(from
); 
 564   /* If the socket has already been created, we exit immediately */ 
 565   if (m_fd 
== INVALID_SOCKET 
|| !m_server
) 
 567     m_error 
= GSOCK_INVSOCK
; 
 571   /* Create a GSocket object for the new connection */ 
 572   connection 
= GSocket_new(); 
 576     m_error 
= GSOCK_MEMERR
; 
 580   /* Wait for a connection (with timeout) */ 
 581   if (Input_Timeout() == GSOCK_TIMEDOUT
) 
 584     /* m_error set by _GSocket_Input_Timeout */ 
 588   connection
->m_fd 
= accept(m_fd
, &from
, (WX_SOCKLEN_T 
*) &fromlen
); 
 590   /* Reenable CONNECTION events */ 
 591   Enable(GSOCK_CONNECTION
); 
 593   if (connection
->m_fd 
== INVALID_SOCKET
) 
 595     if (errno 
== EWOULDBLOCK
) 
 596       m_error 
= GSOCK_WOULDBLOCK
; 
 598       m_error 
= GSOCK_IOERR
; 
 604   /* Initialize all fields */ 
 605   connection
->m_server   
= false; 
 606   connection
->m_stream   
= true; 
 608   /* Setup the peer address field */ 
 609   connection
->m_peer 
= GAddress_new(); 
 610   if (!connection
->m_peer
) 
 613     m_error 
= GSOCK_MEMERR
; 
 616   err 
= _GAddress_translate_from(connection
->m_peer
, &from
, fromlen
); 
 617   if (err 
!= GSOCK_NOERROR
) 
 623 #if defined(__EMX__) || defined(__VISAGECPP__) 
 624   ioctl(connection
->m_fd
, FIONBIO
, (char*)&arg
, sizeof(arg
)); 
 626   ioctl(connection
->m_fd
, FIONBIO
, &arg
); 
 628   gs_gui_functions
->Enable_Events(connection
); 
 633 bool GSocket::SetReusable() 
 635     /* socket must not be null, and must not be in use/already bound */ 
 636     if (this && m_fd 
== INVALID_SOCKET
) { 
 643 /* Client specific parts */ 
 646  *  For stream (connection oriented) sockets, GSocket_Connect() tries 
 647  *  to establish a client connection to a server using the peer address 
 648  *  as established with GSocket_SetPeer(). Returns GSOCK_NOERROR if the 
 649  *  connection has been successfully established, or one of the error 
 650  *  codes listed below. Note that for nonblocking sockets, a return 
 651  *  value of GSOCK_WOULDBLOCK doesn't mean a failure. The connection 
 652  *  request can be completed later; you should use GSocket_Select() 
 653  *  to poll for GSOCK_CONNECTION | GSOCK_LOST, or wait for the 
 654  *  corresponding asynchronous events. 
 656  *  For datagram (non connection oriented) sockets, GSocket_Connect() 
 657  *  just sets the peer address established with GSocket_SetPeer() as 
 658  *  default destination. 
 661  *    GSOCK_INVSOCK    - the socket is in use or not valid. 
 662  *    GSOCK_INVADDR    - the peer address has not been established. 
 663  *    GSOCK_TIMEDOUT   - timeout, the connection failed. 
 664  *    GSOCK_WOULDBLOCK - connection in progress (nonblocking sockets only) 
 665  *    GSOCK_MEMERR     - couldn't allocate memory. 
 666  *    GSOCK_IOERR      - low-level error. 
 668 GSocketError 
GSocket::Connect(GSocketStream stream
) 
 675   /* Enable CONNECTION events (needed for nonblocking connections) */ 
 676   Enable(GSOCK_CONNECTION
); 
 678   if (m_fd 
!= INVALID_SOCKET
) 
 680     m_error 
= GSOCK_INVSOCK
; 
 681     return GSOCK_INVSOCK
; 
 686     m_error 
= GSOCK_INVADDR
; 
 687     return GSOCK_INVADDR
; 
 690   /* Streamed or dgram socket? */ 
 691   m_stream   
= (stream 
== GSOCK_STREAMED
); 
 693   m_establishing 
= false; 
 695   /* Create the socket */ 
 696   m_fd 
= socket(m_peer
->m_realfamily
, 
 697                      m_stream
? SOCK_STREAM 
: SOCK_DGRAM
, 0); 
 699   if (m_fd 
== INVALID_SOCKET
) 
 701     m_error 
= GSOCK_IOERR
; 
 705   /* FreeBSD variants can't use MSG_NOSIGNAL, and instead use a socket option */ 
 707   setsockopt(m_fd
, SOL_SOCKET
, SO_NOSIGPIPE
, (const char*)&arg
, sizeof(u_long
)); 
 710 #if defined(__EMX__) || defined(__VISAGECPP__) 
 711   ioctl(m_fd
, FIONBIO
, (char*)&arg
, sizeof(arg
)); 
 713   ioctl(m_fd
, FIONBIO
, &arg
); 
 716   /* Connect it to the peer address, with a timeout (see below) */ 
 717   ret 
= connect(m_fd
, m_peer
->m_addr
, m_peer
->m_len
); 
 719   /* We only call Enable_Events if we know we aren't shutting down the socket. 
 720    * NB: Enable_Events needs to be called whether the socket is blocking or 
 721    * non-blocking, it just shouldn't be called prior to knowing there is a 
 722    * connection _if_ blocking sockets are being used. 
 723    * If connect above returns 0, we are already connected and need to make the 
 724    * call to Enable_Events now.   
 726   if (m_non_blocking || ret == 0) 
 728     gs_gui_functions->Enable_Events(this); 
 735     /* If connect failed with EINPROGRESS and the GSocket object 
 736      * is in blocking mode, we select() for the specified timeout 
 737      * checking for writability to see if the connection request 
 740     if ((err 
== EINPROGRESS
) && (!m_non_blocking
)) 
 742       if (Output_Timeout() == GSOCK_TIMEDOUT
) 
 745         /* m_error is set in _GSocket_Output_Timeout */ 
 746         return GSOCK_TIMEDOUT
; 
 751         SOCKOPTLEN_T len 
= sizeof(error
); 
 753         getsockopt(m_fd
, SOL_SOCKET
, SO_ERROR
, (char*) &error
, &len
); 
 755         gs_gui_functions
->Enable_Events(this); 
 758           return GSOCK_NOERROR
; 
 762     /* If connect failed with EINPROGRESS and the GSocket object 
 763      * is set to nonblocking, we set m_error to GSOCK_WOULDBLOCK 
 764      * (and return GSOCK_WOULDBLOCK) but we don't close the socket; 
 765      * this way if the connection completes, a GSOCK_CONNECTION 
 766      * event will be generated, if enabled. 
 768     if ((err 
== EINPROGRESS
) && (m_non_blocking
)) 
 770       m_establishing 
= true; 
 771       m_error 
= GSOCK_WOULDBLOCK
; 
 772       return GSOCK_WOULDBLOCK
; 
 775     /* If connect failed with an error other than EINPROGRESS, 
 776      * then the call to GSocket_Connect has failed. 
 779     m_error 
= GSOCK_IOERR
; 
 783   return GSOCK_NOERROR
; 
 786 /* Datagram sockets */ 
 788 /* GSocket_SetNonOriented: 
 789  *  Sets up this socket as a non-connection oriented (datagram) socket. 
 790  *  Before using this function, the local address must have been set 
 791  *  with GSocket_SetLocal(), or the call will fail. Returns GSOCK_NOERROR 
 792  *  on success, or one of the following otherwise. 
 795  *    GSOCK_INVSOCK - the socket is in use. 
 796  *    GSOCK_INVADDR - the local address has not been set. 
 797  *    GSOCK_IOERR   - low-level error. 
 799 GSocketError 
GSocket::SetNonOriented() 
 805   if (m_fd 
!= INVALID_SOCKET
) 
 807     m_error 
= GSOCK_INVSOCK
; 
 808     return GSOCK_INVSOCK
; 
 813     m_error 
= GSOCK_INVADDR
; 
 814     return GSOCK_INVADDR
; 
 817   /* Initialize all fields */ 
 821   /* Create the socket */ 
 822   m_fd 
= socket(m_local
->m_realfamily
, SOCK_DGRAM
, 0); 
 824   if (m_fd 
== INVALID_SOCKET
) 
 826     m_error 
= GSOCK_IOERR
; 
 829 #if defined(__EMX__) || defined(__VISAGECPP__) 
 830   ioctl(m_fd
, FIONBIO
, (char*)&arg
, sizeof(arg
)); 
 832   ioctl(m_fd
, FIONBIO
, &arg
); 
 834   gs_gui_functions
->Enable_Events(this); 
 836   /* Bind to the local address, 
 837    * and retrieve the actual address bound. 
 839   if ((bind(m_fd
, m_local
->m_addr
, m_local
->m_len
) != 0) || 
 842                    (WX_SOCKLEN_T 
*) &m_local
->m_len
) != 0)) 
 845     m_error 
= GSOCK_IOERR
; 
 849   return GSOCK_NOERROR
; 
 854 /* Like recv(), send(), ... */ 
 855 int GSocket::Read(char *buffer
, int size
) 
 861   if (m_fd 
== INVALID_SOCKET 
|| m_server
) 
 863     m_error 
= GSOCK_INVSOCK
; 
 867   /* Disable events during query of socket status */ 
 868   Disable(GSOCK_INPUT
); 
 870   /* If the socket is blocking, wait for data (with a timeout) */ 
 871   if (Input_Timeout() == GSOCK_TIMEDOUT
) 
 872     /* We no longer return here immediately, otherwise socket events would not be re-enabled! */ 
 877       ret 
= Recv_Stream(buffer
, size
); 
 879       ret 
= Recv_Dgram(buffer
, size
); 
 884     if ((errno 
== EWOULDBLOCK
) || (errno 
== EAGAIN
)) 
 885       m_error 
= GSOCK_WOULDBLOCK
; 
 887       m_error 
= GSOCK_IOERR
; 
 890   /* Enable events again now that we are done processing */ 
 896 int GSocket::Write(const char *buffer
, int size
) 
 902   GSocket_Debug(( "GSocket_Write #1, size %d\n", size 
)); 
 904   if (m_fd 
== INVALID_SOCKET 
|| m_server
) 
 906     m_error 
= GSOCK_INVSOCK
; 
 910   GSocket_Debug(( "GSocket_Write #2, size %d\n", size 
)); 
 912   /* If the socket is blocking, wait for writability (with a timeout) */ 
 913   if (Output_Timeout() == GSOCK_TIMEDOUT
) 
 916   GSocket_Debug(( "GSocket_Write #3, size %d\n", size 
)); 
 920     ret 
= Send_Stream(buffer
, size
); 
 922     ret 
= Send_Dgram(buffer
, size
); 
 924   GSocket_Debug(( "GSocket_Write #4, size %d\n", size 
)); 
 928     if ((errno 
== EWOULDBLOCK
) || (errno 
== EAGAIN
)) 
 930       m_error 
= GSOCK_WOULDBLOCK
; 
 931       GSocket_Debug(( "GSocket_Write error WOULDBLOCK\n" )); 
 935       m_error 
= GSOCK_IOERR
; 
 936       GSocket_Debug(( "GSocket_Write error IOERR\n" )); 
 939     /* Only reenable OUTPUT events after an error (just like WSAAsyncSelect 
 940      * in MSW). Once the first OUTPUT event is received, users can assume 
 941      * that the socket is writable until a read operation fails. Only then 
 942      * will further OUTPUT events be posted. 
 944     Enable(GSOCK_OUTPUT
); 
 948   GSocket_Debug(( "GSocket_Write #5, size %d ret %d\n", size
, ret 
)); 
 954  *  Polls the socket to determine its status. This function will 
 955  *  check for the events specified in the 'flags' parameter, and 
 956  *  it will return a mask indicating which operations can be 
 957  *  performed. This function won't block, regardless of the 
 958  *  mode (blocking | nonblocking) of the socket. 
 960 GSocketEventFlags 
GSocket::Select(GSocketEventFlags flags
) 
 962   if (!gs_gui_functions
->CanUseEventLoop()) 
 965     GSocketEventFlags result 
= 0; 
 974         return (GSOCK_LOST_FLAG 
& flags
); 
 976     /* Do not use a static struct, Linux can garble it */ 
 977     tv
.tv_sec 
= m_timeout 
/ 1000; 
 978     tv
.tv_usec 
= (m_timeout 
% 1000) * 1000; 
 983     FD_SET(m_fd
, &readfds
); 
 984     if (flags 
& GSOCK_OUTPUT_FLAG 
|| flags 
& GSOCK_CONNECTION_FLAG
) 
 985       FD_SET(m_fd
, &writefds
); 
 986     FD_SET(m_fd
, &exceptfds
); 
 988     /* Check 'sticky' CONNECTION flag first */ 
 989     result 
|= (GSOCK_CONNECTION_FLAG 
& m_detected
); 
 991     /* If we have already detected a LOST event, then don't try 
 992      * to do any further processing. 
 994     if ((m_detected 
& GSOCK_LOST_FLAG
) != 0) 
 996       m_establishing 
= false; 
 998       return (GSOCK_LOST_FLAG 
& flags
); 
1001     /* Try select now */ 
1002     if (select(m_fd 
+ 1, &readfds
, &writefds
, &exceptfds
, &tv
) <= 0) 
1004       /* What to do here? */ 
1005       return (result 
& flags
); 
1008     /* Check for readability */ 
1009     if (FD_ISSET(m_fd
, &readfds
)) 
1013       int num 
= recv(m_fd
, &c
, 1, MSG_PEEK 
| GSOCKET_MSG_NOSIGNAL
); 
1017         result 
|= GSOCK_INPUT_FLAG
; 
1021         if (m_server 
&& m_stream
) 
1023           result 
|= GSOCK_CONNECTION_FLAG
; 
1024           m_detected 
|= GSOCK_CONNECTION_FLAG
; 
1026         else if ((errno 
!= EWOULDBLOCK
) && (errno 
!= EAGAIN
) && (errno 
!= EINTR
)) 
1028           m_detected 
= GSOCK_LOST_FLAG
; 
1029           m_establishing 
= false; 
1031           /* LOST event: Abort any further processing */ 
1032           return (GSOCK_LOST_FLAG 
& flags
); 
1037     /* Check for writability */ 
1038     if (FD_ISSET(m_fd
, &writefds
)) 
1040       if (m_establishing 
&& !m_server
) 
1043         SOCKOPTLEN_T len 
= sizeof(error
); 
1045         m_establishing 
= false; 
1047         getsockopt(m_fd
, SOL_SOCKET
, SO_ERROR
, (char*)&error
, &len
); 
1051           m_detected 
= GSOCK_LOST_FLAG
; 
1053           /* LOST event: Abort any further processing */ 
1054           return (GSOCK_LOST_FLAG 
& flags
); 
1058           result 
|= GSOCK_CONNECTION_FLAG
; 
1059           m_detected 
|= GSOCK_CONNECTION_FLAG
; 
1064         result 
|= GSOCK_OUTPUT_FLAG
; 
1068     /* Check for exceptions and errors (is this useful in Unices?) */ 
1069     if (FD_ISSET(m_fd
, &exceptfds
)) 
1071       m_establishing 
= false; 
1072       m_detected 
= GSOCK_LOST_FLAG
; 
1074       /* LOST event: Abort any further processing */ 
1075       return (GSOCK_LOST_FLAG 
& flags
); 
1078     return (result 
& flags
); 
1085     return flags 
& m_detected
; 
1092 /* GSocket_SetNonBlocking: 
1093  *  Sets the socket to non-blocking mode. All IO calls will return 
1096 void GSocket::SetNonBlocking(bool non_block
) 
1100   GSocket_Debug( ("GSocket_SetNonBlocking: %d\n", (int)non_block
) ); 
1102   m_non_blocking 
= non_block
; 
1105 /* GSocket_SetTimeout: 
1106  *  Sets the timeout for blocking calls. Time is expressed in 
1109 void GSocket::SetTimeout(unsigned long millisec
) 
1113   m_timeout 
= millisec
; 
1116 /* GSocket_GetError: 
1117  *  Returns the last error occurred for this socket. Note that successful 
1118  *  operations do not clear this back to GSOCK_NOERROR, so use it only 
1121 GSocketError WXDLLIMPEXP_NET 
GSocket::GetError() 
1131  *   There is data to be read in the input buffer. If, after a read 
1132  *   operation, there is still data available, the callback function will 
1135  *   The socket is available for writing. That is, the next write call 
1136  *   won't block. This event is generated only once, when the connection is 
1137  *   first established, and then only if a call failed with GSOCK_WOULDBLOCK, 
1138  *   when the output buffer empties again. This means that the app should 
1139  *   assume that it can write since the first OUTPUT event, and no more 
1140  *   OUTPUT events will be generated unless an error occurs. 
1142  *   Connection successfully established, for client sockets, or incoming 
1143  *   client connection, for server sockets. Wait for this event (also watch 
1144  *   out for GSOCK_LOST) after you issue a nonblocking GSocket_Connect() call. 
1146  *   The connection is lost (or a connection request failed); this could 
1147  *   be due to a failure, or due to the peer closing it gracefully. 
1150 /* GSocket_SetCallback: 
1151  *  Enables the callbacks specified by 'flags'. Note that 'flags' 
1152  *  may be a combination of flags OR'ed toghether, so the same 
1153  *  callback function can be made to accept different events. 
1154  *  The callback function must have the following prototype: 
1156  *  void function(GSocket *socket, GSocketEvent event, char *cdata) 
1158 void GSocket::SetCallback(GSocketEventFlags flags
, 
1159                          GSocketCallback callback
, char *cdata
) 
1165   for (count 
= 0; count 
< GSOCK_MAX_EVENT
; count
++) 
1167     if ((flags 
& (1 << count
)) != 0) 
1169       m_cbacks
[count
] = callback
; 
1170       m_data
[count
] = cdata
; 
1175 /* GSocket_UnsetCallback: 
1176  *  Disables all callbacks specified by 'flags', which may be a 
1177  *  combination of flags OR'ed toghether. 
1179 void GSocket::UnsetCallback(GSocketEventFlags flags
) 
1185   for (count 
= 0; count 
< GSOCK_MAX_EVENT
; count
++) 
1187     if ((flags 
& (1 << count
)) != 0) 
1189       m_cbacks
[count
] = NULL
; 
1190       m_data
[count
] = NULL
; 
1195 GSocketError 
GSocket::GetSockOpt(int level
, int optname
, 
1196                                 void *optval
, int *optlen
) 
1198     if (getsockopt(m_fd
, level
, optname
, (char*)optval
, (SOCKOPTLEN_T
*)optlen
) == 0) 
1200         return GSOCK_NOERROR
; 
1202     return GSOCK_OPTERR
; 
1205 GSocketError 
GSocket::SetSockOpt(int level
, int optname
, 
1206                                 const void *optval
, int optlen
) 
1208     if (setsockopt(m_fd
, level
, optname
, (const char*)optval
, optlen
) == 0) 
1210         return GSOCK_NOERROR
; 
1212     return GSOCK_OPTERR
; 
1215 #define CALL_CALLBACK(socket, event) {                                  \ 
1216   socket->Disable(event);                                               \ 
1217   if (socket->m_cbacks[event])                                          \ 
1218     socket->m_cbacks[event](socket, event, socket->m_data[event]);      \ 
1222 void GSocket::Enable(GSocketEvent event
) 
1224   m_detected 
&= ~(1 << event
); 
1225   gs_gui_functions
->Install_Callback(this, event
); 
1228 void GSocket::Disable(GSocketEvent event
) 
1230   m_detected 
|= (1 << event
); 
1231   gs_gui_functions
->Uninstall_Callback(this, event
); 
1234 /* _GSocket_Input_Timeout: 
1235  *  For blocking sockets, wait until data is available or 
1236  *  until timeout ellapses. 
1238 GSocketError 
GSocket::Input_Timeout() 
1244   /* Linux select() will overwrite the struct on return */ 
1245   tv
.tv_sec  
= (m_timeout 
/ 1000); 
1246   tv
.tv_usec 
= (m_timeout 
% 1000) * 1000; 
1248   if (!m_non_blocking
) 
1251     FD_SET(m_fd
, &readfds
); 
1252     ret 
= select(m_fd 
+ 1, &readfds
, NULL
, NULL
, &tv
); 
1255       GSocket_Debug(( "GSocket_Input_Timeout, select returned 0\n" )); 
1256       m_error 
= GSOCK_TIMEDOUT
; 
1257       return GSOCK_TIMEDOUT
; 
1261       GSocket_Debug(( "GSocket_Input_Timeout, select returned -1\n" )); 
1262       if (errno 
== EBADF
) { GSocket_Debug(( "Invalid file descriptor\n" )); } 
1263       if (errno 
== EINTR
) { GSocket_Debug(( "A non blocked signal was caught\n" )); } 
1264       if (errno 
== EINVAL
) { GSocket_Debug(( "The highest number descriptor is negative\n" )); } 
1265       if (errno 
== ENOMEM
) { GSocket_Debug(( "Not enough memory\n" )); } 
1266       m_error 
= GSOCK_TIMEDOUT
; 
1267       return GSOCK_TIMEDOUT
; 
1270   return GSOCK_NOERROR
; 
1273 /* _GSocket_Output_Timeout: 
1274  *  For blocking sockets, wait until data can be sent without 
1275  *  blocking or until timeout ellapses. 
1277 GSocketError 
GSocket::Output_Timeout() 
1283   /* Linux select() will overwrite the struct on return */ 
1284   tv
.tv_sec  
= (m_timeout 
/ 1000); 
1285   tv
.tv_usec 
= (m_timeout 
% 1000) * 1000; 
1287   GSocket_Debug( ("m_non_blocking has: %d\n", (int)m_non_blocking
) ); 
1289   if (!m_non_blocking
) 
1292     FD_SET(m_fd
, &writefds
); 
1293     ret 
= select(m_fd 
+ 1, NULL
, &writefds
, NULL
, &tv
); 
1296       GSocket_Debug(( "GSocket_Output_Timeout, select returned 0\n" )); 
1297       m_error 
= GSOCK_TIMEDOUT
; 
1298       return GSOCK_TIMEDOUT
; 
1302       GSocket_Debug(( "GSocket_Output_Timeout, select returned -1\n" )); 
1303       if (errno 
== EBADF
) { GSocket_Debug(( "Invalid file descriptor\n" )); } 
1304       if (errno 
== EINTR
) { GSocket_Debug(( "A non blocked signal was caught\n" )); } 
1305       if (errno 
== EINVAL
) { GSocket_Debug(( "The highest number descriptor is negative\n" )); } 
1306       if (errno 
== ENOMEM
) { GSocket_Debug(( "Not enough memory\n" )); } 
1307       m_error 
= GSOCK_TIMEDOUT
; 
1308       return GSOCK_TIMEDOUT
; 
1310     if ( ! FD_ISSET(m_fd
, &writefds
) ) { 
1311         GSocket_Debug(( "GSocket_Output_Timeout is buggy!\n" )); 
1314         GSocket_Debug(( "GSocket_Output_Timeout seems correct\n" )); 
1319     GSocket_Debug(( "GSocket_Output_Timeout, didn't try select!\n" )); 
1322   return GSOCK_NOERROR
; 
1325 int GSocket::Recv_Stream(char *buffer
, int size
) 
1330     ret 
= recv(m_fd
, buffer
, size
, GSOCKET_MSG_NOSIGNAL
); 
1331   } while (ret 
== -1 && errno 
== EINTR
); /* Loop until not interrupted */ 
1335 int GSocket::Recv_Dgram(char *buffer
, int size
) 
1337   struct sockaddr from
; 
1338   WX_SOCKLEN_T fromlen 
= sizeof(from
); 
1342   fromlen 
= sizeof(from
); 
1346     ret 
= recvfrom(m_fd
, buffer
, size
, 0, &from
, (WX_SOCKLEN_T 
*) &fromlen
); 
1347   } while (ret 
== -1 && errno 
== EINTR
); /* Loop until not interrupted */ 
1352   /* Translate a system address into a GSocket address */ 
1355     m_peer 
= GAddress_new(); 
1358       m_error 
= GSOCK_MEMERR
; 
1362   err 
= _GAddress_translate_from(m_peer
, &from
, fromlen
); 
1363   if (err 
!= GSOCK_NOERROR
) 
1365     GAddress_destroy(m_peer
); 
1374 int GSocket::Send_Stream(const char *buffer
, int size
) 
1382     ret 
= send(m_fd
, (char *)buffer
, size
, GSOCKET_MSG_NOSIGNAL
); 
1383   } while (ret 
== -1 && errno 
== EINTR
); /* Loop until not interrupted */ 
1390 int GSocket::Send_Dgram(const char *buffer
, int size
) 
1392   struct sockaddr 
*addr
; 
1398     m_error 
= GSOCK_INVADDR
; 
1402   err 
= _GAddress_translate_to(m_peer
, &addr
, &len
); 
1403   if (err 
!= GSOCK_NOERROR
) 
1413     ret 
= sendto(m_fd
, (char *)buffer
, size
, 0, addr
, len
); 
1414   } while (ret 
== -1 && errno 
== EINTR
); /* Loop until not interrupted */ 
1418   /* Frees memory allocated from _GAddress_translate_to */ 
1424 void GSocket::Detected_Read() 
1428   /* Safeguard against straggling call to Detected_Read */ 
1429   if (m_fd 
== INVALID_SOCKET
) 
1434   /* If we have already detected a LOST event, then don't try 
1435    * to do any further processing. 
1437   if ((m_detected 
& GSOCK_LOST_FLAG
) != 0) 
1439     m_establishing 
= false; 
1441     CALL_CALLBACK(this, GSOCK_LOST
); 
1446   int num 
=  recv(m_fd
, &c
, 1, MSG_PEEK 
| GSOCKET_MSG_NOSIGNAL
); 
1450     CALL_CALLBACK(this, GSOCK_INPUT
); 
1454     if (m_server 
&& m_stream
) 
1456       CALL_CALLBACK(this, GSOCK_CONNECTION
); 
1460       /* Do not throw a lost event in cases where the socket isn't really lost */ 
1461       if ((errno 
== EWOULDBLOCK
) || (errno 
== EAGAIN
) || (errno 
== EINTR
)) 
1463         CALL_CALLBACK(this, GSOCK_INPUT
); 
1467         CALL_CALLBACK(this, GSOCK_LOST
); 
1474 void GSocket::Detected_Write() 
1476   /* If we have already detected a LOST event, then don't try 
1477    * to do any further processing. 
1479   if ((m_detected 
& GSOCK_LOST_FLAG
) != 0) 
1481     m_establishing 
= false; 
1483     CALL_CALLBACK(this, GSOCK_LOST
); 
1488   if (m_establishing 
&& !m_server
) 
1491     SOCKOPTLEN_T len 
= sizeof(error
); 
1493     m_establishing 
= false; 
1495     getsockopt(m_fd
, SOL_SOCKET
, SO_ERROR
, (char*)&error
, &len
); 
1499       CALL_CALLBACK(this, GSOCK_LOST
); 
1504       CALL_CALLBACK(this, GSOCK_CONNECTION
); 
1505       /* We have to fire this event by hand because CONNECTION (for clients) 
1506        * and OUTPUT are internally the same and we just disabled CONNECTION 
1507        * events with the above macro. 
1509       CALL_CALLBACK(this, GSOCK_OUTPUT
); 
1514     CALL_CALLBACK(this, GSOCK_OUTPUT
); 
1518 /* Compatibility functions for GSocket */ 
1519 GSocket 
*GSocket_new(void) 
1521     GSocket 
*newsocket 
= new GSocket(); 
1522     if(newsocket
->IsOk()) 
1529  * ------------------------------------------------------------------------- 
1531  * ------------------------------------------------------------------------- 
1534 /* CHECK_ADDRESS verifies that the current address family is either 
1535  * GSOCK_NOFAMILY or GSOCK_*family*, and if it is GSOCK_NOFAMILY, it 
1536  * initalizes it to be a GSOCK_*family*. In other cases, it returns 
1537  * an appropiate error code. 
1539  * CHECK_ADDRESS_RETVAL does the same but returning 'retval' on error. 
1541 #define CHECK_ADDRESS(address, family)                              \ 
1543   if (address->m_family == GSOCK_NOFAMILY)                          \ 
1544     if (_GAddress_Init_##family(address) != GSOCK_NOERROR)          \ 
1545       return address->m_error;                                      \ 
1546   if (address->m_family != GSOCK_##family)                          \ 
1548     address->m_error = GSOCK_INVADDR;                               \ 
1549     return GSOCK_INVADDR;                                           \ 
1553 #define CHECK_ADDRESS_RETVAL(address, family, retval)               \ 
1555   if (address->m_family == GSOCK_NOFAMILY)                          \ 
1556     if (_GAddress_Init_##family(address) != GSOCK_NOERROR)          \ 
1558   if (address->m_family != GSOCK_##family)                          \ 
1560     address->m_error = GSOCK_INVADDR;                               \ 
1566 GAddress 
*GAddress_new(void) 
1570   if ((address 
= (GAddress 
*) malloc(sizeof(GAddress
))) == NULL
) 
1573   address
->m_family  
= GSOCK_NOFAMILY
; 
1574   address
->m_addr    
= NULL
; 
1580 GAddress 
*GAddress_copy(GAddress 
*address
) 
1584   assert(address 
!= NULL
); 
1586   if ((addr2 
= (GAddress 
*) malloc(sizeof(GAddress
))) == NULL
) 
1589   memcpy(addr2
, address
, sizeof(GAddress
)); 
1591   if (address
->m_addr 
&& address
->m_len 
> 0) 
1593     addr2
->m_addr 
= (struct sockaddr 
*)malloc(addr2
->m_len
); 
1594     if (addr2
->m_addr 
== NULL
) 
1599     memcpy(addr2
->m_addr
, address
->m_addr
, addr2
->m_len
); 
1605 void GAddress_destroy(GAddress 
*address
) 
1607   assert(address 
!= NULL
); 
1609   if (address
->m_addr
) 
1610     free(address
->m_addr
); 
1615 void GAddress_SetFamily(GAddress 
*address
, GAddressType type
) 
1617   assert(address 
!= NULL
); 
1619   address
->m_family 
= type
; 
1622 GAddressType 
GAddress_GetFamily(GAddress 
*address
) 
1624   assert(address 
!= NULL
); 
1626   return address
->m_family
; 
1629 GSocketError 
_GAddress_translate_from(GAddress 
*address
, 
1630                                       struct sockaddr 
*addr
, int len
) 
1632   address
->m_realfamily 
= addr
->sa_family
; 
1633   switch (addr
->sa_family
) 
1636       address
->m_family 
= GSOCK_INET
; 
1639       address
->m_family 
= GSOCK_UNIX
; 
1643       address
->m_family 
= GSOCK_INET6
; 
1648       address
->m_error 
= GSOCK_INVOP
; 
1653   if (address
->m_addr
) 
1654     free(address
->m_addr
); 
1656   address
->m_len  
= len
; 
1657   address
->m_addr 
= (struct sockaddr 
*)malloc(len
); 
1659   if (address
->m_addr 
== NULL
) 
1661     address
->m_error 
= GSOCK_MEMERR
; 
1662     return GSOCK_MEMERR
; 
1664   memcpy(address
->m_addr
, addr
, len
); 
1666   return GSOCK_NOERROR
; 
1669 GSocketError 
_GAddress_translate_to(GAddress 
*address
, 
1670                                     struct sockaddr 
**addr
, int *len
) 
1672   if (!address
->m_addr
) 
1674     address
->m_error 
= GSOCK_INVADDR
; 
1675     return GSOCK_INVADDR
; 
1678   *len 
= address
->m_len
; 
1679   *addr 
= (struct sockaddr 
*)malloc(address
->m_len
); 
1682     address
->m_error 
= GSOCK_MEMERR
; 
1683     return GSOCK_MEMERR
; 
1686   memcpy(*addr
, address
->m_addr
, address
->m_len
); 
1687   return GSOCK_NOERROR
; 
1691  * ------------------------------------------------------------------------- 
1692  * Internet address family 
1693  * ------------------------------------------------------------------------- 
1696 GSocketError 
_GAddress_Init_INET(GAddress 
*address
) 
1698   address
->m_len  
= sizeof(struct sockaddr_in
); 
1699   address
->m_addr 
= (struct sockaddr 
*) malloc(address
->m_len
); 
1700   if (address
->m_addr 
== NULL
) 
1702     address
->m_error 
= GSOCK_MEMERR
; 
1703     return GSOCK_MEMERR
; 
1706   address
->m_family 
= GSOCK_INET
; 
1707   address
->m_realfamily 
= PF_INET
; 
1708   ((struct sockaddr_in 
*)address
->m_addr
)->sin_family 
= AF_INET
; 
1709   ((struct sockaddr_in 
*)address
->m_addr
)->sin_addr
.s_addr 
= INADDR_ANY
; 
1711   return GSOCK_NOERROR
; 
1714 GSocketError 
GAddress_INET_SetHostName(GAddress 
*address
, const char *hostname
) 
1717   struct in_addr 
*addr
; 
1719   assert(address 
!= NULL
); 
1721   CHECK_ADDRESS(address
, INET
); 
1723   addr 
= &(((struct sockaddr_in 
*)address
->m_addr
)->sin_addr
); 
1725   /* If it is a numeric host name, convert it now */ 
1726 #if defined(HAVE_INET_ATON) 
1727   if (inet_aton(hostname
, addr
) == 0) 
1729 #elif defined(HAVE_INET_ADDR) 
1730   if ( (addr
->s_addr 
= inet_addr(hostname
)) == (unsigned)-1 ) 
1733   /* Use gethostbyname by default */ 
1735   int val 
= 1;  /* VA doesn't like constants in conditional expressions */ 
1740     struct in_addr 
*array_addr
; 
1742     /* It is a real name, we solve it */ 
1743     if ((he 
= gethostbyname(hostname
)) == NULL
) 
1745       /* Reset to invalid address */ 
1746       addr
->s_addr 
= INADDR_NONE
; 
1747       address
->m_error 
= GSOCK_NOHOST
; 
1748       return GSOCK_NOHOST
; 
1750     array_addr 
= (struct in_addr 
*) *(he
->h_addr_list
); 
1751     addr
->s_addr 
= array_addr
[0].s_addr
; 
1753   return GSOCK_NOERROR
; 
1756 GSocketError 
GAddress_INET_SetAnyAddress(GAddress 
*address
) 
1758   return GAddress_INET_SetHostAddress(address
, INADDR_ANY
); 
1761 GSocketError 
GAddress_INET_SetHostAddress(GAddress 
*address
, 
1762                                           unsigned long hostaddr
) 
1764   struct in_addr 
*addr
; 
1766   assert(address 
!= NULL
); 
1768   CHECK_ADDRESS(address
, INET
); 
1770   addr 
= &(((struct sockaddr_in 
*)address
->m_addr
)->sin_addr
); 
1771   addr
->s_addr 
= htonl(hostaddr
); 
1773   return GSOCK_NOERROR
; 
1776 GSocketError 
GAddress_INET_SetPortName(GAddress 
*address
, const char *port
, 
1777                                        const char *protocol
) 
1780   struct sockaddr_in 
*addr
; 
1782   assert(address 
!= NULL
); 
1783   CHECK_ADDRESS(address
, INET
); 
1787     address
->m_error 
= GSOCK_INVPORT
; 
1788     return GSOCK_INVPORT
; 
1791 #if defined(__WXPM__) && defined(__EMX__) 
1792   se 
= getservbyname(port
, (char*)protocol
); 
1794   se 
= getservbyname(port
, protocol
); 
1798     /* the cast to int suppresses compiler warnings about subscript having the 
1800     if (isdigit((int)port
[0])) 
1804       port_int 
= atoi(port
); 
1805       addr 
= (struct sockaddr_in 
*)address
->m_addr
; 
1806       addr
->sin_port 
= htons(port_int
); 
1807       return GSOCK_NOERROR
; 
1810     address
->m_error 
= GSOCK_INVPORT
; 
1811     return GSOCK_INVPORT
; 
1814   addr 
= (struct sockaddr_in 
*)address
->m_addr
; 
1815   addr
->sin_port 
= se
->s_port
; 
1817   return GSOCK_NOERROR
; 
1820 GSocketError 
GAddress_INET_SetPort(GAddress 
*address
, unsigned short port
) 
1822   struct sockaddr_in 
*addr
; 
1824   assert(address 
!= NULL
); 
1825   CHECK_ADDRESS(address
, INET
); 
1827   addr 
= (struct sockaddr_in 
*)address
->m_addr
; 
1828   addr
->sin_port 
= htons(port
); 
1830   return GSOCK_NOERROR
; 
1833 GSocketError 
GAddress_INET_GetHostName(GAddress 
*address
, char *hostname
, size_t sbuf
) 
1837   struct sockaddr_in 
*addr
; 
1839   assert(address 
!= NULL
); 
1840   CHECK_ADDRESS(address
, INET
); 
1842   addr 
= (struct sockaddr_in 
*)address
->m_addr
; 
1843   addr_buf 
= (char *)&(addr
->sin_addr
); 
1845   he 
= gethostbyaddr(addr_buf
, sizeof(addr
->sin_addr
), AF_INET
); 
1848     address
->m_error 
= GSOCK_NOHOST
; 
1849     return GSOCK_NOHOST
; 
1852   strncpy(hostname
, he
->h_name
, sbuf
); 
1854   return GSOCK_NOERROR
; 
1857 unsigned long GAddress_INET_GetHostAddress(GAddress 
*address
) 
1859   struct sockaddr_in 
*addr
; 
1861   assert(address 
!= NULL
); 
1862   CHECK_ADDRESS_RETVAL(address
, INET
, 0); 
1864   addr 
= (struct sockaddr_in 
*)address
->m_addr
; 
1866   return ntohl(addr
->sin_addr
.s_addr
); 
1869 unsigned short GAddress_INET_GetPort(GAddress 
*address
) 
1871   struct sockaddr_in 
*addr
; 
1873   assert(address 
!= NULL
); 
1874   CHECK_ADDRESS_RETVAL(address
, INET
, 0); 
1876   addr 
= (struct sockaddr_in 
*)address
->m_addr
; 
1877   return ntohs(addr
->sin_port
); 
1881  * ------------------------------------------------------------------------- 
1882  * Unix address family 
1883  * ------------------------------------------------------------------------- 
1886 #ifndef __VISAGECPP__ 
1887 GSocketError 
_GAddress_Init_UNIX(GAddress 
*address
) 
1889   address
->m_len  
= sizeof(struct sockaddr_un
); 
1890   address
->m_addr 
= (struct sockaddr 
*)malloc(address
->m_len
); 
1891   if (address
->m_addr 
== NULL
) 
1893     address
->m_error 
= GSOCK_MEMERR
; 
1894     return GSOCK_MEMERR
; 
1897   address
->m_family 
= GSOCK_UNIX
; 
1898   address
->m_realfamily 
= PF_UNIX
; 
1899   ((struct sockaddr_un 
*)address
->m_addr
)->sun_family 
= AF_UNIX
; 
1900   ((struct sockaddr_un 
*)address
->m_addr
)->sun_path
[0] = 0; 
1902   return GSOCK_NOERROR
; 
1905 #define UNIX_SOCK_PATHLEN (sizeof(addr->sun_path)/sizeof(addr->sun_path[0])) 
1907 GSocketError 
GAddress_UNIX_SetPath(GAddress 
*address
, const char *path
) 
1909   struct sockaddr_un 
*addr
; 
1911   assert(address 
!= NULL
); 
1913   CHECK_ADDRESS(address
, UNIX
); 
1915   addr 
= ((struct sockaddr_un 
*)address
->m_addr
); 
1916   strncpy(addr
->sun_path
, path
, UNIX_SOCK_PATHLEN
); 
1917   addr
->sun_path
[UNIX_SOCK_PATHLEN 
- 1] = '\0'; 
1919   return GSOCK_NOERROR
; 
1922 GSocketError 
GAddress_UNIX_GetPath(GAddress 
*address
, char *path
, size_t sbuf
) 
1924   struct sockaddr_un 
*addr
; 
1926   assert(address 
!= NULL
); 
1927   CHECK_ADDRESS(address
, UNIX
); 
1929   addr 
= (struct sockaddr_un 
*)address
->m_addr
; 
1931   strncpy(path
, addr
->sun_path
, sbuf
); 
1933   return GSOCK_NOERROR
; 
1935 #endif  /* !defined(__VISAGECPP__) */ 
1936 #endif  /* wxUSE_SOCKETS || defined(__GSOCKET_STANDALONE__) */