Hi, attached is the patch I intend to commit later this day:
- Stores last errno in a module global implicitely - Sets global last error explicitely for socket_select() and socket_create() - Modified socket_last_error() to return global modules last error if no socket resource is given - Added a couple of more E_WARNING messages in case something goes foobar so the user isn't left alone in the dark. regards, - Markus On Sun, Apr 28, 2002 at 10:53:42PM -0500, Jason Greene wrote : > This was something I was planning on adding, but it was not applied to > the 4.2.0 branch, because it introduces a feature enhancement (storing a > global last error) and not a bug fix. It is a very simple enhance, I > just have not had the time to work on it yet. > > -Jason -- Please always Cc to me when replying to me on the lists. GnuPG Key: http://guru.josefine.at/~mfischer/C2272BD0.asc "Mind if I MFH ?" "What QA did you do on it?" "the usual?" "ah... none :)"
? sockets.diff Index: php_sockets.h =================================================================== RCS file: /repository/php4/ext/sockets/php_sockets.h,v retrieving revision 1.22 diff -u -r1.22 php_sockets.h --- php_sockets.h 6 Mar 2002 20:19:09 -0000 1.22 +++ php_sockets.h 29 Apr 2002 08:56:25 -0000 @@ -102,12 +102,14 @@ int accept_connect(php_socket *in_sock, php_socket **new_sock, struct sockaddr *la TSRMLS_DC); int php_read(int bsd_socket, void *buf, int maxlen); +ZEND_BEGIN_MODULE_GLOBALS(sockets) + int last_error; +ZEND_END_MODULE_GLOBALS(sockets) + #ifdef ZTS -#define SOCKETSG(v) (sockets_globals->v) -#define SOCKETSLS_FETCH() php_sockets_globals *sockets_globals = ts_resource(sockets_globals_id) +#define SOCKETS_G(v) TSRMG(sockets_globals_id, zend_sockets_globals *, v) #else -#define SOCKETSG(v) (sockets_globals.v) -#define SOCKETSLS_FETCH() +#define SOCKETS_G(v) (sockets_globals.v) #endif #else Index: sockets.c =================================================================== RCS file: /repository/php4/ext/sockets/sockets.c,v retrieving revision 1.98 diff -u -r1.98 sockets.c --- sockets.c 11 Mar 2002 01:24:42 -0000 1.98 +++ sockets.c 29 Apr 2002 08:56:25 -0000 @@ -62,12 +62,7 @@ # define IS_INVALID_SOCKET(a) (a->bsd_socket == INVALID_SOCKET) #endif -#ifdef ZTS -int sockets_globals_id; -#else -php_sockets_globals sockets_globals; -#endif - +ZEND_DECLARE_MODULE_GLOBALS(sockets) #ifndef MSG_WAITALL #ifdef LINUX @@ -90,7 +85,9 @@ #define PHP_BINARY_READ 0x0002 #define PHP_SOCKET_ERROR(socket,msg,errn) socket->error = errn; \ - php_error(E_WARNING, "%s() %s [%d]: %s", get_active_function_name(TSRMLS_C), msg, errn, php_strerror(errn)) + + SOCKETS_G(last_error) = errn; \ + + php_error(E_WARNING, "%s() %s [%d]: %s", \ + + get_active_function_name(TSRMLS_C), msg, errn, php_strerror(errn)) static int le_iov; #define le_iov_name "Socket I/O vector" @@ -374,12 +371,20 @@ return 1; } + +static void php_sockets_init_globals(zend_sockets_globals *sockets_globals TSRMLS_DC) +{ + sockets_globals->last_error = 0; +} + /* {{{ PHP_MINIT_FUNCTION */ PHP_MINIT_FUNCTION(sockets) { struct protoent *pe; + ZEND_INIT_MODULE_GLOBALS(sockets, php_sockets_init_globals, NULL); + le_socket = zend_register_list_destructors_ex(destroy_socket, NULL, le_socket_name, module_number); le_iov = zend_register_list_destructors_ex(destroy_iovec, NULL, le_iov_name, module_number); @@ -526,6 +531,7 @@ retval = select(max_fd+1, &rfds, &wfds, &efds, tv_p); if (retval == -1) { + SOCKETS_G(last_error) = errno; php_error(E_WARNING, "%s() %s [%d]: %s", get_active_function_name(TSRMLS_C), "unable to select", errno, php_strerror(errno)); RETURN_FALSE; } @@ -570,6 +576,8 @@ ZEND_FETCH_RESOURCE(php_sock, php_socket *, &arg1, -1, le_socket_name, le_socket); if (!accept_connect(php_sock, &new_sock, (struct sockaddr *) &sa TSRMLS_CC)) { + php_error(E_WARNING, "%s() unable to accept socket connection [%d]: +%s", + get_active_function_name(TSRMLS_C), errno, +php_strerror(errno)); RETURN_FALSE; } @@ -798,6 +806,8 @@ RETURN_TRUE; default: + php_error(E_WARNING, "%s() Unsupported address family %d", + get_active_function_name(TSRMLS_C), +sa->sa_family); RETURN_FALSE; } } @@ -854,6 +864,8 @@ RETURN_TRUE; default: + php_error(E_WARNING, "%s() Unsupported address family %d", + get_active_function_name(TSRMLS_C), +sa->sa_family); RETURN_FALSE; } } @@ -885,6 +897,9 @@ php_sock->type = arg1; if (IS_INVALID_SOCKET(php_sock)) { + SOCKETS_G(last_error) = errno; + php_error(E_WARNING, "%s() Unable to create socket [%d]: %s", + get_active_function_name(TSRMLS_C), errno, +php_strerror(errno)); efree(php_sock); RETURN_FALSE; } @@ -912,6 +927,8 @@ switch(php_sock->type) { case AF_INET: if (ZEND_NUM_ARGS() != 3) { + php_error(E_WARNING, "%s() Socket of type AF_INET +requires 3 arguments", + get_active_function_name(TSRMLS_C)); RETURN_FALSE; } @@ -932,6 +949,8 @@ break; default: + php_error(E_WARNING, "%s() Unsupported socket type %d", + get_active_function_name(TSRMLS_C), +php_sock->type); RETURN_FALSE; } @@ -1370,6 +1389,8 @@ break; default: + php_error(E_WARNING, "%s() Unsupported socket type %d", + get_active_function_name(TSRMLS_C), +php_sock->type); RETURN_FALSE; } @@ -1420,6 +1441,8 @@ break; default: + php_error(E_WARNING, "%s() Unsupported socket type %d", + get_active_function_name(TSRMLS_C), +php_sock->type); RETURN_FALSE; } @@ -1565,6 +1588,8 @@ } default: + php_error(E_WARNING, "%s() Unsupported address family %d", + get_active_function_name(TSRMLS_C), sa->sa_family); RETURN_FALSE; } } @@ -1649,6 +1674,8 @@ } default: + php_error(E_WARNING, "%s() Unsupported address family %d", + get_active_function_name(TSRMLS_C), +sa.sa_family); RETURN_FALSE; } } @@ -1895,19 +1922,19 @@ Returns the last error on the socket */ PHP_FUNCTION(socket_last_error) { - zval *arg1; + zval *arg1 = NULL; php_socket *php_sock; - int error; - if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "r", &arg1) == FAILURE) - return; - - ZEND_FETCH_RESOURCE(php_sock, php_socket*, &arg1, -1, le_socket_name, le_socket); - - error = php_sock->error; + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|r", &arg1) == FAILURE) + return; - RETURN_LONG(error); -} + if (arg1) { + ZEND_FETCH_RESOURCE(php_sock, php_socket*, &arg1, -1, le_socket_name, +le_socket); + RETVAL_LONG(php_sock->error); + } else { + RETVAL_LONG(SOCKETS_G(last_error)); + } +} /* }}} */ /* {{{ proto void socket_clear_error(resource socket)
-- PHP Development Mailing List <http://www.php.net/> To unsubscribe, visit: http://www.php.net/unsub.php