Commit bc09964b authored by Mark Dickinson's avatar Mark Dickinson

Merged revisions 77821 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r77821 | mark.dickinson | 2010-01-29 17:11:39 +0000 (Fri, 29 Jan 2010) | 3 lines

  Issue #7788: Fix a crash produced by deleting a list slice with huge
  step value.  Patch by Marcin Bachry.
........
parent 8b441d0d
...@@ -540,6 +540,9 @@ class CommonTest(seq_tests.CommonTest): ...@@ -540,6 +540,9 @@ class CommonTest(seq_tests.CommonTest):
a = self.type2test(range(10)) a = self.type2test(range(10))
a[::2] = tuple(range(5)) a[::2] = tuple(range(5))
self.assertEqual(a, self.type2test([0, 1, 1, 3, 2, 5, 3, 7, 4, 9])) self.assertEqual(a, self.type2test([0, 1, 1, 3, 2, 5, 3, 7, 4, 9]))
# test issue7788
a = self.type2test(range(10))
del a[9::1<<333]
def test_constructor_exception_handling(self): def test_constructor_exception_handling(self):
# Bug #1242657 # Bug #1242657
......
...@@ -1011,6 +1011,9 @@ class NumberTest(BaseTest): ...@@ -1011,6 +1011,9 @@ class NumberTest(BaseTest):
a = array.array(self.typecode, range(10)) a = array.array(self.typecode, range(10))
del a[::1000] del a[::1000]
self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9])) self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
# test issue7788
a = array.array(self.typecode, range(10))
del a[9::1<<333]
def test_assignment(self): def test_assignment(self):
a = array.array(self.typecode, range(10)) a = array.array(self.typecode, range(10))
......
...@@ -600,7 +600,7 @@ class ByteArrayTest(BaseBytesTest): ...@@ -600,7 +600,7 @@ class ByteArrayTest(BaseBytesTest):
self.assertEqual(b, bytearray([0, 1, 2, 42, 42, 42, 3, 4, 5, 6, 7, 8, 9])) self.assertEqual(b, bytearray([0, 1, 2, 42, 42, 42, 3, 4, 5, 6, 7, 8, 9]))
def test_extended_set_del_slice(self): def test_extended_set_del_slice(self):
indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300) indices = (0, None, 1, 3, 19, 300, 1<<333, -1, -2, -31, -300)
for start in indices: for start in indices:
for stop in indices: for stop in indices:
# Skip invalid step 0 # Skip invalid step 0
......
...@@ -12,6 +12,9 @@ What's New in Python 3.2 Alpha 1? ...@@ -12,6 +12,9 @@ What's New in Python 3.2 Alpha 1?
Core and Builtins Core and Builtins
----------------- -----------------
- Issue #7788: Fix an interpreter crash produced by deleting a list
slice with very large step value.
- Issue #7766: Change sys.getwindowsversion() return value to a named - Issue #7766: Change sys.getwindowsversion() return value to a named
tuple and add the additional members returned in an OSVERSIONINFOEX tuple and add the additional members returned in an OSVERSIONINFOEX
structure. The new members are service_pack_major, service_pack_minor, structure. The new members are service_pack_major, service_pack_minor,
......
...@@ -2199,8 +2199,9 @@ array_ass_subscr(arrayobject* self, PyObject* item, PyObject* value) ...@@ -2199,8 +2199,9 @@ array_ass_subscr(arrayobject* self, PyObject* item, PyObject* value)
} }
else if (needed == 0) { else if (needed == 0) {
/* Delete slice */ /* Delete slice */
Py_ssize_t cur, i; size_t cur;
Py_ssize_t i;
if (step < 0) { if (step < 0) {
stop = start + 1; stop = start + 1;
start = stop + step * (slicelength - 1) - 1; start = stop + step * (slicelength - 1) - 1;
......
...@@ -642,7 +642,8 @@ bytearray_ass_subscript(PyByteArrayObject *self, PyObject *index, PyObject *valu ...@@ -642,7 +642,8 @@ bytearray_ass_subscript(PyByteArrayObject *self, PyObject *index, PyObject *valu
else { else {
if (needed == 0) { if (needed == 0) {
/* Delete slice */ /* Delete slice */
Py_ssize_t cur, i; size_t cur;
Py_ssize_t i;
if (!_canresize(self)) if (!_canresize(self))
return -1; return -1;
......
...@@ -2444,7 +2444,8 @@ list_ass_subscript(PyListObject* self, PyObject* item, PyObject* value) ...@@ -2444,7 +2444,8 @@ list_ass_subscript(PyListObject* self, PyObject* item, PyObject* value)
if (value == NULL) { if (value == NULL) {
/* delete slice */ /* delete slice */
PyObject **garbage; PyObject **garbage;
Py_ssize_t cur, i; size_t cur;
Py_ssize_t i;
if (slicelength <= 0) if (slicelength <= 0)
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment