More debug code
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@6756 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
29c25a8e01
commit
aac67d4c3d
@ -60,7 +60,7 @@ struct sockaddr_un {
|
|||||||
#else
|
#else
|
||||||
# ifdef __GLIBC__
|
# ifdef __GLIBC__
|
||||||
# if __GLIBC__ == 2
|
# if __GLIBC__ == 2
|
||||||
# define SOCKLEN_T socklen_t
|
# define SOCKLEN_T socklen_t
|
||||||
# endif
|
# endif
|
||||||
# else
|
# else
|
||||||
# define SOCKLEN_T int
|
# define SOCKLEN_T int
|
||||||
@ -69,10 +69,16 @@ struct sockaddr_un {
|
|||||||
|
|
||||||
#endif /* SOCKLEN_T */
|
#endif /* SOCKLEN_T */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* MSW defines this, Unices don't.
|
||||||
|
*/
|
||||||
|
#ifndef INVALID_SOCKET
|
||||||
|
#define INVALID_SOCKET -1
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* INADDR_BROADCAST is identical to INADDR_NONE which is not defined
|
* INADDR_BROADCAST is identical to INADDR_NONE which is not defined
|
||||||
* on all unices. INADDR_BROADCAST should be fine to indicate an error.
|
* on all systems. INADDR_BROADCAST should be fine to indicate an error.
|
||||||
*/
|
*/
|
||||||
#ifndef INADDR_NONE
|
#ifndef INADDR_NONE
|
||||||
#define INADDR_NONE INADDR_BROADCAST
|
#define INADDR_NONE INADDR_BROADCAST
|
||||||
@ -137,7 +143,7 @@ GSocket *GSocket_new(void)
|
|||||||
if (socket == NULL)
|
if (socket == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
socket->m_fd = -1;
|
socket->m_fd = INVALID_SOCKET;
|
||||||
for (i=0;i<GSOCK_MAX_EVENT;i++)
|
for (i=0;i<GSOCK_MAX_EVENT;i++)
|
||||||
{
|
{
|
||||||
socket->m_cbacks[i] = NULL;
|
socket->m_cbacks[i] = NULL;
|
||||||
@ -170,7 +176,7 @@ void GSocket_destroy(GSocket *socket)
|
|||||||
assert(socket != NULL);
|
assert(socket != NULL);
|
||||||
|
|
||||||
/* Check that the socket is really shutdowned */
|
/* Check that the socket is really shutdowned */
|
||||||
if (socket->m_fd != -1)
|
if (socket->m_fd != INVALID_SOCKET)
|
||||||
GSocket_Shutdown(socket);
|
GSocket_Shutdown(socket);
|
||||||
|
|
||||||
/* Per-socket GUI-specific cleanup */
|
/* Per-socket GUI-specific cleanup */
|
||||||
@ -198,11 +204,11 @@ void GSocket_Shutdown(GSocket *socket)
|
|||||||
assert(socket != NULL);
|
assert(socket != NULL);
|
||||||
|
|
||||||
/* If socket has been created, shutdown it */
|
/* If socket has been created, shutdown it */
|
||||||
if (socket->m_fd != -1)
|
if (socket->m_fd != INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
shutdown(socket->m_fd, 2);
|
shutdown(socket->m_fd, 2);
|
||||||
close(socket->m_fd);
|
close(socket->m_fd);
|
||||||
socket->m_fd = -1;
|
socket->m_fd = INVALID_SOCKET;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Disable GUI callbacks */
|
/* Disable GUI callbacks */
|
||||||
@ -234,7 +240,7 @@ GSocketError GSocket_SetLocal(GSocket *socket, GAddress *address)
|
|||||||
assert(socket != NULL);
|
assert(socket != NULL);
|
||||||
|
|
||||||
/* the socket must be initialized, or it must be a server */
|
/* the socket must be initialized, or it must be a server */
|
||||||
if ((socket->m_fd != -1 && !socket->m_server))
|
if ((socket->m_fd != INVALID_SOCKET && !socket->m_server))
|
||||||
{
|
{
|
||||||
socket->m_error = GSOCK_INVSOCK;
|
socket->m_error = GSOCK_INVSOCK;
|
||||||
return GSOCK_INVSOCK;
|
return GSOCK_INVSOCK;
|
||||||
@ -288,7 +294,7 @@ GAddress *GSocket_GetLocal(GSocket *socket)
|
|||||||
return GAddress_copy(socket->m_local);
|
return GAddress_copy(socket->m_local);
|
||||||
|
|
||||||
/* else, if the socket is initialized, try getsockname */
|
/* else, if the socket is initialized, try getsockname */
|
||||||
if (socket->m_fd == -1)
|
if (socket->m_fd == INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
socket->m_error = GSOCK_INVSOCK;
|
socket->m_error = GSOCK_INVSOCK;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -350,7 +356,7 @@ GSocketError GSocket_SetServer(GSocket *sck)
|
|||||||
assert(sck != NULL);
|
assert(sck != NULL);
|
||||||
|
|
||||||
/* must not be in use */
|
/* must not be in use */
|
||||||
if (sck->m_fd != -1)
|
if (sck->m_fd != INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
sck->m_error = GSOCK_INVSOCK;
|
sck->m_error = GSOCK_INVSOCK;
|
||||||
return GSOCK_INVSOCK;
|
return GSOCK_INVSOCK;
|
||||||
@ -371,7 +377,7 @@ GSocketError GSocket_SetServer(GSocket *sck)
|
|||||||
/* Create the socket */
|
/* Create the socket */
|
||||||
sck->m_fd = socket(sck->m_local->m_realfamily, SOCK_STREAM, 0);
|
sck->m_fd = socket(sck->m_local->m_realfamily, SOCK_STREAM, 0);
|
||||||
|
|
||||||
if (sck->m_fd == -1)
|
if (sck->m_fd == INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
sck->m_error = GSOCK_IOERR;
|
sck->m_error = GSOCK_IOERR;
|
||||||
return GSOCK_IOERR;
|
return GSOCK_IOERR;
|
||||||
@ -391,7 +397,7 @@ GSocketError GSocket_SetServer(GSocket *sck)
|
|||||||
(listen(sck->m_fd, 5) != 0))
|
(listen(sck->m_fd, 5) != 0))
|
||||||
{
|
{
|
||||||
close(sck->m_fd);
|
close(sck->m_fd);
|
||||||
sck->m_fd = -1;
|
sck->m_fd = INVALID_SOCKET;
|
||||||
sck->m_error = GSOCK_IOERR;
|
sck->m_error = GSOCK_IOERR;
|
||||||
return GSOCK_IOERR;
|
return GSOCK_IOERR;
|
||||||
}
|
}
|
||||||
@ -425,7 +431,7 @@ GSocket *GSocket_WaitConnection(GSocket *socket)
|
|||||||
_GSocket_Enable(socket, GSOCK_CONNECTION);
|
_GSocket_Enable(socket, GSOCK_CONNECTION);
|
||||||
|
|
||||||
/* If the socket has already been created, we exit immediately */
|
/* If the socket has already been created, we exit immediately */
|
||||||
if (socket->m_fd == -1 || !socket->m_server)
|
if (socket->m_fd == INVALID_SOCKET || !socket->m_server)
|
||||||
{
|
{
|
||||||
socket->m_error = GSOCK_INVSOCK;
|
socket->m_error = GSOCK_INVSOCK;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -450,7 +456,7 @@ GSocket *GSocket_WaitConnection(GSocket *socket)
|
|||||||
|
|
||||||
connection->m_fd = accept(socket->m_fd, &from, (SOCKLEN_T *) &fromlen);
|
connection->m_fd = accept(socket->m_fd, &from, (SOCKLEN_T *) &fromlen);
|
||||||
|
|
||||||
if (connection->m_fd == -1)
|
if (connection->m_fd == INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
if (errno == EWOULDBLOCK)
|
if (errno == EWOULDBLOCK)
|
||||||
socket->m_error = GSOCK_WOULDBLOCK;
|
socket->m_error = GSOCK_WOULDBLOCK;
|
||||||
@ -489,71 +495,6 @@ GSocket *GSocket_WaitConnection(GSocket *socket)
|
|||||||
return connection;
|
return connection;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Datagram sockets */
|
|
||||||
|
|
||||||
/* GSocket_SetNonOriented:
|
|
||||||
* Sets up this socket as a non-connection oriented (datagram) socket.
|
|
||||||
* Before using this function, the local address must have been set
|
|
||||||
* with GSocket_SetLocal(), or the call will fail. Returns GSOCK_NOERROR
|
|
||||||
* on success, or one of the following otherwise.
|
|
||||||
*
|
|
||||||
* Error codes:
|
|
||||||
* GSOCK_INVSOCK - the socket is in use.
|
|
||||||
* GSOCK_INVADDR - the local address has not been set.
|
|
||||||
* GSOCK_IOERR - low-level error.
|
|
||||||
*/
|
|
||||||
GSocketError GSocket_SetNonOriented(GSocket *sck)
|
|
||||||
{
|
|
||||||
int arg = 1;
|
|
||||||
|
|
||||||
assert(sck != NULL);
|
|
||||||
|
|
||||||
if (sck->m_fd != -1)
|
|
||||||
{
|
|
||||||
sck->m_error = GSOCK_INVSOCK;
|
|
||||||
return GSOCK_INVSOCK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!sck->m_local)
|
|
||||||
{
|
|
||||||
sck->m_error = GSOCK_INVADDR;
|
|
||||||
return GSOCK_INVADDR;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Initialize all fields */
|
|
||||||
sck->m_stream = FALSE;
|
|
||||||
sck->m_server = FALSE;
|
|
||||||
sck->m_oriented = FALSE;
|
|
||||||
|
|
||||||
/* Create the socket */
|
|
||||||
sck->m_fd = socket(sck->m_local->m_realfamily, SOCK_DGRAM, 0);
|
|
||||||
|
|
||||||
if (sck->m_fd < 0)
|
|
||||||
{
|
|
||||||
sck->m_error = GSOCK_IOERR;
|
|
||||||
return GSOCK_IOERR;
|
|
||||||
}
|
|
||||||
|
|
||||||
ioctl(sck->m_fd, FIONBIO, &arg);
|
|
||||||
_GSocket_Enable_Events(sck);
|
|
||||||
|
|
||||||
/* Bind to the local address,
|
|
||||||
* and retrieve the actual address bound.
|
|
||||||
*/
|
|
||||||
if ((bind(sck->m_fd, sck->m_local->m_addr, sck->m_local->m_len) != 0) ||
|
|
||||||
(getsockname(sck->m_fd,
|
|
||||||
sck->m_local->m_addr,
|
|
||||||
(SOCKLEN_T *) &sck->m_local->m_len) != 0))
|
|
||||||
{
|
|
||||||
close(sck->m_fd);
|
|
||||||
sck->m_fd = -1;
|
|
||||||
sck->m_error = GSOCK_IOERR;
|
|
||||||
return GSOCK_IOERR;
|
|
||||||
}
|
|
||||||
|
|
||||||
return GSOCK_NOERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Client specific parts */
|
/* Client specific parts */
|
||||||
|
|
||||||
/* GSocket_Connect:
|
/* GSocket_Connect:
|
||||||
@ -589,7 +530,7 @@ GSocketError GSocket_Connect(GSocket *sck, GSocketStream stream)
|
|||||||
/* Enable CONNECTION events (needed for nonblocking connections) */
|
/* Enable CONNECTION events (needed for nonblocking connections) */
|
||||||
_GSocket_Enable(sck, GSOCK_CONNECTION);
|
_GSocket_Enable(sck, GSOCK_CONNECTION);
|
||||||
|
|
||||||
if (sck->m_fd != -1)
|
if (sck->m_fd != INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
sck->m_error = GSOCK_INVSOCK;
|
sck->m_error = GSOCK_INVSOCK;
|
||||||
return GSOCK_INVSOCK;
|
return GSOCK_INVSOCK;
|
||||||
@ -611,7 +552,7 @@ GSocketError GSocket_Connect(GSocket *sck, GSocketStream stream)
|
|||||||
sck->m_fd = socket(sck->m_peer->m_realfamily,
|
sck->m_fd = socket(sck->m_peer->m_realfamily,
|
||||||
sck->m_stream? SOCK_STREAM : SOCK_DGRAM, 0);
|
sck->m_stream? SOCK_STREAM : SOCK_DGRAM, 0);
|
||||||
|
|
||||||
if (sck->m_fd == -1)
|
if (sck->m_fd == INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
sck->m_error = GSOCK_IOERR;
|
sck->m_error = GSOCK_IOERR;
|
||||||
return GSOCK_IOERR;
|
return GSOCK_IOERR;
|
||||||
@ -637,7 +578,7 @@ GSocketError GSocket_Connect(GSocket *sck, GSocketStream stream)
|
|||||||
if (_GSocket_Output_Timeout(sck) == GSOCK_TIMEDOUT)
|
if (_GSocket_Output_Timeout(sck) == GSOCK_TIMEDOUT)
|
||||||
{
|
{
|
||||||
close(sck->m_fd);
|
close(sck->m_fd);
|
||||||
sck->m_fd = -1;
|
sck->m_fd = INVALID_SOCKET;
|
||||||
/* sck->m_error is set in _GSocket_Output_Timeout */
|
/* sck->m_error is set in _GSocket_Output_Timeout */
|
||||||
return GSOCK_TIMEDOUT;
|
return GSOCK_TIMEDOUT;
|
||||||
}
|
}
|
||||||
@ -670,7 +611,72 @@ GSocketError GSocket_Connect(GSocket *sck, GSocketStream stream)
|
|||||||
* then the call to GSocket_Connect has failed.
|
* then the call to GSocket_Connect has failed.
|
||||||
*/
|
*/
|
||||||
close(sck->m_fd);
|
close(sck->m_fd);
|
||||||
sck->m_fd = -1;
|
sck->m_fd = INVALID_SOCKET;
|
||||||
|
sck->m_error = GSOCK_IOERR;
|
||||||
|
return GSOCK_IOERR;
|
||||||
|
}
|
||||||
|
|
||||||
|
return GSOCK_NOERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Datagram sockets */
|
||||||
|
|
||||||
|
/* GSocket_SetNonOriented:
|
||||||
|
* Sets up this socket as a non-connection oriented (datagram) socket.
|
||||||
|
* Before using this function, the local address must have been set
|
||||||
|
* with GSocket_SetLocal(), or the call will fail. Returns GSOCK_NOERROR
|
||||||
|
* on success, or one of the following otherwise.
|
||||||
|
*
|
||||||
|
* Error codes:
|
||||||
|
* GSOCK_INVSOCK - the socket is in use.
|
||||||
|
* GSOCK_INVADDR - the local address has not been set.
|
||||||
|
* GSOCK_IOERR - low-level error.
|
||||||
|
*/
|
||||||
|
GSocketError GSocket_SetNonOriented(GSocket *sck)
|
||||||
|
{
|
||||||
|
int arg = 1;
|
||||||
|
|
||||||
|
assert(sck != NULL);
|
||||||
|
|
||||||
|
if (sck->m_fd != INVALID_SOCKET)
|
||||||
|
{
|
||||||
|
sck->m_error = GSOCK_INVSOCK;
|
||||||
|
return GSOCK_INVSOCK;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!sck->m_local)
|
||||||
|
{
|
||||||
|
sck->m_error = GSOCK_INVADDR;
|
||||||
|
return GSOCK_INVADDR;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Initialize all fields */
|
||||||
|
sck->m_stream = FALSE;
|
||||||
|
sck->m_server = FALSE;
|
||||||
|
sck->m_oriented = FALSE;
|
||||||
|
|
||||||
|
/* Create the socket */
|
||||||
|
sck->m_fd = socket(sck->m_local->m_realfamily, SOCK_DGRAM, 0);
|
||||||
|
|
||||||
|
if (sck->m_fd == INVALID_SOCKET)
|
||||||
|
{
|
||||||
|
sck->m_error = GSOCK_IOERR;
|
||||||
|
return GSOCK_IOERR;
|
||||||
|
}
|
||||||
|
|
||||||
|
ioctl(sck->m_fd, FIONBIO, &arg);
|
||||||
|
_GSocket_Enable_Events(sck);
|
||||||
|
|
||||||
|
/* Bind to the local address,
|
||||||
|
* and retrieve the actual address bound.
|
||||||
|
*/
|
||||||
|
if ((bind(sck->m_fd, sck->m_local->m_addr, sck->m_local->m_len) != 0) ||
|
||||||
|
(getsockname(sck->m_fd,
|
||||||
|
sck->m_local->m_addr,
|
||||||
|
(SOCKLEN_T *) &sck->m_local->m_len) != 0))
|
||||||
|
{
|
||||||
|
close(sck->m_fd);
|
||||||
|
sck->m_fd = INVALID_SOCKET;
|
||||||
sck->m_error = GSOCK_IOERR;
|
sck->m_error = GSOCK_IOERR;
|
||||||
return GSOCK_IOERR;
|
return GSOCK_IOERR;
|
||||||
}
|
}
|
||||||
@ -690,7 +696,7 @@ int GSocket_Read(GSocket *socket, char *buffer, int size)
|
|||||||
/* Reenable INPUT events */
|
/* Reenable INPUT events */
|
||||||
_GSocket_Enable(socket, GSOCK_INPUT);
|
_GSocket_Enable(socket, GSOCK_INPUT);
|
||||||
|
|
||||||
if (socket->m_fd == -1 || socket->m_server)
|
if (socket->m_fd == INVALID_SOCKET || socket->m_server)
|
||||||
{
|
{
|
||||||
socket->m_error = GSOCK_INVSOCK;
|
socket->m_error = GSOCK_INVSOCK;
|
||||||
return -1;
|
return -1;
|
||||||
@ -725,7 +731,7 @@ int GSocket_Write(GSocket *socket, const char *buffer, int size)
|
|||||||
|
|
||||||
GSocket_Debug(( "GSocket_Write #1, size %d\n", size ));
|
GSocket_Debug(( "GSocket_Write #1, size %d\n", size ));
|
||||||
|
|
||||||
if (socket->m_fd == -1 || socket->m_server)
|
if (socket->m_fd == INVALID_SOCKET || socket->m_server)
|
||||||
{
|
{
|
||||||
socket->m_error = GSOCK_INVSOCK;
|
socket->m_error = GSOCK_INVSOCK;
|
||||||
return -1;
|
return -1;
|
||||||
@ -1080,7 +1086,16 @@ GSocketError _GSocket_Output_Timeout(GSocket *socket)
|
|||||||
socket->m_error = GSOCK_TIMEDOUT;
|
socket->m_error = GSOCK_TIMEDOUT;
|
||||||
return GSOCK_TIMEDOUT;
|
return GSOCK_TIMEDOUT;
|
||||||
}
|
}
|
||||||
|
if ( ! FD_ISSET(socket->m_fd, &writefds) )
|
||||||
|
GSocket_Debug(( "GSocket_Output_Timeout is buggy!" ));
|
||||||
|
else
|
||||||
|
GSocket_Debug(( "GSocket_Output_Timeout seems correct" ));
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GSocket_Debug(( "GSocket_Output_Timeout, didn't try select!" ));
|
||||||
|
}
|
||||||
|
|
||||||
return GSOCK_NOERROR;
|
return GSOCK_NOERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user