diff options
Diffstat (limited to 'doc/socket.n')
| -rw-r--r-- | doc/socket.n | 42 | 
1 files changed, 29 insertions, 13 deletions
| diff --git a/doc/socket.n b/doc/socket.n index 0e427ed..b7a4a45 100644 --- a/doc/socket.n +++ b/doc/socket.n @@ -5,8 +5,8 @@  '\" See the file "license.terms" for information on usage and redistribution  '\" of this file, and for a DISCLAIMER OF ALL WARRANTIES.  '\" -.so man.macros  .TH socket n 8.6 Tcl "Tcl Built-In Commands" +.so man.macros  .BS  '\" Note:  do not modify the .SH NAME line immediately below!  .SH NAME @@ -71,22 +71,32 @@ port number will be chosen at random by the system software.  This option will cause the client socket to be connected  asynchronously. This means that the socket will be created immediately  but may not yet be connected to the server, when the call to -\fBsocket\fR returns. When a \fBgets\fR or \fBflush\fR is done on the -socket before the connection attempt succeeds or fails, if the socket -is in blocking mode, the operation will wait until the connection is -completed or fails. If the socket is in nonblocking mode and a -\fBgets\fR or \fBflush\fR is done on the socket before the connection -attempt succeeds or fails, the operation returns immediately and +\fBsocket\fR returns. +.RS +.PP +When a \fBgets\fR or \fBflush\fR is done on the socket before the +connection attempt succeeds or fails, if the socket is in blocking +mode, the operation will wait until the connection is completed or +fails. If the socket is in nonblocking mode and a \fBgets\fR or +\fBflush\fR is done on the socket before the connection attempt +succeeds or fails, the operation returns immediately and  \fBfblocked\fR on the socket returns 1. Synchronous client sockets may  be switched (after they have connected) to operating in asynchronous  mode using: -.RS  .PP  .CS  \fBchan configure \fIchan \fB\-blocking 0\fR  .CE  .PP -See the \fBchan\fR \fBconfigure\fR command for more details. +See the \fBchan configure\fR command for more details. +.PP +The Tcl event loop should be running while an asynchronous connection +is in progress, because it may have to do several connection attempts +in the background. Running the event loop also allows you to set up a +writable channel event on the socket to get notified when the +asynchronous connection has succeeded or failed. See the \fBvwait\fR +and the \fBchan\fR commands for more details on the event loop and +channel events.  .RE  .SH "SERVER SOCKETS"  .PP @@ -146,6 +156,11 @@ This option gets the current error status of the given socket.  This  is useful when you need to determine if an asynchronous connect  operation succeeded.  If there was an error, the error message is  returned.  If there was no error, an empty string is returned. +.RS +.PP +Note that the error status is reset by the read operation; this mimics +the underlying getsockopt(SO_ERROR) call. +.RE  .TP  \fB\-sockname\fR  . @@ -154,14 +169,15 @@ client connects to a server socket) this option returns a list of  three elements, the address, the host name and the port number for the  socket. If the host name cannot be computed, the second element is  identical to the address, the first element of the list. - +.RS +.PP  For server sockets this option returns a list of a multiple of three  elements each group of which have the same meaning as described  above. The list contains more than one group when the server socket -was created without \fB-myaddr\fR or with the argument to -\fB-myaddr\fR being a domain name that resolves multiple IP addresses +was created without \fB\-myaddr\fR or with the argument to +\fB\-myaddr\fR being a domain name that resolves multiple IP addresses  that are local to the invoking host. - +.RE  .TP  \fB\-peername\fR  . | 
