diff options
Diffstat (limited to 'Objects/weakrefobject.c')
| -rw-r--r-- | Objects/weakrefobject.c | 16 | 
1 files changed, 12 insertions, 4 deletions
| diff --git a/Objects/weakrefobject.c b/Objects/weakrefobject.c index 040e93810d..302cdc9edf 100644 --- a/Objects/weakrefobject.c +++ b/Objects/weakrefobject.c @@ -884,7 +884,8 @@ PyObject_ClearWeakRefs(PyObject *object)              current->wr_callback = NULL;              clear_weakref(current);              if (callback != NULL) { -                handle_callback(current, callback); +                if (current->ob_refcnt > 0) +                    handle_callback(current, callback);                  Py_DECREF(callback);              }          } @@ -902,9 +903,15 @@ PyObject_ClearWeakRefs(PyObject *object)              for (i = 0; i < count; ++i) {                  PyWeakReference *next = current->wr_next; -                Py_INCREF(current); -                PyTuple_SET_ITEM(tuple, i * 2, (PyObject *) current); -                PyTuple_SET_ITEM(tuple, i * 2 + 1, current->wr_callback); +                if (current->ob_refcnt > 0) +                { +                    Py_INCREF(current); +                    PyTuple_SET_ITEM(tuple, i * 2, (PyObject *) current); +                    PyTuple_SET_ITEM(tuple, i * 2 + 1, current->wr_callback); +                } +                else { +                    Py_DECREF(current->wr_callback); +                }                  current->wr_callback = NULL;                  clear_weakref(current);                  current = next; @@ -912,6 +919,7 @@ PyObject_ClearWeakRefs(PyObject *object)              for (i = 0; i < count; ++i) {                  PyObject *callback = PyTuple_GET_ITEM(tuple, i * 2 + 1); +                /* The tuple may have slots left to NULL */                  if (callback != NULL) {                      PyObject *item = PyTuple_GET_ITEM(tuple, i * 2);                      handle_callback((PyWeakReference *)item, callback); | 
