]> granicus.if.org Git - python/commitdiff
issue #9090 : Limit the fix to windows since getting a portable simple
authorKristján Valur Jónsson <sweskman@gmail.com>
Tue, 19 Mar 2013 20:01:05 +0000 (13:01 -0700)
committerKristján Valur Jónsson <sweskman@gmail.com>
Tue, 19 Mar 2013 20:01:05 +0000 (13:01 -0700)
time function on non-windows isn't quite simple.

Modules/socketmodule.c

index 4aa2db8f9ca3e2ae21755040a0a8df06c6166711..76f087b71516c844b8bf18d4180dfcc48085555b 100644 (file)
@@ -751,6 +751,14 @@ internal_select(PySocketSockObject *s, int writing)
     }
     END_SELECT_LOOP(s)
 */
+#ifdef _WIN32
+/* _PyTime_floattime is exported from timemodule.c which is a builtin on windows
+ * but not on linux.  The problem we are fixing is mostly a windows problem so
+ * we leave it at that.
+ */
+#define HAVE_PYTIME_FLOATTIME
+#endif
+#ifdef HAVE_PYTIME_FLOATTIME
 PyAPI_FUNC(double) _PyTime_floattime(void); /* defined in timemodule.c */
 #define BEGIN_SELECT_LOOP(s) \
     { \
@@ -768,7 +776,18 @@ PyAPI_FUNC(double) _PyTime_floattime(void); /* defined in timemodule.c */
                 break; \
             interval = deadline - _PyTime_floattime(); \
         } \
-    } \
+    }
+#else
+#define BEGIN_SELECT_LOOP(s) \
+    { \
+        double interval = s->sock_timeout; \
+        do { \
+            errno = 0; \
+
+#define END_SELECT_LOOP(s) \
+        } while(0); \
+    }
+#endif
 
 /* Initialize a new socket object. */