Fixed a couple of bugs: getargs doesn't use % escapes, and seconds
must be set after timeout is initialized.
diff --git a/Modules/selectmodule.c b/Modules/selectmodule.c
index 77ea61c..2cae7f4 100644
--- a/Modules/selectmodule.c
+++ b/Modules/selectmodule.c
@@ -125,12 +125,12 @@
/* Get args. Looks funny because of optional timeout argument */
if ( getargs(args, "(OOOO)", &ifdlist, &ofdlist, &efdlist, &tout) ) {
- seconds = (int)timeout;
if (tout == None)
tvp = (struct timeval *)0;
else {
- if (!getargs(tout, "%d;timeout must be float or None", &timeout))
+ if (!getargs(tout, "d;timeout must be float or None", &timeout))
return NULL;
+ seconds = (int)timeout;
timeout = timeout - (double)seconds;
tv.tv_sec = seconds;
tv.tv_usec = (int)(timeout*1000000.0);