Updated to Python 3.3.1.
- Refreshed patches: 55 (systemtap), 111 (no static lib), 146 (hashlib fips), 153 (fix test_gdb noise), 157 (uid, gid overflow - fixed upstream, just keeping few more downstream tests) - Removed patches: 3 (audiotest.au made it to upstream tarball) - Removed workaround for http://bugs.python.org/issue14774, discussed in http://bugs.python.org/issue15298 and fixed in revision 24d52d3060e8.
This commit is contained in:
parent
b4d586e100
commit
50232369f6
@ -653,8 +653,8 @@ diff -up Python-3.3.0rc2/Makefile.pre.in.systemtap Python-3.3.0rc2/Makefile.pre.
|
||||
Python/formatter_unicode.o: $(srcdir)/Python/formatter_unicode.c \
|
||||
$(BYTESTR_DEPS)
|
||||
@@ -724,6 +726,13 @@ Objects/typeobject.o: $(srcdir)/Objects/
|
||||
$(srcdir)/Objects/typeslots.inc: $(srcdir)/Include/typeslots.h $(srcdir)/Objects/typeslots.py
|
||||
$(PYTHON) $(srcdir)/Objects/typeslots.py < $(srcdir)/Include/typeslots.h > $(srcdir)/Objects/typeslots.inc
|
||||
Objects/typeslots.inc: $(srcdir)/Include/typeslots.h $(srcdir)/Objects/typeslots.py
|
||||
$(PYTHON) $(srcdir)/Objects/typeslots.py < $(srcdir)/Include/typeslots.h > Objects/typeslots.inc
|
||||
|
||||
+# Only needed with --with-systemtap; not a public header:
|
||||
+$(srcdir)/Python/pysystemtap.h: $(srcdir)/Python/pysystemtap.d
|
||||
@ -667,8 +667,8 @@ diff -up Python-3.3.0rc2/Makefile.pre.in.systemtap Python-3.3.0rc2/Makefile.pre.
|
||||
# Header files
|
||||
|
||||
@@ -1345,6 +1354,7 @@ clean: pycremoval
|
||||
-rm -f pybuilddir.txt
|
||||
-rm -f Lib/lib2to3/*Grammar*.pickle
|
||||
-rm -f $(SYSCONFIGDATA)
|
||||
-rm -f Modules/_testembed Modules/_freeze_importlib
|
||||
+ -rm -f $(srcdir)/Python/pysystemtap.h
|
||||
|
||||
|
@ -9,7 +9,7 @@ diff -up cpython-59223da36dec/Makefile.pre.in.no-static-lib cpython-59223da36dec
|
||||
+$(BUILDPYTHON): Modules/python.o $(LDLIBRARY) $(PY3LIBRARY)
|
||||
$(LINKCC) $(PY_LDFLAGS) $(LINKFORSHARED) -o $@ Modules/python.o $(BLDLIBRARY) $(LIBS) $(MODLIBS) $(SYSLIBS) $(LDLAST)
|
||||
|
||||
platform: $(BUILDPYTHON) $(SYSCONFIGDATA)
|
||||
platform: $(BUILDPYTHON) pybuilddir.txt
|
||||
@@ -480,18 +480,6 @@ sharedmods: $(BUILDPYTHON) $(SYSCONFIGDA
|
||||
$(RUNSHARED) CC='$(CC)' LDSHARED='$(BLDSHARED)' OPT='$(OPT)' \
|
||||
$(PYTHON_FOR_BUILD) $(srcdir)/setup.py $$quiet build
|
||||
@ -44,7 +44,7 @@ diff -up cpython-59223da36dec/Makefile.pre.in.no-static-lib cpython-59223da36dec
|
||||
done
|
||||
- @if test -d $(LIBRARY); then :; else \
|
||||
- if test "$(PYTHONFRAMEWORKDIR)" = no-framework; then \
|
||||
- if test "$(SO)" = .dll; then \
|
||||
- if test "$(SHLIB_SUFFIX)" = .dll; then \
|
||||
- $(INSTALL_DATA) $(LDLIBRARY) $(DESTDIR)$(LIBPL) ; \
|
||||
- else \
|
||||
- $(INSTALL_DATA) $(LIBRARY) $(DESTDIR)$(LIBPL)/$(LIBRARY) ; \
|
||||
|
@ -285,7 +285,7 @@ diff -up Python-3.2.2/Modules/_hashopenssl.c.hashlib-fips Python-3.2.2/Modules/_
|
||||
+} EVPCachedInfo;
|
||||
|
||||
-#define DEFINE_CONSTS_FOR_NEW(Name) \
|
||||
- static PyObject *CONST_ ## Name ## _name_obj; \
|
||||
- static PyObject *CONST_ ## Name ## _name_obj = NULL; \
|
||||
- static EVP_MD_CTX CONST_new_ ## Name ## _ctx; \
|
||||
- static EVP_MD_CTX *CONST_new_ ## Name ## _ctx_p = NULL;
|
||||
+#define DEFINE_CONSTS_FOR_NEW(Name) \
|
||||
@ -444,7 +444,7 @@ diff -up Python-3.2.2/Modules/_hashopenssl.c.hashlib-fips Python-3.2.2/Modules/_
|
||||
|
||||
if (data_obj)
|
||||
PyBuffer_Release(&view);
|
||||
@@ -547,55 +620,115 @@ generate_hash_name_list(void)
|
||||
@@ -547,58 +620,115 @@ generate_hash_name_list(void)
|
||||
|
||||
|
||||
/*
|
||||
@ -550,12 +550,15 @@ diff -up Python-3.2.2/Modules/_hashopenssl.c.hashlib-fips Python-3.2.2/Modules/_
|
||||
" hash object; optionally initialized with a string") \
|
||||
}
|
||||
|
||||
-/* used in the init function to setup a constructor */
|
||||
-/* used in the init function to setup a constructor: initialize OpenSSL
|
||||
- constructor constants if they haven't been initialized already. */
|
||||
-#define INIT_CONSTRUCTOR_CONSTANTS(NAME) do { \
|
||||
- CONST_ ## NAME ## _name_obj = PyUnicode_FromString(#NAME); \
|
||||
- if (EVP_get_digestbyname(#NAME)) { \
|
||||
- CONST_new_ ## NAME ## _ctx_p = &CONST_new_ ## NAME ## _ctx; \
|
||||
- EVP_DigestInit(CONST_new_ ## NAME ## _ctx_p, EVP_get_digestbyname(#NAME)); \
|
||||
- if (CONST_ ## NAME ## _name_obj == NULL) { \
|
||||
- CONST_ ## NAME ## _name_obj = PyUnicode_FromString(#NAME); \
|
||||
- if (EVP_get_digestbyname(#NAME)) { \
|
||||
- CONST_new_ ## NAME ## _ctx_p = &CONST_new_ ## NAME ## _ctx; \
|
||||
- EVP_DigestInit(CONST_new_ ## NAME ## _ctx_p, EVP_get_digestbyname(#NAME)); \
|
||||
- } \
|
||||
- } \
|
||||
-} while (0);
|
||||
+/*
|
||||
|
@ -18,10 +18,9 @@ diff -up cpython-59223da36dec/Lib/test/test_gdb.py.fix-test_gdb-noise cpython-59
|
||||
if cmds_after_breakpoint:
|
||||
commands += cmds_after_breakpoint
|
||||
@@ -154,8 +163,16 @@ class DebuggerTests(unittest.TestCase):
|
||||
err = err.replace("warning: Cannot initialize thread debugging"
|
||||
" library: Debugger service failed\n",
|
||||
'Do you need "set solib-search-path" or '
|
||||
'"set sysroot"?\n',
|
||||
'')
|
||||
-
|
||||
+ err = '\n'.join([line
|
||||
+ for line in err.splitlines()
|
||||
+ if not line.startswith('warning: Unable to open')
|
||||
@ -29,7 +28,7 @@ diff -up cpython-59223da36dec/Lib/test/test_gdb.py.fix-test_gdb-noise cpython-59
|
||||
+ if not line.startswith('Try: yum --disablerepo=')
|
||||
+ # In case 'set print entry-values no' failed:
|
||||
+ if not line.startswith('Undefined set print command')])
|
||||
+
|
||||
|
||||
# Ensure no unexpected error messages:
|
||||
+ self.maxDiff = None
|
||||
self.assertEqual(err, '')
|
||||
|
@ -1,32 +1,3 @@
|
||||
diff -up Python-3.3.0b1/Include/modsupport.h.uid-gid-overflows Python-3.3.0b1/Include/modsupport.h
|
||||
--- Python-3.3.0b1/Include/modsupport.h.uid-gid-overflows 2012-06-26 16:19:40.000000000 -0400
|
||||
+++ Python-3.3.0b1/Include/modsupport.h 2012-07-20 14:21:46.854688763 -0400
|
||||
@@ -8,6 +8,7 @@ extern "C" {
|
||||
/* Module support interface */
|
||||
|
||||
#include <stdarg.h>
|
||||
+#include <sys/types.h>
|
||||
|
||||
/* If PY_SSIZE_T_CLEAN is defined, each functions treats #-specifier
|
||||
to mean Py_ssize_t */
|
||||
@@ -125,6 +126,17 @@ PyAPI_FUNC(PyObject *) PyModule_Create2(
|
||||
PyAPI_DATA(char *) _Py_PackageContext;
|
||||
#endif
|
||||
|
||||
+/*
|
||||
+ Non-standard extension: support for dealing with uid_t and gid_t without
|
||||
+ integer overflow
|
||||
+ */
|
||||
+
|
||||
+PyAPI_FUNC(PyObject *) _PyObject_FromUid(uid_t uid);
|
||||
+PyAPI_FUNC(PyObject *) _PyObject_FromGid(gid_t gid);
|
||||
+
|
||||
+PyAPI_FUNC(int) _PyArg_ParseUid(PyObject *in_obj, uid_t *out_uid);
|
||||
+PyAPI_FUNC(int) _PyArg_ParseGid(PyObject *in_obj, gid_t *out_gid);
|
||||
+
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
diff -up Python-3.3.0b1/Lib/test/test_os.py.uid-gid-overflows Python-3.3.0b1/Lib/test/test_os.py
|
||||
--- Python-3.3.0b1/Lib/test/test_os.py.uid-gid-overflows 2012-06-26 16:19:48.000000000 -0400
|
||||
+++ Python-3.3.0b1/Lib/test/test_os.py 2012-07-20 14:21:46.856688739 -0400
|
||||
@ -39,7 +10,7 @@ diff -up Python-3.3.0b1/Lib/test/test_os.py.uid-gid-overflows Python-3.3.0b1/Lib
|
||||
|
||||
if hasattr(os, 'setgid'):
|
||||
def test_setgid(self):
|
||||
if os.getuid() != 0:
|
||||
if os.getuid() != 0 and not HAVE_WHEEL_GROUP:
|
||||
self.assertRaises(os.error, os.setgid, 0)
|
||||
+ self.assertRaises(TypeError, os.setgid, 'not an int')
|
||||
self.assertRaises(OverflowError, os.setgid, 1<<32)
|
||||
@ -53,7 +24,7 @@ diff -up Python-3.3.0b1/Lib/test/test_os.py.uid-gid-overflows Python-3.3.0b1/Lib
|
||||
|
||||
if hasattr(os, 'setegid'):
|
||||
def test_setegid(self):
|
||||
if os.getuid() != 0:
|
||||
if os.getuid() != 0 and not HAVE_WHEEL_GROUP:
|
||||
self.assertRaises(os.error, os.setegid, 0)
|
||||
+ self.assertRaises(TypeError, os.setegid, 'not an int')
|
||||
self.assertRaises(OverflowError, os.setegid, 1<<32)
|
||||
@ -69,62 +40,13 @@ diff -up Python-3.3.0b1/Lib/test/test_os.py.uid-gid-overflows Python-3.3.0b1/Lib
|
||||
|
||||
@@ -1212,6 +1218,8 @@ if sys.platform != 'win32':
|
||||
def test_setregid(self):
|
||||
if os.getuid() != 0:
|
||||
if os.getuid() != 0 and not HAVE_WHEEL_GROUP:
|
||||
self.assertRaises(os.error, os.setregid, 0, 0)
|
||||
+ self.assertRaises(TypeError, os.setregid, 'not an int', 0)
|
||||
+ self.assertRaises(TypeError, os.setregid, 0, 'not an int')
|
||||
self.assertRaises(OverflowError, os.setregid, 1<<32, 0)
|
||||
self.assertRaises(OverflowError, os.setregid, 0, 1<<32)
|
||||
|
||||
diff -up Python-3.3.0b1/Lib/test/test_posix.py.uid-gid-overflows Python-3.3.0b1/Lib/test/test_posix.py
|
||||
--- Python-3.3.0b1/Lib/test/test_posix.py.uid-gid-overflows 2012-06-26 16:19:48.000000000 -0400
|
||||
+++ Python-3.3.0b1/Lib/test/test_posix.py 2012-07-20 14:21:46.857688726 -0400
|
||||
@@ -387,10 +387,17 @@ class PosixTester(unittest.TestCase):
|
||||
else:
|
||||
self.assertTrue(stat.S_ISFIFO(posix.stat(support.TESTFN).st_mode))
|
||||
|
||||
- def _test_all_chown_common(self, chown_func, first_param):
|
||||
+ def _test_all_chown_common(self, chown_func, stat_func, first_param):
|
||||
"""Common code for chown, fchown and lchown tests."""
|
||||
# test a successful chown call
|
||||
chown_func(first_param, os.getuid(), os.getgid())
|
||||
+ self.assertEqual(stat_func(first_param).st_uid, os.getuid())
|
||||
+ self.assertEqual(stat_func(first_param).st_gid, os.getgid())
|
||||
+
|
||||
+ # verify that -1 works as a "do-nothing" option:
|
||||
+ chown_func(first_param, -1, -1)
|
||||
+ self.assertEqual(stat_func(first_param).st_uid, os.getuid())
|
||||
+ self.assertEqual(stat_func(first_param).st_gid, os.getgid())
|
||||
|
||||
if os.getuid() == 0:
|
||||
try:
|
||||
@@ -421,7 +428,7 @@ class PosixTester(unittest.TestCase):
|
||||
|
||||
# re-create the file
|
||||
support.create_empty_file(support.TESTFN)
|
||||
- self._test_all_chown_common(posix.chown, support.TESTFN)
|
||||
+ self._test_all_chown_common(posix.chown, posix.stat, support.TESTFN)
|
||||
|
||||
@unittest.skipUnless(hasattr(posix, 'fchown'), "test needs os.fchown()")
|
||||
def test_fchown(self):
|
||||
@@ -431,7 +438,7 @@ class PosixTester(unittest.TestCase):
|
||||
test_file = open(support.TESTFN, 'w')
|
||||
try:
|
||||
fd = test_file.fileno()
|
||||
- self._test_all_chown_common(posix.fchown, fd)
|
||||
+ self._test_all_chown_common(posix.fchown, posix.fstat, fd)
|
||||
finally:
|
||||
test_file.close()
|
||||
|
||||
@@ -440,7 +447,7 @@ class PosixTester(unittest.TestCase):
|
||||
os.unlink(support.TESTFN)
|
||||
# create a symlink
|
||||
os.symlink(_DUMMY_SYMLINK, support.TESTFN)
|
||||
- self._test_all_chown_common(posix.lchown, support.TESTFN)
|
||||
+ self._test_all_chown_common(posix.lchown, posix.lstat, support.TESTFN)
|
||||
|
||||
def test_chdir(self):
|
||||
if hasattr(posix, 'chdir'):
|
||||
diff -up Python-3.3.0b1/Lib/test/test_pwd.py.uid-gid-overflows Python-3.3.0b1/Lib/test/test_pwd.py
|
||||
--- Python-3.3.0b1/Lib/test/test_pwd.py.uid-gid-overflows 2012-06-26 16:19:48.000000000 -0400
|
||||
+++ Python-3.3.0b1/Lib/test/test_pwd.py 2012-07-20 14:21:46.857688726 -0400
|
||||
@ -140,557 +62,3 @@ diff -up Python-3.3.0b1/Lib/test/test_pwd.py.uid-gid-overflows Python-3.3.0b1/Li
|
||||
self.assertNotIn(fakeuid, byuids)
|
||||
self.assertRaises(KeyError, pwd.getpwuid, fakeuid)
|
||||
|
||||
diff -up Python-3.3.0b1/Modules/grpmodule.c.uid-gid-overflows Python-3.3.0b1/Modules/grpmodule.c
|
||||
--- Python-3.3.0b1/Modules/grpmodule.c.uid-gid-overflows 2012-06-26 16:19:54.000000000 -0400
|
||||
+++ Python-3.3.0b1/Modules/grpmodule.c 2012-07-20 14:21:46.858688713 -0400
|
||||
@@ -69,7 +69,7 @@ mkgrent(struct group *p)
|
||||
Py_INCREF(Py_None);
|
||||
}
|
||||
#endif
|
||||
- SET(setIndex++, PyLong_FromLong((long) p->gr_gid));
|
||||
+ SET(setIndex++, _PyObject_FromGid(p->gr_gid));
|
||||
SET(setIndex++, w);
|
||||
#undef SET
|
||||
|
||||
@@ -84,18 +84,16 @@ mkgrent(struct group *p)
|
||||
static PyObject *
|
||||
grp_getgrgid(PyObject *self, PyObject *pyo_id)
|
||||
{
|
||||
- PyObject *py_int_id;
|
||||
- unsigned int gid;
|
||||
+ gid_t gid;
|
||||
struct group *p;
|
||||
|
||||
- py_int_id = PyNumber_Long(pyo_id);
|
||||
- if (!py_int_id)
|
||||
- return NULL;
|
||||
- gid = PyLong_AS_LONG(py_int_id);
|
||||
- Py_DECREF(py_int_id);
|
||||
+ if (!_PyArg_ParseGid(pyo_id, &gid)) {
|
||||
+ return NULL;
|
||||
+ }
|
||||
|
||||
if ((p = getgrgid(gid)) == NULL) {
|
||||
- PyErr_Format(PyExc_KeyError, "getgrgid(): gid not found: %d", gid);
|
||||
+ PyErr_Format(PyExc_KeyError,
|
||||
+ "getgrgid(): gid not found: %lu", (unsigned long)gid);
|
||||
return NULL;
|
||||
}
|
||||
return mkgrent(p);
|
||||
diff -up Python-3.3.0b1/Modules/posixmodule.c.uid-gid-overflows Python-3.3.0b1/Modules/posixmodule.c
|
||||
--- Python-3.3.0b1/Modules/posixmodule.c.uid-gid-overflows 2012-07-20 14:21:46.788689588 -0400
|
||||
+++ Python-3.3.0b1/Modules/posixmodule.c 2012-07-20 14:24:19.626778849 -0400
|
||||
@@ -2151,8 +2151,8 @@ _pystat_fromstructstat(STRUCT_STAT *st)
|
||||
PyStructSequence_SET_ITEM(v, 2, PyLong_FromLong((long)st->st_dev));
|
||||
#endif
|
||||
PyStructSequence_SET_ITEM(v, 3, PyLong_FromLong((long)st->st_nlink));
|
||||
- PyStructSequence_SET_ITEM(v, 4, PyLong_FromLong((long)st->st_uid));
|
||||
- PyStructSequence_SET_ITEM(v, 5, PyLong_FromLong((long)st->st_gid));
|
||||
+ PyStructSequence_SET_ITEM(v, 4, _PyObject_FromUid(st->st_uid));
|
||||
+ PyStructSequence_SET_ITEM(v, 5, _PyObject_FromGid(st->st_gid));
|
||||
#ifdef HAVE_LARGEFILE_SUPPORT
|
||||
PyStructSequence_SET_ITEM(v, 6,
|
||||
PyLong_FromLongLong((PY_LONG_LONG)st->st_size));
|
||||
@@ -2957,7 +2957,6 @@ static PyObject *
|
||||
posix_chown(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
path_t path;
|
||||
- long uid_l, gid_l;
|
||||
uid_t uid;
|
||||
gid_t gid;
|
||||
int dir_fd = DEFAULT_DIR_FD;
|
||||
@@ -2971,9 +2970,10 @@ posix_chown(PyObject *self, PyObject *ar
|
||||
#ifdef HAVE_FCHOWN
|
||||
path.allow_fd = 1;
|
||||
#endif
|
||||
- if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O&ll|$O&p:chown", keywords,
|
||||
+ if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O&O&O&|$O&p:chown", keywords,
|
||||
path_converter, &path,
|
||||
- &uid_l, &gid_l,
|
||||
+ _PyArg_ParseUid, &uid,
|
||||
+ _PyArg_ParseGid, &gid,
|
||||
#ifdef HAVE_FCHOWNAT
|
||||
dir_fd_converter, &dir_fd,
|
||||
#else
|
||||
@@ -3004,8 +3004,6 @@ posix_chown(PyObject *self, PyObject *ar
|
||||
#endif
|
||||
|
||||
Py_BEGIN_ALLOW_THREADS
|
||||
- uid = (uid_t)uid_l;
|
||||
- gid = (uid_t)gid_l;
|
||||
#ifdef HAVE_FCHOWN
|
||||
if (path.fd != -1)
|
||||
result = fchown(path.fd, uid, gid);
|
||||
@@ -3049,12 +3047,15 @@ static PyObject *
|
||||
posix_fchown(PyObject *self, PyObject *args)
|
||||
{
|
||||
int fd;
|
||||
- long uid, gid;
|
||||
+ uid_t uid;
|
||||
+ gid_t gid;
|
||||
int res;
|
||||
- if (!PyArg_ParseTuple(args, "ill:fchown", &fd, &uid, &gid))
|
||||
+ if (!PyArg_ParseTuple(args, "iO&O&:chown", &fd,
|
||||
+ _PyArg_ParseUid, &uid,
|
||||
+ _PyArg_ParseGid, &gid))
|
||||
return NULL;
|
||||
Py_BEGIN_ALLOW_THREADS
|
||||
- res = fchown(fd, (uid_t) uid, (gid_t) gid);
|
||||
+ res = fchown(fd, uid, gid);
|
||||
Py_END_ALLOW_THREADS
|
||||
if (res < 0)
|
||||
return posix_error();
|
||||
@@ -3074,15 +3075,17 @@ posix_lchown(PyObject *self, PyObject *a
|
||||
{
|
||||
PyObject *opath;
|
||||
char *path;
|
||||
- long uid, gid;
|
||||
+ uid_t uid;
|
||||
+ gid_t gid;
|
||||
int res;
|
||||
- if (!PyArg_ParseTuple(args, "O&ll:lchown",
|
||||
+ if (!PyArg_ParseTuple(args, "O&O&O&:lchown",
|
||||
PyUnicode_FSConverter, &opath,
|
||||
- &uid, &gid))
|
||||
+ _PyArg_ParseUid, &uid,
|
||||
+ _PyArg_ParseGid, &gid))
|
||||
return NULL;
|
||||
path = PyBytes_AsString(opath);
|
||||
Py_BEGIN_ALLOW_THREADS
|
||||
- res = lchown(path, (uid_t) uid, (gid_t) gid);
|
||||
+ res = lchown(path, uid, gid);
|
||||
Py_END_ALLOW_THREADS
|
||||
if (res < 0)
|
||||
return posix_error_with_allocated_filename(opath);
|
||||
@@ -6184,7 +6187,7 @@ Return the current process's effective g
|
||||
static PyObject *
|
||||
posix_getegid(PyObject *self, PyObject *noargs)
|
||||
{
|
||||
- return PyLong_FromLong((long)getegid());
|
||||
+ return _PyObject_FromGid(getegid());
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -6197,7 +6200,7 @@ Return the current process's effective u
|
||||
static PyObject *
|
||||
posix_geteuid(PyObject *self, PyObject *noargs)
|
||||
{
|
||||
- return PyLong_FromLong((long)geteuid());
|
||||
+ return _PyObject_FromUid(geteuid());
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -6210,7 +6213,7 @@ Return the current process's group id.")
|
||||
static PyObject *
|
||||
posix_getgid(PyObject *self, PyObject *noargs)
|
||||
{
|
||||
- return PyLong_FromLong((long)getgid());
|
||||
+ return _PyObject_FromGid(getgid());
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -6349,7 +6352,7 @@ posix_getgroups(PyObject *self, PyObject
|
||||
if (result != NULL) {
|
||||
int i;
|
||||
for (i = 0; i < n; ++i) {
|
||||
- PyObject *o = PyLong_FromLong((long)alt_grouplist[i]);
|
||||
+ PyObject *o = _PyObject_FromGid(alt_grouplist[i]);
|
||||
if (o == NULL) {
|
||||
Py_DECREF(result);
|
||||
result = NULL;
|
||||
@@ -6380,14 +6383,15 @@ posix_initgroups(PyObject *self, PyObjec
|
||||
PyObject *oname;
|
||||
char *username;
|
||||
int res;
|
||||
- long gid;
|
||||
+ gid_t gid;
|
||||
|
||||
- if (!PyArg_ParseTuple(args, "O&l:initgroups",
|
||||
- PyUnicode_FSConverter, &oname, &gid))
|
||||
+ if (!PyArg_ParseTuple(args, "O&O&:initgroups",
|
||||
+ PyUnicode_FSConverter, &oname,
|
||||
+ _PyArg_ParseGid, &gid))
|
||||
return NULL;
|
||||
username = PyBytes_AS_STRING(oname);
|
||||
|
||||
- res = initgroups(username, (gid_t) gid);
|
||||
+ res = initgroups(username, gid);
|
||||
Py_DECREF(oname);
|
||||
if (res == -1)
|
||||
return PyErr_SetFromErrno(PyExc_OSError);
|
||||
@@ -6562,7 +6566,7 @@ Return the current process's user id.");
|
||||
static PyObject *
|
||||
posix_getuid(PyObject *self, PyObject *noargs)
|
||||
{
|
||||
- return PyLong_FromLong((long)getuid());
|
||||
+ return _PyObject_FromUid(getuid());
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -6702,15 +6706,9 @@ Set the current process's user id.");
|
||||
static PyObject *
|
||||
posix_setuid(PyObject *self, PyObject *args)
|
||||
{
|
||||
- long uid_arg;
|
||||
uid_t uid;
|
||||
- if (!PyArg_ParseTuple(args, "l:setuid", &uid_arg))
|
||||
- return NULL;
|
||||
- uid = uid_arg;
|
||||
- if (uid != uid_arg) {
|
||||
- PyErr_SetString(PyExc_OverflowError, "user id too big");
|
||||
+ if (!PyArg_ParseTuple(args, "O&:setuid", _PyArg_ParseUid, &uid))
|
||||
return NULL;
|
||||
- }
|
||||
if (setuid(uid) < 0)
|
||||
return posix_error();
|
||||
Py_INCREF(Py_None);
|
||||
@@ -6727,15 +6725,9 @@ Set the current process's effective user
|
||||
static PyObject *
|
||||
posix_seteuid (PyObject *self, PyObject *args)
|
||||
{
|
||||
- long euid_arg;
|
||||
uid_t euid;
|
||||
- if (!PyArg_ParseTuple(args, "l", &euid_arg))
|
||||
+ if (!PyArg_ParseTuple(args, "O&:seteuid", _PyArg_ParseUid, &euid))
|
||||
return NULL;
|
||||
- euid = euid_arg;
|
||||
- if (euid != euid_arg) {
|
||||
- PyErr_SetString(PyExc_OverflowError, "user id too big");
|
||||
- return NULL;
|
||||
- }
|
||||
if (seteuid(euid) < 0) {
|
||||
return posix_error();
|
||||
} else {
|
||||
@@ -6753,15 +6745,9 @@ Set the current process's effective grou
|
||||
static PyObject *
|
||||
posix_setegid (PyObject *self, PyObject *args)
|
||||
{
|
||||
- long egid_arg;
|
||||
gid_t egid;
|
||||
- if (!PyArg_ParseTuple(args, "l", &egid_arg))
|
||||
- return NULL;
|
||||
- egid = egid_arg;
|
||||
- if (egid != egid_arg) {
|
||||
- PyErr_SetString(PyExc_OverflowError, "group id too big");
|
||||
+ if (!PyArg_ParseTuple(args, "O&:setegid", _PyArg_ParseGid, &egid))
|
||||
return NULL;
|
||||
- }
|
||||
if (setegid(egid) < 0) {
|
||||
return posix_error();
|
||||
} else {
|
||||
@@ -6779,23 +6765,11 @@ Set the current process's real and effec
|
||||
static PyObject *
|
||||
posix_setreuid (PyObject *self, PyObject *args)
|
||||
{
|
||||
- long ruid_arg, euid_arg;
|
||||
uid_t ruid, euid;
|
||||
- if (!PyArg_ParseTuple(args, "ll", &ruid_arg, &euid_arg))
|
||||
- return NULL;
|
||||
- if (ruid_arg == -1)
|
||||
- ruid = (uid_t)-1; /* let the compiler choose how -1 fits */
|
||||
- else
|
||||
- ruid = ruid_arg; /* otherwise, assign from our long */
|
||||
- if (euid_arg == -1)
|
||||
- euid = (uid_t)-1;
|
||||
- else
|
||||
- euid = euid_arg;
|
||||
- if ((euid_arg != -1 && euid != euid_arg) ||
|
||||
- (ruid_arg != -1 && ruid != ruid_arg)) {
|
||||
- PyErr_SetString(PyExc_OverflowError, "user id too big");
|
||||
+ if (!PyArg_ParseTuple(args, "O&O&",
|
||||
+ _PyArg_ParseUid, &ruid,
|
||||
+ _PyArg_ParseUid, &euid))
|
||||
return NULL;
|
||||
- }
|
||||
if (setreuid(ruid, euid) < 0) {
|
||||
return posix_error();
|
||||
} else {
|
||||
@@ -6813,23 +6787,11 @@ Set the current process's real and effec
|
||||
static PyObject *
|
||||
posix_setregid (PyObject *self, PyObject *args)
|
||||
{
|
||||
- long rgid_arg, egid_arg;
|
||||
gid_t rgid, egid;
|
||||
- if (!PyArg_ParseTuple(args, "ll", &rgid_arg, &egid_arg))
|
||||
- return NULL;
|
||||
- if (rgid_arg == -1)
|
||||
- rgid = (gid_t)-1; /* let the compiler choose how -1 fits */
|
||||
- else
|
||||
- rgid = rgid_arg; /* otherwise, assign from our long */
|
||||
- if (egid_arg == -1)
|
||||
- egid = (gid_t)-1;
|
||||
- else
|
||||
- egid = egid_arg;
|
||||
- if ((egid_arg != -1 && egid != egid_arg) ||
|
||||
- (rgid_arg != -1 && rgid != rgid_arg)) {
|
||||
- PyErr_SetString(PyExc_OverflowError, "group id too big");
|
||||
+ if (!PyArg_ParseTuple(args, "O&O&",
|
||||
+ _PyArg_ParseGid, &rgid,
|
||||
+ _PyArg_ParseGid, &egid))
|
||||
return NULL;
|
||||
- }
|
||||
if (setregid(rgid, egid) < 0) {
|
||||
return posix_error();
|
||||
} else {
|
||||
@@ -6847,15 +6809,9 @@ Set the current process's group id.");
|
||||
static PyObject *
|
||||
posix_setgid(PyObject *self, PyObject *args)
|
||||
{
|
||||
- long gid_arg;
|
||||
gid_t gid;
|
||||
- if (!PyArg_ParseTuple(args, "l:setgid", &gid_arg))
|
||||
+ if (!PyArg_ParseTuple(args, "O&:setgid", _PyArg_ParseGid, &gid))
|
||||
return NULL;
|
||||
- gid = gid_arg;
|
||||
- if (gid != gid_arg) {
|
||||
- PyErr_SetString(PyExc_OverflowError, "group id too big");
|
||||
- return NULL;
|
||||
- }
|
||||
if (setgid(gid) < 0)
|
||||
return posix_error();
|
||||
Py_INCREF(Py_None);
|
||||
@@ -6888,27 +6844,9 @@ posix_setgroups(PyObject *self, PyObject
|
||||
elem = PySequence_GetItem(groups, i);
|
||||
if (!elem)
|
||||
return NULL;
|
||||
- if (!PyLong_Check(elem)) {
|
||||
- PyErr_SetString(PyExc_TypeError,
|
||||
- "groups must be integers");
|
||||
+ if (!_PyArg_ParseGid(elem, &grouplist[i])) {
|
||||
Py_DECREF(elem);
|
||||
return NULL;
|
||||
- } else {
|
||||
- unsigned long x = PyLong_AsUnsignedLong(elem);
|
||||
- if (PyErr_Occurred()) {
|
||||
- PyErr_SetString(PyExc_TypeError,
|
||||
- "group id too big");
|
||||
- Py_DECREF(elem);
|
||||
- return NULL;
|
||||
- }
|
||||
- grouplist[i] = x;
|
||||
- /* read back the value to see if it fitted in gid_t */
|
||||
- if (grouplist[i] != x) {
|
||||
- PyErr_SetString(PyExc_TypeError,
|
||||
- "group id too big");
|
||||
- Py_DECREF(elem);
|
||||
- return NULL;
|
||||
- }
|
||||
}
|
||||
Py_DECREF(elem);
|
||||
}
|
||||
@@ -10388,9 +10326,11 @@ Set the current process's real, effectiv
|
||||
static PyObject*
|
||||
posix_setresuid (PyObject *self, PyObject *args)
|
||||
{
|
||||
- /* We assume uid_t is no larger than a long. */
|
||||
- long ruid, euid, suid;
|
||||
- if (!PyArg_ParseTuple(args, "lll", &ruid, &euid, &suid))
|
||||
+ uid_t ruid, euid, suid;
|
||||
+ if (!PyArg_ParseTuple(args, "O&O&O&",
|
||||
+ _PyArg_ParseUid, &ruid,
|
||||
+ _PyArg_ParseUid, &euid,
|
||||
+ _PyArg_ParseUid, &suid))
|
||||
return NULL;
|
||||
if (setresuid(ruid, euid, suid) < 0)
|
||||
return posix_error();
|
||||
@@ -10406,9 +10346,11 @@ Set the current process's real, effectiv
|
||||
static PyObject*
|
||||
posix_setresgid (PyObject *self, PyObject *args)
|
||||
{
|
||||
- /* We assume uid_t is no larger than a long. */
|
||||
- long rgid, egid, sgid;
|
||||
- if (!PyArg_ParseTuple(args, "lll", &rgid, &egid, &sgid))
|
||||
+ gid_t rgid, egid, sgid;
|
||||
+ if (!PyArg_ParseTuple(args, "O&O&O&",
|
||||
+ _PyArg_ParseGid, &rgid,
|
||||
+ _PyArg_ParseGid, &egid,
|
||||
+ _PyArg_ParseGid, &sgid))
|
||||
return NULL;
|
||||
if (setresgid(rgid, egid, sgid) < 0)
|
||||
return posix_error();
|
||||
@@ -10425,14 +10367,13 @@ static PyObject*
|
||||
posix_getresuid (PyObject *self, PyObject *noargs)
|
||||
{
|
||||
uid_t ruid, euid, suid;
|
||||
- long l_ruid, l_euid, l_suid;
|
||||
+ PyObject *obj_ruid, *obj_euid, *obj_suid;
|
||||
if (getresuid(&ruid, &euid, &suid) < 0)
|
||||
return posix_error();
|
||||
- /* Force the values into long's as we don't know the size of uid_t. */
|
||||
- l_ruid = ruid;
|
||||
- l_euid = euid;
|
||||
- l_suid = suid;
|
||||
- return Py_BuildValue("(lll)", l_ruid, l_euid, l_suid);
|
||||
+ obj_ruid = _PyObject_FromUid(ruid);
|
||||
+ obj_euid = _PyObject_FromUid(euid);
|
||||
+ obj_suid = _PyObject_FromUid(suid);
|
||||
+ return Py_BuildValue("(NNN)", obj_ruid, obj_euid, obj_suid);
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -10445,14 +10386,13 @@ static PyObject*
|
||||
posix_getresgid (PyObject *self, PyObject *noargs)
|
||||
{
|
||||
uid_t rgid, egid, sgid;
|
||||
- long l_rgid, l_egid, l_sgid;
|
||||
+ PyObject *obj_rgid, *obj_egid, *obj_sgid;
|
||||
if (getresgid(&rgid, &egid, &sgid) < 0)
|
||||
return posix_error();
|
||||
- /* Force the values into long's as we don't know the size of uid_t. */
|
||||
- l_rgid = rgid;
|
||||
- l_egid = egid;
|
||||
- l_sgid = sgid;
|
||||
- return Py_BuildValue("(lll)", l_rgid, l_egid, l_sgid);
|
||||
+ obj_rgid = _PyObject_FromGid(rgid);
|
||||
+ obj_egid = _PyObject_FromGid(egid);
|
||||
+ obj_sgid = _PyObject_FromGid(sgid);
|
||||
+ return Py_BuildValue("(NNN)", obj_rgid, obj_egid, obj_sgid);
|
||||
}
|
||||
#endif
|
||||
|
||||
diff -up Python-3.3.0b1/Modules/pwdmodule.c.uid-gid-overflows Python-3.3.0b1/Modules/pwdmodule.c
|
||||
--- Python-3.3.0b1/Modules/pwdmodule.c.uid-gid-overflows 2012-06-26 16:19:54.000000000 -0400
|
||||
+++ Python-3.3.0b1/Modules/pwdmodule.c 2012-07-20 14:21:46.861688675 -0400
|
||||
@@ -74,8 +74,8 @@ mkpwent(struct passwd *p)
|
||||
#else
|
||||
SETS(setIndex++, p->pw_passwd);
|
||||
#endif
|
||||
- SETI(setIndex++, p->pw_uid);
|
||||
- SETI(setIndex++, p->pw_gid);
|
||||
+ PyStructSequence_SET_ITEM(v, setIndex++, _PyObject_FromUid(p->pw_uid));
|
||||
+ PyStructSequence_SET_ITEM(v, setIndex++, _PyObject_FromGid(p->pw_gid));
|
||||
#ifdef __VMS
|
||||
SETS(setIndex++, "");
|
||||
#else
|
||||
@@ -104,13 +104,14 @@ See help(pwd) for more on password datab
|
||||
static PyObject *
|
||||
pwd_getpwuid(PyObject *self, PyObject *args)
|
||||
{
|
||||
- unsigned int uid;
|
||||
+ uid_t uid;
|
||||
struct passwd *p;
|
||||
- if (!PyArg_ParseTuple(args, "I:getpwuid", &uid))
|
||||
+ if (!PyArg_ParseTuple(args, "O&:getpwuid",
|
||||
+ _PyArg_ParseUid, &uid))
|
||||
return NULL;
|
||||
if ((p = getpwuid(uid)) == NULL) {
|
||||
PyErr_Format(PyExc_KeyError,
|
||||
- "getpwuid(): uid not found: %d", uid);
|
||||
+ "getpwuid(): uid not found: %lu", (unsigned long)uid);
|
||||
return NULL;
|
||||
}
|
||||
return mkpwent(p);
|
||||
diff -up Python-3.3.0b1/Python/getargs.c.uid-gid-overflows Python-3.3.0b1/Python/getargs.c
|
||||
--- Python-3.3.0b1/Python/getargs.c.uid-gid-overflows 2012-06-26 16:19:57.000000000 -0400
|
||||
+++ Python-3.3.0b1/Python/getargs.c 2012-07-20 14:21:46.861688675 -0400
|
||||
@@ -4,6 +4,7 @@
|
||||
#include "Python.h"
|
||||
|
||||
#include <ctype.h>
|
||||
+#include <limits.h>
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
@@ -1807,6 +1808,102 @@ _PyArg_NoKeywords(const char *funcname,
|
||||
funcname);
|
||||
return 0;
|
||||
}
|
||||
+
|
||||
+PyObject *
|
||||
+_PyObject_FromUid(uid_t uid)
|
||||
+{
|
||||
+ return PyLong_FromUnsignedLong((uid_t)uid);
|
||||
+}
|
||||
+
|
||||
+PyObject *
|
||||
+_PyObject_FromGid(gid_t gid)
|
||||
+{
|
||||
+ return PyLong_FromUnsignedLong((gid_t)gid);
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+_PyArg_ParseUid(PyObject *in_obj, uid_t *out_uid)
|
||||
+{
|
||||
+ PyObject *index, *number = NULL;
|
||||
+ long sl;
|
||||
+ unsigned long ul;
|
||||
+
|
||||
+ assert(out_uid);
|
||||
+
|
||||
+ index = PyNumber_Index(in_obj);
|
||||
+ if (index != NULL) {
|
||||
+ number = PyNumber_Long(index);
|
||||
+ Py_DECREF(index);
|
||||
+ }
|
||||
+ if (number == NULL) {
|
||||
+ PyErr_SetString(PyExc_TypeError, "user id must be integer");
|
||||
+ return 0;
|
||||
+ }
|
||||
+
|
||||
+ /* Special case: support -1 (e.g. for use by chown) */
|
||||
+ sl = PyLong_AsLong(number);
|
||||
+ if (PyErr_Occurred()) {
|
||||
+ PyErr_Clear();
|
||||
+ } else if (sl == -1) {
|
||||
+ Py_DECREF(number);
|
||||
+ *out_uid = (uid_t)-1;
|
||||
+ return 1;
|
||||
+ }
|
||||
+
|
||||
+ /* Otherwise, it must be >= 0 */
|
||||
+ ul = PyLong_AsUnsignedLong(number);
|
||||
+ Py_DECREF(number);
|
||||
+ *out_uid = ul;
|
||||
+ /* read back the value to see if it fitted in uid_t */
|
||||
+ if (PyErr_Occurred() || *out_uid != ul) {
|
||||
+ PyErr_SetString(PyExc_OverflowError,
|
||||
+ "user id is not in range(-1, 2^32-1)");
|
||||
+ return 0;
|
||||
+ }
|
||||
+ return 1;
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+_PyArg_ParseGid(PyObject *in_obj, gid_t *out_gid)
|
||||
+{
|
||||
+ PyObject *index, *number = NULL;
|
||||
+ long sl;
|
||||
+ unsigned long ul;
|
||||
+
|
||||
+ assert(out_gid);
|
||||
+
|
||||
+ index = PyNumber_Index(in_obj);
|
||||
+ if (index != NULL) {
|
||||
+ number = PyNumber_Long(index);
|
||||
+ Py_DECREF(index);
|
||||
+ }
|
||||
+ if (number == NULL) {
|
||||
+ PyErr_SetString(PyExc_TypeError, "group id must be integer");
|
||||
+ return 0;
|
||||
+ }
|
||||
+
|
||||
+ /* Special case: support -1 (e.g. for use by chown) */
|
||||
+ sl = PyLong_AsLong(number);
|
||||
+ if (PyErr_Occurred()) {
|
||||
+ PyErr_Clear();
|
||||
+ } else if (sl == -1) {
|
||||
+ Py_DECREF(number);
|
||||
+ *out_gid = (gid_t)-1;
|
||||
+ return 1;
|
||||
+ }
|
||||
+
|
||||
+ ul = PyLong_AsUnsignedLong(number);
|
||||
+ Py_DECREF(number);
|
||||
+ *out_gid = ul;
|
||||
+ /* read back the value to see if it fitted in gid_t */
|
||||
+ if (PyErr_Occurred() || *out_gid != ul) {
|
||||
+ PyErr_SetString(PyExc_OverflowError,
|
||||
+ "group id is not in range(-1, 2^32-1)");
|
||||
+ return 0;
|
||||
+ }
|
||||
+ return 1;
|
||||
+}
|
||||
+
|
||||
#ifdef __cplusplus
|
||||
};
|
||||
#endif
|
||||
|
30
00178-dont-duplicate-flags-in-sysconfig.patch
Normal file
30
00178-dont-duplicate-flags-in-sysconfig.patch
Normal file
@ -0,0 +1,30 @@
|
||||
diff -r 39b9b05c3085 Lib/distutils/sysconfig.py
|
||||
--- a/Lib/distutils/sysconfig.py Wed Apr 10 00:27:23 2013 +0200
|
||||
+++ b/Lib/distutils/sysconfig.py Wed Apr 10 10:14:18 2013 +0200
|
||||
@@ -362,7 +362,10 @@
|
||||
done[n] = item = ""
|
||||
if found:
|
||||
after = value[m.end():]
|
||||
- value = value[:m.start()] + item + after
|
||||
+ value = value[:m.start()]
|
||||
+ if item.strip() not in value:
|
||||
+ value += item
|
||||
+ value += after
|
||||
if "$" in after:
|
||||
notdone[name] = value
|
||||
else:
|
||||
diff -r 39b9b05c3085 Lib/sysconfig.py
|
||||
--- a/Lib/sysconfig.py Wed Apr 10 00:27:23 2013 +0200
|
||||
+++ b/Lib/sysconfig.py Wed Apr 10 10:14:18 2013 +0200
|
||||
@@ -296,7 +296,10 @@
|
||||
|
||||
if found:
|
||||
after = value[m.end():]
|
||||
- value = value[:m.start()] + item + after
|
||||
+ value = value[:m.start()]
|
||||
+ if item.strip() not in value:
|
||||
+ value += item
|
||||
+ value += after
|
||||
if "$" in after:
|
||||
notdone[name] = value
|
||||
else:
|
@ -1,7 +1,7 @@
|
||||
diff -up ./configure.autotool-intermediates ./configure
|
||||
--- ./configure.autotool-intermediates 2013-03-25 16:11:38.140657282 -0400
|
||||
+++ ./configure 2013-03-25 16:11:46.922656680 -0400
|
||||
@@ -779,6 +779,8 @@ with_thread
|
||||
--- ./configure.autotool-intermediates 2013-04-09 14:52:49.831773426 +0200
|
||||
+++ ./configure 2013-04-09 14:52:53.204765347 +0200
|
||||
@@ -802,6 +802,8 @@ with_thread
|
||||
enable_ipv6
|
||||
with_doc_strings
|
||||
with_tsc
|
||||
@ -10,7 +10,7 @@ diff -up ./configure.autotool-intermediates ./configure
|
||||
with_pymalloc
|
||||
with_valgrind
|
||||
with_systemtap
|
||||
@@ -1457,6 +1459,8 @@ Optional Packages:
|
||||
@@ -1479,6 +1481,8 @@ Optional Packages:
|
||||
deprecated; use --with(out)-threads
|
||||
--with(out)-doc-strings disable/enable documentation strings
|
||||
--with(out)-tsc enable/disable timestamp counter profile
|
||||
@ -19,7 +19,7 @@ diff -up ./configure.autotool-intermediates ./configure
|
||||
--with(out)-pymalloc disable/enable specialized mallocs
|
||||
--with-valgrind Enable Valgrind support
|
||||
--with(out)-systemtap disable/enable SystemTap support
|
||||
@@ -6471,7 +6475,7 @@ then
|
||||
@@ -6529,7 +6533,7 @@ then
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether gcc supports ParseTuple __format__" >&5
|
||||
$as_echo_n "checking whether gcc supports ParseTuple __format__... " >&6; }
|
||||
save_CFLAGS=$CFLAGS
|
||||
@ -28,7 +28,7 @@ diff -up ./configure.autotool-intermediates ./configure
|
||||
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||
/* end confdefs.h. */
|
||||
|
||||
@@ -10008,6 +10012,50 @@ $as_echo "#define WITH_TSC 1" >>confdefs
|
||||
@@ -10117,6 +10121,50 @@ $as_echo "#define WITH_TSC 1" >>confdefs
|
||||
|
||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
|
||||
$as_echo "yes" >&6; }
|
||||
@ -80,3 +80,15 @@ diff -up ./configure.autotool-intermediates ./configure
|
||||
$as_echo "no" >&6; }
|
||||
fi
|
||||
diff -up ./pyconfig.h.in.autotool-intermediates ./pyconfig.h.in
|
||||
--- ./pyconfig.h.in.autotool-intermediates 2013-04-09 14:52:49.829773431 +0200
|
||||
+++ ./pyconfig.h.in 2013-04-09 14:52:53.488764667 +0200
|
||||
@@ -1193,9 +1193,6 @@
|
||||
/* Define if setpgrp() must be called as setpgrp(0, 0). */
|
||||
#undef SETPGRP_HAVE_ARG
|
||||
|
||||
-/* Define this to be extension of shared libraries (including the dot!). */
|
||||
-#undef SHLIB_EXT
|
||||
-
|
||||
/* Define if i>>j for signed int i does not extend the sign bit when i < 0 */
|
||||
#undef SIGNED_RIGHT_SHIFT_ZERO_FILLS
|
||||
|
||||
|
60
python3.spec
60
python3.spec
@ -125,8 +125,8 @@
|
||||
# ==================
|
||||
Summary: Version 3 of the Python programming language aka Python 3000
|
||||
Name: python3
|
||||
Version: %{pybasever}.0
|
||||
Release: 10%{?dist}
|
||||
Version: %{pybasever}.1
|
||||
Release: 1%{?dist}
|
||||
License: Python
|
||||
Group: Development/Languages
|
||||
|
||||
@ -222,9 +222,9 @@ Source7: pyfuntop.stp
|
||||
# Was Patch0 in ivazquez' python3000 specfile:
|
||||
Patch1: Python-3.1.1-rpath.patch
|
||||
|
||||
# The four TestMIMEAudio tests fail due to "audiotest.au" not being packaged.
|
||||
# It's simplest to remove them:
|
||||
Patch3: 00003-remove-mimeaudio-tests.patch
|
||||
# Some tests were removed due to audiotest.au not being packaged. This was
|
||||
# however added to the archive in 3.3.1, so we no longer delete the tests.
|
||||
# Patch3: 00003-remove-mimeaudio-tests.patch
|
||||
|
||||
# 00055 #
|
||||
# Systemtap support: add statically-defined probe points
|
||||
@ -462,9 +462,7 @@ Patch156: 00156-gdb-autoload-safepath.patch
|
||||
Patch157: 00157-uid-gid-overflows.patch
|
||||
|
||||
# 00158 #
|
||||
# Patch158: 00158-fix-hashlib-leak.patch
|
||||
# in python.spec
|
||||
# TODO: python3 status?
|
||||
# Upstream as of Python 3.3.1
|
||||
|
||||
# 00159 #
|
||||
# Patch159: 00159-correct-libdb-include-path.patch
|
||||
@ -528,13 +526,13 @@ Patch164: 00164-disable-interrupted_write-tests-on-ppc.patch
|
||||
# TODO: python3 status?
|
||||
|
||||
# 00171 #
|
||||
# python.spec had:
|
||||
# Patch171: 00171-raise-correct-exception-when-dev-urandom-is-missing.patch
|
||||
# in python.spec
|
||||
# TODO: python3 status?
|
||||
|
||||
# 00172 #
|
||||
# python.spec had:
|
||||
# Patch172: 00172-use-poll-for-multiprocessing-socket-connection.patch
|
||||
# in python.spec
|
||||
# TODO: python3 status?
|
||||
|
||||
# 00173 #
|
||||
@ -556,12 +554,8 @@ Patch173: 00173-workaround-ENOPROTOOPT-in-bind_port.patch
|
||||
Patch175: 00175-fix-configure-Wformat.patch
|
||||
|
||||
# 00176 #
|
||||
# Potential patch for so extensions being wrong since SOABI in upstream python3.
|
||||
# http://bugs.python.org/issue16754
|
||||
# (rhbz#889784)
|
||||
# Does not affect python2 (python2 does not have compiled extensions with the
|
||||
# problematic information)
|
||||
Patch176: 00176-upstream-issue16754-so-extension.patch
|
||||
# Fixed upstream as of Python 3.3.1
|
||||
# Patch176: 00176-upstream-issue16754-so-extension.patch
|
||||
|
||||
# 00177 #
|
||||
# Patch for potential unicode error when determining OS release names
|
||||
@ -570,6 +564,11 @@ Patch176: 00176-upstream-issue16754-so-extension.patch
|
||||
# Does not affect python2 (python2 uses a byte string so it doesn't need to decode)
|
||||
Patch177: 00177-platform-unicode.patch
|
||||
|
||||
# 00178 #
|
||||
# Don't duplicate various FLAGS in sysconfig values
|
||||
# http://bugs.python.org/issue17679
|
||||
# Does not affect python2 AFAICS (different sysconfig values initialization)
|
||||
Patch178: 00178-dont-duplicate-flags-in-sysconfig.patch
|
||||
|
||||
# (New patches go here ^^^)
|
||||
#
|
||||
@ -744,7 +743,7 @@ done
|
||||
# Apply patches:
|
||||
#
|
||||
%patch1 -p1
|
||||
%patch3 -p1 -b .remove-mimeaudio-tests
|
||||
# 3: upstream as of Python 3.3.1
|
||||
|
||||
%if 0%{?with_systemtap}
|
||||
%patch55 -p1 -b .systemtap
|
||||
@ -819,8 +818,9 @@ done
|
||||
%patch173 -p1
|
||||
#00174: TODO
|
||||
%patch175 -p1
|
||||
%patch176 -p1
|
||||
# 00176: upstream as of Python 3.3.1
|
||||
%patch177 -p1
|
||||
%patch178 -p1
|
||||
|
||||
# Currently (2010-01-15), http://docs.python.org/library is for 2.6, and there
|
||||
# are many differences between 2.6 and the Python 3 library.
|
||||
@ -868,7 +868,7 @@ for f in pyconfig.h.in configure ; do
|
||||
done
|
||||
|
||||
# Rerun the autotools:
|
||||
PATH=~/autoconf-2.65/bin:$PATH autoreconf
|
||||
autoreconf
|
||||
|
||||
# Regenerate the patch:
|
||||
gendiff . .autotool-intermediates > %{PATCH5000}
|
||||
@ -969,12 +969,6 @@ InstallPython() {
|
||||
|
||||
pushd $ConfDir
|
||||
|
||||
# Workaround for http://bugs.python.org/issue14774 : Lib/_sysconfigdata.py
|
||||
# is in the srcdir but contains per-config data.
|
||||
# Regenerate it each time:
|
||||
rm -f ../../Lib/_sysconfigdata.py
|
||||
make $topdir/Lib/_sysconfigdata.py
|
||||
|
||||
make install DESTDIR=%{buildroot} INSTALL="install -p"
|
||||
|
||||
popd
|
||||
@ -1256,13 +1250,6 @@ CheckPython() {
|
||||
# Note that we're running the tests using the version of the code in the
|
||||
# builddir, not in the buildroot.
|
||||
|
||||
# Workaround for http://bugs.python.org/issue14774, as per the install
|
||||
# stanza (albeit from a different directory):
|
||||
rm -f Lib/_sysconfigdata.py
|
||||
pushd $ConfDir
|
||||
make $topdir/Lib/_sysconfigdata.py
|
||||
popd
|
||||
|
||||
# Run the upstream test suite, setting "WITHIN_PYTHON_RPM_BUILD" so that the
|
||||
# our non-standard decorators take effect on the relevant tests:
|
||||
# @unittest._skipInRpmBuild(reason)
|
||||
@ -1677,6 +1664,15 @@ rm -fr %{buildroot}
|
||||
# ======================================================
|
||||
|
||||
%changelog
|
||||
* Tue Apr 09 2013 Bohuslav Kabrda <bkabrda@redhat.com> - 3.3.1-1
|
||||
- Updated to Python 3.3.1.
|
||||
- Refreshed patches: 55 (systemtap), 111 (no static lib), 146 (hashlib fips),
|
||||
153 (fix test_gdb noise), 157 (uid, gid overflow - fixed upstream, just
|
||||
keeping few more downstream tests)
|
||||
- Removed patches: 3 (audiotest.au made it to upstream tarball)
|
||||
- Removed workaround for http://bugs.python.org/issue14774, discussed in
|
||||
http://bugs.python.org/issue15298 and fixed in revision 24d52d3060e8.
|
||||
|
||||
* Mon Mar 25 2013 David Malcolm <dmalcolm@redhat.com> - 3.3.0-10
|
||||
- fix gcc 4.8 incompatibility (rhbz#927358); regenerate autotool intermediates
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user