Commit 8042f4af authored by Benjamin Peterson's avatar Benjamin Peterson

Merged revisions 84714 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r84714 | benjamin.peterson | 2010-09-11 11:02:03 -0500 (Sat, 11 Sep 2010) | 1 line

  check for NULL tp_as_mapping in PySequence_(Get/Set/Del)Slice #9834
........
parent 40f7e11f
...@@ -105,6 +105,10 @@ Core and Builtins ...@@ -105,6 +105,10 @@ Core and Builtins
C-API C-API
----- -----
- Issue #9834: Don't segfault in PySequence_GetSlice, PySequence_SetSlice, or
PySequence_DelSlice when the object doesn't have any mapping operations
defined.
- Issue #5753: A new C API function, :cfunc:`PySys_SetArgvEx`, allows - Issue #5753: A new C API function, :cfunc:`PySys_SetArgvEx`, allows
embedders of the interpreter to set sys.argv without also modifying embedders of the interpreter to set sys.argv without also modifying
sys.path. This helps fix `CVE-2008-5983 sys.path. This helps fix `CVE-2008-5983
......
...@@ -1623,7 +1623,7 @@ PySequence_GetSlice(PyObject *s, Py_ssize_t i1, Py_ssize_t i2) ...@@ -1623,7 +1623,7 @@ PySequence_GetSlice(PyObject *s, Py_ssize_t i1, Py_ssize_t i2)
if (!s) return null_error(); if (!s) return null_error();
mp = s->ob_type->tp_as_mapping; mp = s->ob_type->tp_as_mapping;
if (mp->mp_subscript) { if (mp && mp->mp_subscript) {
PyObject *res; PyObject *res;
PyObject *slice = _PySlice_FromIndices(i1, i2); PyObject *slice = _PySlice_FromIndices(i1, i2);
if (!slice) if (!slice)
...@@ -1701,7 +1701,7 @@ PySequence_SetSlice(PyObject *s, Py_ssize_t i1, Py_ssize_t i2, PyObject *o) ...@@ -1701,7 +1701,7 @@ PySequence_SetSlice(PyObject *s, Py_ssize_t i1, Py_ssize_t i2, PyObject *o)
} }
mp = s->ob_type->tp_as_mapping; mp = s->ob_type->tp_as_mapping;
if (mp->mp_ass_subscript) { if (mp && mp->mp_ass_subscript) {
int res; int res;
PyObject *slice = _PySlice_FromIndices(i1, i2); PyObject *slice = _PySlice_FromIndices(i1, i2);
if (!slice) if (!slice)
...@@ -1726,7 +1726,7 @@ PySequence_DelSlice(PyObject *s, Py_ssize_t i1, Py_ssize_t i2) ...@@ -1726,7 +1726,7 @@ PySequence_DelSlice(PyObject *s, Py_ssize_t i1, Py_ssize_t i2)
} }
mp = s->ob_type->tp_as_mapping; mp = s->ob_type->tp_as_mapping;
if (mp->mp_ass_subscript) { if (mp && mp->mp_ass_subscript) {
int res; int res;
PyObject *slice = _PySlice_FromIndices(i1, i2); PyObject *slice = _PySlice_FromIndices(i1, i2);
if (!slice) if (!slice)
......
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