newLISP Fan Club

Forum => newLISP in the real world => Topic started by: zool on June 11, 2005, 04:26:19 PM

Title: non-blocking net-connect for TCP
Post by: zool on June 11, 2005, 04:26:19 PM
Hi!



I'd find it very useful to have a parameter for net-connect to make that call non-blocking. I've built a simple polling loop and and a socket class to handle multiple connections in one thread, but when it comes to outgoing connections they block until they're connected. This is a bit disappointing, especially since I've made a single exe of newlisp and freewrap, cause then a blocking call also blocks the GUI. (I might just release that little hack when I've cleaned up the code.)



Anyone know of a workaround for this? Is it hard to implement? Lutz? And yeah, thanks for a great scripting tool!
Title:
Post by: pjot on June 11, 2005, 04:38:38 PM
You can use (net-select) or (net-peek) to check if data is available on the socket to read.



The (net-connect) statement is not blocking; if there is nothing at the other side it will just return a nil.



Peter
Title:
Post by: zool on June 13, 2005, 03:53:32 PM
Peter:



Try this: (net-connect "192.168.0.56" 80) (I just assume you don't have anybody on that intranet address).



It's not really non-blocking. It just appears to be that way when you connect to a server that send a RST (we're talking TCP here). If there's nothing on the other end, only the timeout stops the connection attempt. Or is there a parameter that I've forgotten? I wish you where right.
Title:
Post by: Lutz on June 13, 2005, 08:06:20 PM
'net-connect' is based on the libc sockets call connect() which will block until a connection is made or a timeout occurs.



When 'net-connect' fails it returns 'nil' and you can use the newLISP function (sys-error) to consult the internal errno of your OS. Some value will be returned which you can lookup in your platforms /usr/incluce/sys/errno.h.



errno.h contains a large list of possible error numbers for different i/o situations. The entries important for 'net-connect' you can lookup in the unix man page of your platform doing a:



man connect



The newLISP (net-error) will also be set and return "Connection failed"



Lutz
Title:
Post by: pjot on June 13, 2005, 11:08:11 PM
Oops, you appear to be are right there! I tried to connect to a non-existing IP address in my IP segment, this returns a nil very fast.



But indeed, if I try to reach a non-pingable IP address outside my current network, then it takes a long time to connect.



Also, if I try to 'ping' such an address, even the 'ping' does not return.



I guess we're facing the limitations of Unix TCP networking.



Peter
Title:
Post by: newdep on June 14, 2005, 06:11:47 AM
Its it possible though to do a net-connect with a timeout, but thats

a change in the C code. I know its possible to intercept the default

timeout value in Unix and windows...  



Norman.
Title:
Post by: Lutz on June 14, 2005, 08:32:25 AM
setsockopt() with either SO_SNDTIMEO or SO_RCVTIMEO both do not work for connect() but perhaps you could try on the unix command line:



sysctl -a



to see all options and look if you find some option to change the UNIX internal timeout value.



Lutz
Title:
Post by: zool on June 15, 2005, 12:56:19 PM
What are the options for windows then?