d71b9a7269
2.4.4 => 2.4.8 2.5.2 => 2.5.4 2.6 => 2.6.1 Python 2.4 and 2.5 lose their build knobs to match 2.6. Removes no longer needed Python 2.5 security patches backported from the release25-maint SVN branch. Remove the -bz2 subpackage from all three versions. It is silly to make a subpackage to avoid depending on something tiny and compatibly licensed. Python 2.4 and 2.5 lose their -expat subpackages; expat has been in base for some time. Python 2.5 loses its sqlite subpackge. Again, sqlite is tiny, compatibly licensed and is depended upon by more and more applications. This brings it into line with the 2.6 version. Rework all three version's handling of setup.py. Rather than regex replacing LOCALBASE and X11BASE into setup.py post-configure, these are passed in though environment variables. Will save hours of frustrated cursing familiar to anyone who has accidently used the update-patches target after configure and had to go back and redo all the substitutions. Rework the patching of setup.py for 2.4 and 2.5 to be more like what we do for 2.6. I.e. keep the diff minimal and avoid deleting huge blocks of code, so the diff has a chance of applying without massive hand-editing each patch release. Fix .py paths in installed .pyc files (patch from eric@) feedback from several, particularly eric@, ajacoutot@ and Ingo Schwarze; "get it in" ajacoutot@
42 lines
1.2 KiB
Plaintext
42 lines
1.2 KiB
Plaintext
$OpenBSD: patch-Modules_socketmodule_c,v 1.5 2009/01/01 21:03:27 djm Exp $
|
|
--- Modules/socketmodule.c.orig Wed Oct 11 02:20:41 2006
|
|
+++ Modules/socketmodule.c Fri Dec 26 12:27:16 2008
|
|
@@ -72,9 +72,6 @@ Local naming conventions:
|
|
|
|
#include "Python.h"
|
|
|
|
-#undef MAX
|
|
-#define MAX(x, y) ((x) < (y) ? (y) : (x))
|
|
-
|
|
/* Socket object documentation */
|
|
PyDoc_STRVAR(sock_doc,
|
|
"socket([family[, type[, proto]]]) -> socket object\n\
|
|
@@ -1807,10 +1804,15 @@ internal_connect(PySocketSockObject *s, struct sockadd
|
|
|
|
if (s->sock_timeout > 0.0) {
|
|
if (res < 0 && errno == EINPROGRESS && IS_SELECTABLE(s)) {
|
|
+ socklen_t res_size = sizeof res;
|
|
+ int save_errno;
|
|
+
|
|
timeout = internal_select(s, 1);
|
|
- res = connect(s->sock_fd, addr, addrlen);
|
|
- if (res < 0 && errno == EISCONN)
|
|
- res = 0;
|
|
+ save_errno = errno;
|
|
+ (void)getsockopt(s->sock_fd, SOL_SOCKET, SO_ERROR,
|
|
+ &res, &res_size);
|
|
+ errno = save_errno;
|
|
+ res = res ? -1 : 0;
|
|
}
|
|
}
|
|
|
|
@@ -3307,7 +3309,7 @@ socket_inet_aton(PyObject *self, PyObject *args)
|
|
|
|
#if !defined(HAVE_INET_ATON) || defined(USE_INET_ATON_WEAKLINK)
|
|
/* Have to use inet_addr() instead */
|
|
- unsigned long packed_addr;
|
|
+ int packed_addr;
|
|
#endif
|
|
char *ip_addr;
|
|
|