diff options
| author | harald.oehlmann@elmicron.de <oehhar> | 2014-09-26 12:05:30 (GMT) |
|---|---|---|
| committer | harald.oehlmann@elmicron.de <oehhar> | 2014-09-26 12:05:30 (GMT) |
| commit | 4a202f4e68eb7a229138f90a42e5731c89b82c06 (patch) | |
| tree | 35d0f303ead76ff1561141cdab4bddf7e94f4615 /unix/tclUnixSock.c | |
| parent | 2d826a696acf94c7c54e9649ea0a7ff1859b2f08 (diff) | |
| download | tcl-4a202f4e68eb7a229138f90a42e5731c89b82c06.zip tcl-4a202f4e68eb7a229138f90a42e5731c89b82c06.tar.gz tcl-4a202f4e68eb7a229138f90a42e5731c89b82c06.tar.bz2 | |
Implemented tip-427: socket fconfigure option -connecting plus no -peername,-sockname when still connecting.
Diffstat (limited to 'unix/tclUnixSock.c')
| -rw-r--r-- | unix/tclUnixSock.c | 34 |
1 files changed, 27 insertions, 7 deletions
diff --git a/unix/tclUnixSock.c b/unix/tclUnixSock.c index 96700ce..ca25435 100644 --- a/unix/tclUnixSock.c +++ b/unix/tclUnixSock.c @@ -823,7 +823,20 @@ TcpGetOptionProc( address peername; socklen_t size = sizeof(peername); - if (getpeername(statePtr->fds.fd, &peername.sa, &size) >= 0) { + if ( (statePtr->flags & TCP_ASYNC_CONNECT) ) { + /* + * In async connect output an empty string + */ + if (len == 0) { + Tcl_DStringAppendElement(dsPtr, "-peername"); + Tcl_DStringAppendElement(dsPtr, ""); + } else { + return TCL_OK; + } + } else if (getpeername(statePtr->fds.fd, &peername.sa, &size) >= 0) { + /* + * Peername fetch succeeded - output list + */ if (len == 0) { Tcl_DStringAppendElement(dsPtr, "-peername"); Tcl_DStringStartSublist(dsPtr); @@ -863,11 +876,18 @@ TcpGetOptionProc( Tcl_DStringAppendElement(dsPtr, "-sockname"); Tcl_DStringStartSublist(dsPtr); } - for (fds = &statePtr->fds; fds != NULL; fds = fds->next) { - size = sizeof(sockname); - if (getsockname(fds->fd, &(sockname.sa), &size) >= 0) { - found = 1; - TcpHostPortList(interp, dsPtr, sockname, size); + if ( (statePtr->flags & TCP_ASYNC_CONNECT) ) { + /* + * In async connect output an empty string + */ + found = 1; + } else { + for (fds = &statePtr->fds; fds != NULL; fds = fds->next) { + size = sizeof(sockname); + if (getsockname(fds->fd, &(sockname.sa), &size) >= 0) { + found = 1; + TcpHostPortList(interp, dsPtr, sockname, size); + } } } if (found) { @@ -885,7 +905,7 @@ TcpGetOptionProc( } if (len > 0) { - return Tcl_BadChannelOption(interp, optionName, "peername sockname"); + return Tcl_BadChannelOption(interp, optionName, "connecting peername sockname"); } return TCL_OK; |
