[Python-checkins] r76764 - in python/branches/py3k: Lib/test/test_tuple.py Misc/NEWS Objects/tupleobject.c
antoine.pitrou
python-checkins at python.org
Sat Dec 12 20:18:27 CET 2009
Author: antoine.pitrou
Date: Sat Dec 12 20:18:27 2009
New Revision: 76764
Log:
Merged revisions 76763 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r76763 | antoine.pitrou | 2009-12-12 20:13:08 +0100 (sam., 12 déc. 2009) | 7 lines
Issue #7466: segmentation fault when the garbage collector is called
in the middle of populating a tuple. Patch by Florent Xicluna.
(note: no NEWS entry for trunk since the bug was introduced in 2.7/3.1)
........
Modified:
python/branches/py3k/ (props changed)
python/branches/py3k/Lib/test/test_tuple.py
python/branches/py3k/Misc/NEWS
python/branches/py3k/Objects/tupleobject.c
Modified: python/branches/py3k/Lib/test/test_tuple.py
==============================================================================
--- python/branches/py3k/Lib/test/test_tuple.py (original)
+++ python/branches/py3k/Lib/test/test_tuple.py Sat Dec 12 20:18:27 2009
@@ -146,6 +146,9 @@
pass
self.check_track_dynamic(MyTuple, True)
+ def test_bug7466(self):
+ # Trying to untrack an unfinished tuple could crash Python
+ self._not_tracked(tuple(gc.collect() for i in range(101)))
def test_main():
support.run_unittest(TupleTest)
Modified: python/branches/py3k/Misc/NEWS
==============================================================================
--- python/branches/py3k/Misc/NEWS (original)
+++ python/branches/py3k/Misc/NEWS Sat Dec 12 20:18:27 2009
@@ -12,6 +12,9 @@
Core and Builtins
-----------------
+- Issue #7466: segmentation fault when the garbage collector is called
+ in the middle of populating a tuple. Patch by Florent Xicluna.
+
- Issue #7419: setlocale() could crash the interpreter on Windows when called
with invalid values.
Modified: python/branches/py3k/Objects/tupleobject.c
==============================================================================
--- python/branches/py3k/Objects/tupleobject.c (original)
+++ python/branches/py3k/Objects/tupleobject.c Sat Dec 12 20:18:27 2009
@@ -850,7 +850,8 @@
/* XXX UNREF/NEWREF interface should be more symmetrical */
_Py_DEC_REFTOTAL;
- _PyObject_GC_UNTRACK(v);
+ if (_PyObject_GC_IS_TRACKED(v))
+ _PyObject_GC_UNTRACK(v);
_Py_ForgetReference((PyObject *) v);
/* DECREF items deleted by shrinkage */
for (i = newsize; i < oldsize; i++) {
More information about the Python-checkins
mailing list