mirror of
https://github.com/python/cpython.git
synced 2025-12-04 00:30:19 +00:00
Forward-port of r52136,52138: a review of overflow-detecting code.
* unified the way intobject, longobject and mystrtoul handle
values around -sys.maxint-1.
* in general, trying to entierely avoid overflows in any computation
involving signed ints or longs is extremely involved. Fixed a few
simple cases where a compiler might be too clever (but that's all
guesswork).
* more overflow checks against bad data in marshal.c.
* 2.5 specific: fixed a number of places that were still confusing int
and Py_ssize_t. Some of them could potentially have caused
"real-world" breakage.
* list.pop(x): fixing overflow issues on x was messy. I just reverted
to PyArg_ParseTuple("n"), which does the right thing. (An obscure
test was trying to give a Decimal to list.pop()... doesn't make
sense any more IMHO)
* trying to write a few tests...
This commit is contained in:
parent
0d2f498a4c
commit
7ccbca93a2
19 changed files with 186 additions and 106 deletions
|
|
@ -1652,20 +1652,18 @@ _PySequence_IterSearch(PyObject *seq, PyObject *obj, int operation)
|
|||
if (cmp > 0) {
|
||||
switch (operation) {
|
||||
case PY_ITERSEARCH_COUNT:
|
||||
++n;
|
||||
if (n <= 0) {
|
||||
/* XXX(nnorwitz): int means ssize_t */
|
||||
if (n == PY_SSIZE_T_MAX) {
|
||||
PyErr_SetString(PyExc_OverflowError,
|
||||
"count exceeds C int size");
|
||||
"count exceeds C integer size");
|
||||
goto Fail;
|
||||
}
|
||||
++n;
|
||||
break;
|
||||
|
||||
case PY_ITERSEARCH_INDEX:
|
||||
if (wrapped) {
|
||||
/* XXX(nnorwitz): int means ssize_t */
|
||||
PyErr_SetString(PyExc_OverflowError,
|
||||
"index exceeds C int size");
|
||||
"index exceeds C integer size");
|
||||
goto Fail;
|
||||
}
|
||||
goto Done;
|
||||
|
|
@ -1680,9 +1678,9 @@ _PySequence_IterSearch(PyObject *seq, PyObject *obj, int operation)
|
|||
}
|
||||
|
||||
if (operation == PY_ITERSEARCH_INDEX) {
|
||||
++n;
|
||||
if (n <= 0)
|
||||
if (n == PY_SSIZE_T_MAX)
|
||||
wrapped = 1;
|
||||
++n;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue