FreeBSD Bugzilla – Attachment 153783 Details for
Bug 192511
lang/python27: Fix build with LibreSSL
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Help
|
New Account
|
Log In
Remember
[x]
|
Forgot Password
Login:
[x]
[patch]
svn diff for lang/python27
patch-lang_python27-libressl (text/plain), 31.11 KB, created by
Bernard Spil
on 2015-03-04 15:41:06 UTC
(
hide
)
Description:
svn diff for lang/python27
Filename:
MIME Type:
Creator:
Bernard Spil
Created:
2015-03-04 15:41:06 UTC
Size:
31.11 KB
patch
obsolete
>Index: Makefile >=================================================================== >--- Makefile (revision 380439) >+++ Makefile (working copy) >@@ -105,6 +105,10 @@ > PLIST_SUB+= NO_NIS="" > .endif > >+.if defined(WITH_OPENSSL_PORT) >+CONFIGURE_ARGS+= CPPFLAGS=-I/usr/local/include LDFLAGS=-L/usr/local/lib >+.endif >+ > post-patch: > @${REINPLACE_CMD} -e \ > 's,/usr/doc/python-docs-,${PREFIX}/share/doc/python,g' \ >Index: files/patch-Doc__library__fcntl.rst >=================================================================== >--- files/patch-Doc__library__fcntl.rst (revision 380439) >+++ files/patch-Doc__library__fcntl.rst (working copy) >@@ -1,10 +0,0 @@ >---- ./Doc/library/fcntl.rst.orig 2014-07-03 21:53:41.473098625 +1000 >-+++ ./Doc/library/fcntl.rst 2014-07-03 21:54:04.342833056 +1000 >-@@ -50,7 +50,6 @@ >- operations are typically defined in the library module :mod:`termios` and the >- argument handling is even more complicated. >- >-- The op parameter is limited to values that can fit in 32-bits. >- Additional constants of interest for use as the *op* argument can be >- found in the :mod:`termios` module, under the same names as used in >- the relevant C header files. >Index: files/patch-Doc_library_fcntl.rst >=================================================================== >--- files/patch-Doc_library_fcntl.rst (revision 0) >+++ files/patch-Doc_library_fcntl.rst (working copy) >@@ -0,0 +1,10 @@ >+--- Doc/library/fcntl.rst.orig 2014-12-10 15:59:27 UTC >++++ Doc/library/fcntl.rst >+@@ -50,7 +50,6 @@ The module defines the following functio >+ operations are typically defined in the library module :mod:`termios` and the >+ argument handling is even more complicated. >+ >+- The op parameter is limited to values that can fit in 32-bits. >+ Additional constants of interest for use as the *op* argument can be >+ found in the :mod:`termios` module, under the same names as used in >+ the relevant C header files. > >Property changes on: files/patch-Doc_library_fcntl.rst >___________________________________________________________________ >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Index: files/patch-Lib__distutils__unixccompiler.py >=================================================================== >--- files/patch-Lib__distutils__unixccompiler.py (revision 380439) >+++ files/patch-Lib__distutils__unixccompiler.py (working copy) >@@ -1,15 +0,0 @@ >-# Description: Some python extensions can't be compiled with clang 3.4 >-# Issue ID: http://bugs.python.org/issue20767 >-# Submitted by: antoine >- >---- ./Lib/distutils/unixccompiler.py.orig 2013-11-10 07:36:40.000000000 +0000 >-+++ ./Lib/distutils/unixccompiler.py 2014-02-19 15:41:48.000000000 +0000 >-@@ -228,6 +228,8 @@ >- if sys.platform[:6] == "darwin": >- # MacOSX's linker doesn't understand the -R flag at all >- return "-L" + dir >-+ elif sys.platform[:7] == "freebsd": >-+ return "-Wl,-rpath=" + dir >- elif sys.platform[:5] == "hp-ux": >- if self._is_gcc(compiler): >- return ["-Wl,+s", "-L" + dir] >Index: files/patch-Lib_distutils_command_build__scripts.py >=================================================================== >--- files/patch-Lib_distutils_command_build__scripts.py (revision 0) >+++ files/patch-Lib_distutils_command_build__scripts.py (working copy) >@@ -0,0 +1,12 @@ >+--- Lib/distutils/command/build_scripts.py.orig 2014-12-10 15:59:34 UTC >++++ Lib/distutils/command/build_scripts.py >+@@ -126,6 +126,9 @@ class build_scripts (Command): >+ file, oldmode, newmode) >+ os.chmod(file, newmode) >+ >++ # XXX should we modify self.outfiles? >++ return outfiles >++ >+ # copy_scripts () >+ >+ # class build_scripts > >Property changes on: files/patch-Lib_distutils_command_build__scripts.py >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-Lib_distutils_command_build_scripts.py >=================================================================== >--- files/patch-Lib_distutils_command_build_scripts.py (revision 380439) >+++ files/patch-Lib_distutils_command_build_scripts.py (working copy) >@@ -1,17 +0,0 @@ >-# Description: A non-invasive partial backport of the Python3 distutils behaviour. >-# This allows Python's scripts to be properly suffixed (similar to Python 3.x) on >-# installation. >-# Submitted by: mva >- >---- Lib/distutils/command/build_scripts.py.orig 2014-07-26 11:52:20.000000000 +0200 >-+++ Lib/distutils/command/build_scripts.py 2014-07-26 11:52:56.000000000 +0200 >-@@ -126,6 +126,9 @@ >- file, oldmode, newmode) >- os.chmod(file, newmode) >- >-+ # XXX should we modify self.outfiles? >-+ return outfiles >-+ >- # copy_scripts () >- >- # class build_scripts >Index: files/patch-Lib_distutils_unixccompiler.py >=================================================================== >--- files/patch-Lib_distutils_unixccompiler.py (revision 0) >+++ files/patch-Lib_distutils_unixccompiler.py (working copy) >@@ -0,0 +1,15 @@ >+# Description: Some python extensions can't be compiled with clang 3.4 >+# Issue ID: http://bugs.python.org/issue20767 >+# Submitted by: antoine >+ >+--- Lib/distutils/unixccompiler.py.orig 2014-12-10 15:59:34 UTC >++++ Lib/distutils/unixccompiler.py >+@@ -228,6 +228,8 @@ class UnixCCompiler(CCompiler): >+ if sys.platform[:6] == "darwin": >+ # MacOSX's linker doesn't understand the -R flag at all >+ return "-L" + dir >++ elif sys.platform[:7] == "freebsd": >++ return "-Wl,-rpath=" + dir >+ elif sys.platform[:5] == "hp-ux": >+ if self._is_gcc(compiler): >+ return ["-Wl,+s", "-L" + dir] > >Property changes on: files/patch-Lib_distutils_unixccompiler.py >___________________________________________________________________ >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Index: files/patch-Lib_socket.py >=================================================================== >--- files/patch-Lib_socket.py (revision 0) >+++ files/patch-Lib_socket.py (working copy) >@@ -0,0 +1,25 @@ >+--- Lib/socket.py.orig 2014-12-10 15:59:40 UTC >++++ Lib/socket.py >+@@ -67,7 +67,6 @@ else: >+ from _ssl import SSLError as sslerror >+ from _ssl import \ >+ RAND_add, \ >+- RAND_egd, \ >+ RAND_status, \ >+ SSL_ERROR_ZERO_RETURN, \ >+ SSL_ERROR_WANT_READ, \ >+@@ -78,6 +77,14 @@ else: >+ SSL_ERROR_WANT_CONNECT, \ >+ SSL_ERROR_EOF, \ >+ SSL_ERROR_INVALID_ERROR_CODE >++### Fix build with LibreSSL (does not have RAND_egd) >++### PR192511, http://bugs.python.org/issue21356 >++ try: >++ from _ssl import RAND_egd >++ # LibreSSL does not provide RAND_egd >++ except ImportError: >++ pass >++### End PR192511 >+ >+ import os, sys, warnings >+ > >Property changes on: files/patch-Lib_socket.py >___________________________________________________________________ >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Index: files/patch-Lib_ssl.py >=================================================================== >--- files/patch-Lib_ssl.py (revision 0) >+++ files/patch-Lib_ssl.py (working copy) >@@ -0,0 +1,19 @@ >+--- Lib/ssl.py.orig 2014-12-10 15:59:40 UTC >++++ Lib/ssl.py >+@@ -106,7 +106,15 @@ from _ssl import CERT_NONE, CERT_OPTIONA >+ from _ssl import (VERIFY_DEFAULT, VERIFY_CRL_CHECK_LEAF, VERIFY_CRL_CHECK_CHAIN, >+ VERIFY_X509_STRICT) >+ from _ssl import txt2obj as _txt2obj, nid2obj as _nid2obj >+-from _ssl import RAND_status, RAND_egd, RAND_add >++### Fix build with LibreSSL (does not have RAND_egd) >++### PR192511, http://bugs.python.org/issue21356 >++from _ssl import RAND_status, RAND_add >++try: >++ from _ssl import RAND_egd >++except ImportError: >++ # LibreSSL does not provide RAND_egd >++ pass >++### End PR192511 >+ >+ def _import_symbols(prefix): >+ for n in dir(_ssl): > >Property changes on: files/patch-Lib_ssl.py >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-Lib_test_test__ssl.py >=================================================================== >--- files/patch-Lib_test_test__ssl.py (revision 0) >+++ files/patch-Lib_test_test__ssl.py (working copy) >@@ -0,0 +1,17 @@ >+--- Lib/test/test_ssl.py.orig 2014-12-10 15:59:47 UTC >++++ Lib/test/test_ssl.py >+@@ -169,8 +169,12 @@ class BasicSocketTests(unittest.TestCase >+ sys.stdout.write("\n RAND_status is %d (%s)\n" >+ % (v, (v and "sufficient randomness") or >+ "insufficient randomness")) >+- self.assertRaises(TypeError, ssl.RAND_egd, 1) >+- self.assertRaises(TypeError, ssl.RAND_egd, 'foo', 1) >++### Fix build with LibreSSL (does not have RAND_egd) >++### PR192511, http://bugs.python.org/issue21356 >++ if hasattr(ssl, 'RAND_egd'): >++ self.assertRaises(TypeError, ssl.RAND_egd, 1) >++ self.assertRaises(TypeError, ssl.RAND_egd, 'foo', 1) >++### End PR192511 >+ ssl.RAND_add("this is a random string", 75.0) >+ >+ def test_parse_cert(self): > >Property changes on: files/patch-Lib_test_test__ssl.py >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-Modules-_ctypes-libffi-configure >=================================================================== >--- files/patch-Modules-_ctypes-libffi-configure (revision 380439) >+++ files/patch-Modules-_ctypes-libffi-configure (working copy) >@@ -1,11 +0,0 @@ >---- Modules/_ctypes/libffi/configure.orig 2014-12-16 08:10:12.000000000 +0100 >-+++ Modules/_ctypes/libffi/configure 2014-12-16 08:10:40.000000000 +0100 >-@@ -7526,7 +7526,7 @@ >- rm -rf conftest* >- ;; >- >--x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ >-+amd64-*-freebsd*|x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ >- s390*-*linux*|s390*-*tpf*|sparc*-*linux*) >- # Find out what ABI is being produced by ac_compile, and set linker >- # options accordingly. Note that the listed cases only cover the >Index: files/patch-Modules___ctypes__libffi__src__arm__ffi.c >=================================================================== >--- files/patch-Modules___ctypes__libffi__src__arm__ffi.c (revision 380439) >+++ files/patch-Modules___ctypes__libffi__src__arm__ffi.c (working copy) >@@ -1,36 +0,0 @@ >-# Description: Fix _ctypes abort on import for FreeBSD/ARM. This is an issue >-# for anything !apple that is using the libcompiler_rt provided by clang on arm >-# PR: ports/149167 ports/184517 >-# Patch by: cognet@ (to be upstreamed @ LLVM) >- >---- ./Modules/_ctypes/libffi/src/arm/ffi.c.orig 2013-11-10 18:36:41.000000000 +1100 >-+++ ./Modules/_ctypes/libffi/src/arm/ffi.c 2013-12-03 18:05:51.461078888 +1100 >-@@ -33,6 +33,11 @@ >- >- #include <stdlib.h> >- >-+#if defined(__FreeBSD__) && defined(__arm__) >-+#include <sys/types.h> >-+#include <machine/sysarch.h> >-+#endif >-+ >- /* Forward declares. */ >- static int vfp_type_p (ffi_type *); >- static void layout_vfp_args (ffi_cif *); >-@@ -582,6 +587,16 @@ >- >- #else >- >-+#if defined(__FreeBSD__) && defined(__arm__) >-+#define __clear_cache(start, end) do { \ >-+ struct arm_sync_icache_args ua; \ >-+ \ >-+ ua.addr = (uintptr_t)(start); \ >-+ ua.len = (char *)(end) - (char *)start; \ >-+ sysarch(ARM_SYNC_ICACHE, &ua); \ >-+ } while (0); >-+#endif >-+ >- #define FFI_INIT_TRAMPOLINE(TRAMP,FUN,CTX) \ >- ({ unsigned char *__tramp = (unsigned char*)(TRAMP); \ >- unsigned int __fun = (unsigned int)(FUN); \ >Index: files/patch-Modules___ctypes_libffi_configure >=================================================================== >--- files/patch-Modules___ctypes_libffi_configure (revision 0) >+++ files/patch-Modules___ctypes_libffi_configure (working copy) >@@ -0,0 +1,11 @@ >+--- Modules/_ctypes/libffi/configure.orig 2014-12-10 15:59:51 UTC >++++ Modules/_ctypes/libffi/configure >+@@ -7526,7 +7526,7 @@ mips64*-*linux*) >+ rm -rf conftest* >+ ;; >+ >+-x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ >++amd64-*-freebsd*|x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ >+ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) >+ # Find out what ABI is being produced by ac_compile, and set linker >+ # options accordingly. Note that the listed cases only cover the > >Property changes on: files/patch-Modules___ctypes_libffi_configure >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-Modules___ctypes_libffi_src_arm_ffi.c >=================================================================== >--- files/patch-Modules___ctypes_libffi_src_arm_ffi.c (revision 0) >+++ files/patch-Modules___ctypes_libffi_src_arm_ffi.c (working copy) >@@ -0,0 +1,36 @@ >+# Description: Fix _ctypes abort on import for FreeBSD/ARM. This is an issue >+# for anything !apple that is using the libcompiler_rt provided by clang on arm >+# PR: ports/149167 ports/184517 >+# Patch by: cognet@ (to be upstreamed @ LLVM) >+ >+--- ./Modules/_ctypes/libffi/src/arm/ffi.c.orig 2013-11-10 18:36:41.000000000 +1100 >++++ ./Modules/_ctypes/libffi/src/arm/ffi.c 2013-12-03 18:05:51.461078888 +1100 >+@@ -33,6 +33,11 @@ >+ >+ #include <stdlib.h> >+ >++#if defined(__FreeBSD__) && defined(__arm__) >++#include <sys/types.h> >++#include <machine/sysarch.h> >++#endif >++ >+ /* Forward declares. */ >+ static int vfp_type_p (ffi_type *); >+ static void layout_vfp_args (ffi_cif *); >+@@ -582,6 +587,16 @@ >+ >+ #else >+ >++#if defined(__FreeBSD__) && defined(__arm__) >++#define __clear_cache(start, end) do { \ >++ struct arm_sync_icache_args ua; \ >++ \ >++ ua.addr = (uintptr_t)(start); \ >++ ua.len = (char *)(end) - (char *)start; \ >++ sysarch(ARM_SYNC_ICACHE, &ua); \ >++ } while (0); >++#endif >++ >+ #define FFI_INIT_TRAMPOLINE(TRAMP,FUN,CTX) \ >+ ({ unsigned char *__tramp = (unsigned char*)(TRAMP); \ >+ unsigned int __fun = (unsigned int)(FUN); \ > >Property changes on: files/patch-Modules___ctypes_libffi_src_arm_ffi.c >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-Modules___ssl.c >=================================================================== >--- files/patch-Modules___ssl.c (revision 0) >+++ files/patch-Modules___ssl.c (working copy) >@@ -0,0 +1,35 @@ >+--- Modules/_ssl.c.orig 2014-12-10 15:59:53 UTC >++++ Modules/_ssl.c >+@@ -3301,6 +3301,9 @@ Returns 1 if the OpenSSL PRNG has been s >+ It is necessary to seed the PRNG with RAND_add() on some platforms before\n\ >+ using the ssl() function."); >+ >++/* ### Fix build with LibreSSL (does not have RAND_egd) >++ ### PR192511, http://bugs.python.org/issue21356 */ >++#ifdef HAVE_RAND_EGD >+ static PyObject * >+ PySSL_RAND_egd(PyObject *self, PyObject *arg) >+ { >+@@ -3326,6 +3329,8 @@ PyDoc_STRVAR(PySSL_RAND_egd_doc, >+ Queries the entropy gather daemon (EGD) on the socket named by 'path'.\n\ >+ Returns number of bytes read. Raises SSLError if connection to EGD\n\ >+ fails or if it does not provide enough data to seed PRNG."); >++#endif /* HAVE_RAND_EGD */ >++/* ### End PR192511 */ >+ >+ #endif /* HAVE_OPENSSL_RAND */ >+ >+@@ -3720,8 +3725,13 @@ static PyMethodDef PySSL_methods[] = { >+ #ifdef HAVE_OPENSSL_RAND >+ {"RAND_add", PySSL_RAND_add, METH_VARARGS, >+ PySSL_RAND_add_doc}, >++/* ### Fix build with LibreSSL (does not have RAND_egd) >++ ### PR192511, http://bugs.python.org/issue21356 */ >++#ifdef HAVE_RAND_EGD >+ {"RAND_egd", PySSL_RAND_egd, METH_VARARGS, >+ PySSL_RAND_egd_doc}, >++#endif /* HAVE_RAND_EGD */ >++/* ### End PR192551 */ >+ {"RAND_status", (PyCFunction)PySSL_RAND_status, METH_NOARGS, >+ PySSL_RAND_status_doc}, >+ #endif > >Property changes on: files/patch-Modules___ssl.c >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-Modules__fcntlmodule.c >=================================================================== >--- files/patch-Modules__fcntlmodule.c (revision 380439) >+++ files/patch-Modules__fcntlmodule.c (working copy) >@@ -1,53 +0,0 @@ >---- ./Modules/fcntlmodule.c.orig 2014-07-03 21:57:10.429953240 +1000 >-+++ ./Modules/fcntlmodule.c 2014-07-03 21:59:36.517210444 +1000 >-@@ -98,20 +98,15 @@ >- { >- #define IOCTL_BUFSZ 1024 >- int fd; >-- /* In PyArg_ParseTuple below, we use the unsigned non-checked 'I' >-+ /* In PyArg_ParseTuple below, we use the unsigned non-checked 'k' >- format for the 'code' parameter because Python turns 0x8000000 >- into either a large positive number (PyLong or PyInt on 64-bit >- platforms) or a negative number on others (32-bit PyInt) >- whereas the system expects it to be a 32bit bit field value >- regardless of it being passed as an int or unsigned long on >-- various platforms. See the termios.TIOCSWINSZ constant across >-- platforms for an example of this. >-- >-- If any of the 64bit platforms ever decide to use more than 32bits >-- in their unsigned long ioctl codes this will break and need >-- special casing based on the platform being built on. >-+ various platforms. >- */ >-- unsigned int code; >-+ unsigned long code; >- int arg; >- int ret; >- char *str; >-@@ -119,7 +114,7 @@ >- int mutate_arg = 1; >- char buf[IOCTL_BUFSZ+1]; /* argument plus NUL byte */ >- >-- if (PyArg_ParseTuple(args, "O&Iw#|i:ioctl", >-+ if (PyArg_ParseTuple(args, "O&kw#|i:ioctl", >- conv_descriptor, &fd, &code, >- &str, &len, &mutate_arg)) { >- char *arg; >-@@ -170,7 +165,7 @@ >- } >- >- PyErr_Clear(); >-- if (PyArg_ParseTuple(args, "O&Is#:ioctl", >-+ if (PyArg_ParseTuple(args, "O&ks#:ioctl", >- conv_descriptor, &fd, &code, &str, &len)) { >- if (len > IOCTL_BUFSZ) { >- PyErr_SetString(PyExc_ValueError, >-@@ -192,7 +187,7 @@ >- PyErr_Clear(); >- arg = 0; >- if (!PyArg_ParseTuple(args, >-- "O&I|i;ioctl requires a file or file descriptor," >-+ "O&k|i;ioctl requires a file or file descriptor," >- " an integer and optionally an integer or buffer argument", >- conv_descriptor, &fd, &code, &arg)) { >- return NULL; >Index: files/patch-Modules_fcntlmodule.c >=================================================================== >--- files/patch-Modules_fcntlmodule.c (revision 0) >+++ files/patch-Modules_fcntlmodule.c (working copy) >@@ -0,0 +1,53 @@ >+--- Modules/fcntlmodule.c.orig 2014-12-10 15:59:54 UTC >++++ Modules/fcntlmodule.c >+@@ -98,20 +98,15 @@ fcntl_ioctl(PyObject *self, PyObject *ar >+ { >+ #define IOCTL_BUFSZ 1024 >+ int fd; >+- /* In PyArg_ParseTuple below, we use the unsigned non-checked 'I' >++ /* In PyArg_ParseTuple below, we use the unsigned non-checked 'k' >+ format for the 'code' parameter because Python turns 0x8000000 >+ into either a large positive number (PyLong or PyInt on 64-bit >+ platforms) or a negative number on others (32-bit PyInt) >+ whereas the system expects it to be a 32bit bit field value >+ regardless of it being passed as an int or unsigned long on >+- various platforms. See the termios.TIOCSWINSZ constant across >+- platforms for an example of this. >+- >+- If any of the 64bit platforms ever decide to use more than 32bits >+- in their unsigned long ioctl codes this will break and need >+- special casing based on the platform being built on. >++ various platforms. >+ */ >+- unsigned int code; >++ unsigned long code; >+ int arg; >+ int ret; >+ char *str; >+@@ -119,7 +114,7 @@ fcntl_ioctl(PyObject *self, PyObject *ar >+ int mutate_arg = 1; >+ char buf[IOCTL_BUFSZ+1]; /* argument plus NUL byte */ >+ >+- if (PyArg_ParseTuple(args, "O&Iw#|i:ioctl", >++ if (PyArg_ParseTuple(args, "O&kw#|i:ioctl", >+ conv_descriptor, &fd, &code, >+ &str, &len, &mutate_arg)) { >+ char *arg; >+@@ -170,7 +165,7 @@ fcntl_ioctl(PyObject *self, PyObject *ar >+ } >+ >+ PyErr_Clear(); >+- if (PyArg_ParseTuple(args, "O&Is#:ioctl", >++ if (PyArg_ParseTuple(args, "O&ks#:ioctl", >+ conv_descriptor, &fd, &code, &str, &len)) { >+ if (len > IOCTL_BUFSZ) { >+ PyErr_SetString(PyExc_ValueError, >+@@ -192,7 +187,7 @@ fcntl_ioctl(PyObject *self, PyObject *ar >+ PyErr_Clear(); >+ arg = 0; >+ if (!PyArg_ParseTuple(args, >+- "O&I|i;ioctl requires a file or file descriptor," >++ "O&k|i;ioctl requires a file or file descriptor," >+ " an integer and optionally an integer or buffer argument", >+ conv_descriptor, &fd, &code, &arg)) { >+ return NULL; > >Property changes on: files/patch-Modules_fcntlmodule.c >___________________________________________________________________ >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Index: files/patch-configure >=================================================================== >--- files/patch-configure (revision 0) >+++ files/patch-configure (working copy) >@@ -0,0 +1,28 @@ >+--- configure.orig 2015-03-04 11:28:43 UTC >++++ configure >+@@ -2924,13 +2924,6 @@ $as_echo "#define _NETBSD_SOURCE 1" >>co >+ >+ >+ # The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >+-# certain features on FreeBSD, so we need __BSD_VISIBLE to re-enable >+-# them. >+- >+-$as_echo "#define __BSD_VISIBLE 1" >>confdefs.h >+- >+- >+-# The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >+ # u_int on Irix 5.3. Defining _BSD_TYPES brings it back. >+ >+ $as_echo "#define _BSD_TYPES 1" >>confdefs.h >+@@ -3298,9 +3291,8 @@ $as_echo "#define _BSD_SOURCE 1" >>confd >+ # but used in struct sockaddr.sa_family. Reported by Tim Rice. >+ SCO_SV/3.2) >+ define_xopen_source=no;; >+- # On FreeBSD 4, the math functions C89 does not cover are never defined >+- # with _XOPEN_SOURCE and __BSD_VISIBLE does not re-enable them. >+- FreeBSD/4.*) >++ # On FreeBSD, defining _XOPEN_SOURCE to 600 requests a strict environment. >++ FreeBSD/*) >+ define_xopen_source=no;; >+ # On MacOS X 10.2, a bug in ncurses.h means that it craps out if >+ # _XOPEN_EXTENDED_SOURCE is defined. Apparently, this is fixed in 10.3, which > >Property changes on: files/patch-configure >___________________________________________________________________ >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Index: files/patch-configure.ac >=================================================================== >--- files/patch-configure.ac (revision 0) >+++ files/patch-configure.ac (working copy) >@@ -0,0 +1,26 @@ >+--- configure.ac.orig 2015-03-04 11:28:43 UTC >++++ configure.ac >+@@ -88,11 +88,6 @@ AC_DEFINE(_GNU_SOURCE, 1, [Define on Lin >+ AC_DEFINE(_NETBSD_SOURCE, 1, [Define on NetBSD to activate all library features]) >+ >+ # The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >+-# certain features on FreeBSD, so we need __BSD_VISIBLE to re-enable >+-# them. >+-AC_DEFINE(__BSD_VISIBLE, 1, [Define on FreeBSD to activate all library features]) >+- >+-# The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >+ # u_int on Irix 5.3. Defining _BSD_TYPES brings it back. >+ AC_DEFINE(_BSD_TYPES, 1, [Define on Irix to enable u_int]) >+ >+@@ -426,9 +421,8 @@ case $ac_sys_system/$ac_sys_release in >+ # but used in struct sockaddr.sa_family. Reported by Tim Rice. >+ SCO_SV/3.2) >+ define_xopen_source=no;; >+- # On FreeBSD 4, the math functions C89 does not cover are never defined >+- # with _XOPEN_SOURCE and __BSD_VISIBLE does not re-enable them. >+- FreeBSD/4.*) >++ # On FreeBSD, defining _XOPEN_SOURCE to 600 requests a strict environment. >++ FreeBSD/*) >+ define_xopen_source=no;; >+ # On MacOS X 10.2, a bug in ncurses.h means that it craps out if >+ # _XOPEN_EXTENDED_SOURCE is defined. Apparently, this is fixed in 10.3, which > >Property changes on: files/patch-configure.ac >___________________________________________________________________ >Added: svn:mime-type >## -0,0 +1 ## >+text/plain >\ No newline at end of property >Added: fbsd:nokeywords >## -0,0 +1 ## >+yes >\ No newline at end of property >Added: svn:eol-style >## -0,0 +1 ## >+native >\ No newline at end of property >Index: files/patch-pr192365 >=================================================================== >--- files/patch-pr192365 (revision 380439) >+++ files/patch-pr192365 (working copy) >@@ -1,58 +0,0 @@ >-# Description: do not define __BSD_VISIBLE/_XOPEN_SOURCE/_POSIX_C_SOURCE >-# in include/python2.7/pyconfig.h >-# Submitted by: antoine >- >---- configure.orig 2014-09-06 14:42:50 UTC >-+++ configure >-@@ -2919,13 +2919,6 @@ >- >- >- # The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >--# certain features on FreeBSD, so we need __BSD_VISIBLE to re-enable >--# them. >-- >--$as_echo "#define __BSD_VISIBLE 1" >>confdefs.h >-- >-- >--# The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >- # u_int on Irix 5.3. Defining _BSD_TYPES brings it back. >- >- $as_echo "#define _BSD_TYPES 1" >>confdefs.h >-@@ -3293,9 +3286,8 @@ >- # but used in struct sockaddr.sa_family. Reported by Tim Rice. >- SCO_SV/3.2) >- define_xopen_source=no;; >-- # On FreeBSD 4, the math functions C89 does not cover are never defined >-- # with _XOPEN_SOURCE and __BSD_VISIBLE does not re-enable them. >-- FreeBSD/4.*) >-+ # On FreeBSD, defining _XOPEN_SOURCE to 600 requests a strict environment. >-+ FreeBSD/*) >- define_xopen_source=no;; >- # On MacOS X 10.2, a bug in ncurses.h means that it craps out if >- # _XOPEN_EXTENDED_SOURCE is defined. Apparently, this is fixed in 10.3, which >---- configure.ac.orig 2014-09-06 14:42:50 UTC >-+++ configure.ac >-@@ -88,11 +88,6 @@ >- AC_DEFINE(_NETBSD_SOURCE, 1, [Define on NetBSD to activate all library features]) >- >- # The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >--# certain features on FreeBSD, so we need __BSD_VISIBLE to re-enable >--# them. >--AC_DEFINE(__BSD_VISIBLE, 1, [Define on FreeBSD to activate all library features]) >-- >--# The later defininition of _XOPEN_SOURCE and _POSIX_C_SOURCE disables >- # u_int on Irix 5.3. Defining _BSD_TYPES brings it back. >- AC_DEFINE(_BSD_TYPES, 1, [Define on Irix to enable u_int]) >- >-@@ -426,9 +421,8 @@ >- # but used in struct sockaddr.sa_family. Reported by Tim Rice. >- SCO_SV/3.2) >- define_xopen_source=no;; >-- # On FreeBSD 4, the math functions C89 does not cover are never defined >-- # with _XOPEN_SOURCE and __BSD_VISIBLE does not re-enable them. >-- FreeBSD/4.*) >-+ # On FreeBSD, defining _XOPEN_SOURCE to 600 requests a strict environment. >-+ FreeBSD/*) >- define_xopen_source=no;; >- # On MacOS X 10.2, a bug in ncurses.h means that it craps out if >- # _XOPEN_EXTENDED_SOURCE is defined. Apparently, this is fixed in 10.3, which >Index: files/patch-setup.py >=================================================================== >--- files/patch-setup.py (revision 380439) >+++ files/patch-setup.py (working copy) >@@ -5,9 +5,9 @@ > > # Description: ossaudiodev detection fix backport > >---- setup.py.orig 2014-06-30 04:05:48.000000000 +0200 >-+++ setup.py 2014-07-26 14:51:29.000000000 +0200 >-@@ -15,6 +15,7 @@ >+--- setup.py.orig 2014-12-10 16:00:01 UTC >++++ setup.py >+@@ -15,6 +15,7 @@ from distutils.core import Extension, se > from distutils.command.build_ext import build_ext > from distutils.command.install import install > from distutils.command.install_lib import install_lib >@@ -15,7 +15,7 @@ > from distutils.spawn import find_executable > > cross_compiling = "_PYTHON_HOST_PLATFORM" in os.environ >-@@ -33,7 +34,7 @@ >+@@ -33,7 +34,7 @@ host_platform = get_platform() > COMPILED_WITH_PYDEBUG = ('--with-pydebug' in sysconfig.get_config_var("CONFIG_ARGS")) > > # This global variable is used to hold the list of modules to be disabled. >@@ -24,7 +24,7 @@ > > def add_dir_to_list(dirlist, dir): > """Add the directory 'dir' to the list 'dirlist' (at the front) if >-@@ -1212,7 +1213,7 @@ >+@@ -1214,7 +1215,7 @@ class PyBuildExt(build_ext): > sysroot = macosx_sdk_root() > f = os.path.join(sysroot, f[1:]) > >@@ -33,7 +33,7 @@ > data = open(f).read() > m = re.search(r"#s*define\s+HASHVERSION\s+2\s*", data) > if m is not None: >-@@ -1551,7 +1552,7 @@ >+@@ -1553,7 +1554,7 @@ class PyBuildExt(build_ext): > macros = dict() > libraries = [] > >@@ -42,7 +42,7 @@ > # FreeBSD's P1003.1b semaphore support is very experimental > # and has many known problems. (as of June 2008) > macros = dict() >-@@ -1602,9 +1603,10 @@ >+@@ -1604,9 +1605,10 @@ class PyBuildExt(build_ext): > else: > missing.append('linuxaudiodev') > >@@ -56,7 +56,7 @@ > exts.append( Extension('ossaudiodev', ['ossaudiodev.c']) ) > else: > missing.append('ossaudiodev') >-@@ -2176,6 +2178,22 @@ >+@@ -2178,6 +2180,22 @@ class PyBuildInstallLib(install_lib): > def is_chmod_supported(self): > return hasattr(os, 'chmod') > >@@ -79,7 +79,7 @@ > SUMMARY = """ > Python is an interpreted, interactive, object-oriented programming > language. It is often compared to Tcl, Perl, Scheme or Java. >-@@ -2221,7 +2239,9 @@ >+@@ -2223,7 +2241,9 @@ def main(): > platforms = ["Many"], > > # Build info >@@ -90,7 +90,7 @@ > 'install_lib':PyBuildInstallLib}, > # The struct module is defined here, because build_ext won't be > # called unless there's at least one extension module defined. >-@@ -2229,8 +2249,7 @@ >+@@ -2231,8 +2251,7 @@ def main(): > > # Scripts to install > scripts = ['Tools/scripts/pydoc', 'Tools/scripts/idle',
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 192511
:
145517
|
149952
|
149974
|
149975
|
149976
|
149998
|
149999
|
150000
|
150909
|
150910
|
150944
|
151207
|
151208
|
153781
|
153782
|
153783
|
153820
|
153828
|
154266
|
154280
|
154281
|
154282
|
154283
|
154342
|
154344
|
154345
|
155432
|
157097
|
157316