gh-106529: Fix subtle Tier 2 edge case with list iterator (#106756)
The Tier 2 opcode _IS_ITER_EXHAUSTED_LIST (and _TUPLE) didn't set it->it_seq to NULL, causing a subtle bug that resulted in test_exhausted_iterator in list_tests.py to fail when running all tests with -Xuops. The bug was introduced in gh-106696. Added this as an explicit test. Also fixed the dependencies for ceval.o -- it depends on executor_cases.c.h.
This commit is contained in:
@@ -2448,7 +2448,12 @@ dummy_func(
|
||||
_PyListIterObject *it = (_PyListIterObject *)iter;
|
||||
assert(Py_TYPE(iter) == &PyListIter_Type);
|
||||
PyListObject *seq = it->it_seq;
|
||||
if (seq == NULL || it->it_index >= PyList_GET_SIZE(seq)) {
|
||||
if (seq == NULL) {
|
||||
exhausted = Py_True;
|
||||
}
|
||||
else if (it->it_index >= PyList_GET_SIZE(seq)) {
|
||||
Py_DECREF(seq);
|
||||
it->it_seq = NULL;
|
||||
exhausted = Py_True;
|
||||
}
|
||||
else {
|
||||
@@ -2499,7 +2504,12 @@ dummy_func(
|
||||
_PyTupleIterObject *it = (_PyTupleIterObject *)iter;
|
||||
assert(Py_TYPE(iter) == &PyTupleIter_Type);
|
||||
PyTupleObject *seq = it->it_seq;
|
||||
if (seq == NULL || it->it_index >= PyTuple_GET_SIZE(seq)) {
|
||||
if (seq == NULL) {
|
||||
exhausted = Py_True;
|
||||
}
|
||||
else if (it->it_index >= PyTuple_GET_SIZE(seq)) {
|
||||
Py_DECREF(seq);
|
||||
it->it_seq = NULL;
|
||||
exhausted = Py_True;
|
||||
}
|
||||
else {
|
||||
|
||||
Reference in New Issue
Block a user