Issue #20437: Fixed 21 potential bugs when deleting objects references.

This commit is contained in:
Serhiy Storchaka 2014-02-09 13:33:53 +02:00
parent e9c31470e1
commit 505ff755d7
16 changed files with 34 additions and 63 deletions

View File

@ -10,6 +10,8 @@ What's New in Python 3.3.4 release candidate 1?
Core and Builtins Core and Builtins
----------------- -----------------
- Issue #20437: Fixed 21 potential bugs when deleting objects references.
- Issue #20538: UTF-7 incremental decoder produced inconsistant string when - Issue #20538: UTF-7 incremental decoder produced inconsistant string when
input was truncated in BASE64 section. input was truncated in BASE64 section.

View File

@ -159,10 +159,8 @@ _DictRemover_call(PyObject *myself, PyObject *args, PyObject *kw)
if (-1 == PyDict_DelItem(self->dict, self->key)) if (-1 == PyDict_DelItem(self->dict, self->key))
/* XXX Error context */ /* XXX Error context */
PyErr_WriteUnraisable(Py_None); PyErr_WriteUnraisable(Py_None);
Py_DECREF(self->key); Py_CLEAR(self->key);
self->key = NULL; Py_CLEAR(self->dict);
Py_DECREF(self->dict);
self->dict = NULL;
} }
Py_INCREF(Py_None); Py_INCREF(Py_None);
return Py_None; return Py_None;
@ -2930,10 +2928,8 @@ static int
PyCFuncPtr_set_restype(PyCFuncPtrObject *self, PyObject *ob) PyCFuncPtr_set_restype(PyCFuncPtrObject *self, PyObject *ob)
{ {
if (ob == NULL) { if (ob == NULL) {
Py_XDECREF(self->restype); Py_CLEAR(self->restype);
self->restype = NULL; Py_CLEAR(self->checker);
Py_XDECREF(self->checker);
self->checker = NULL;
return 0; return 0;
} }
if (ob != Py_None && !PyType_stgdict(ob) && !PyCallable_Check(ob)) { if (ob != Py_None && !PyType_stgdict(ob) && !PyCallable_Check(ob)) {
@ -2976,10 +2972,8 @@ PyCFuncPtr_set_argtypes(PyCFuncPtrObject *self, PyObject *ob)
PyObject *converters; PyObject *converters;
if (ob == NULL || ob == Py_None) { if (ob == NULL || ob == Py_None) {
Py_XDECREF(self->converters); Py_CLEAR(self->converters);
self->converters = NULL; Py_CLEAR(self->argtypes);
Py_XDECREF(self->argtypes);
self->argtypes = NULL;
} else { } else {
converters = converters_from_argtypes(ob); converters = converters_from_argtypes(ob);
if (!converters) if (!converters)

View File

@ -230,8 +230,7 @@ int pysqlite_build_row_cast_map(pysqlite_Cursor* self)
if (converter != Py_None) { if (converter != Py_None) {
Py_DECREF(converter); Py_DECREF(converter);
} }
Py_XDECREF(self->row_cast_map); Py_CLEAR(self->row_cast_map);
self->row_cast_map = NULL;
return -1; return -1;
} }
@ -443,8 +442,7 @@ PyObject* _pysqlite_query_execute(pysqlite_Cursor* self, int multiple, PyObject*
self->locked = 1; self->locked = 1;
self->reset = 0; self->reset = 0;
Py_XDECREF(self->next_row); Py_CLEAR(self->next_row);
self->next_row = NULL;
if (multiple) { if (multiple) {
/* executemany() */ /* executemany() */
@ -860,8 +858,7 @@ PyObject* pysqlite_cursor_iternext(pysqlite_Cursor *self)
if (!self->next_row) { if (!self->next_row) {
if (self->statement) { if (self->statement) {
(void)pysqlite_statement_reset(self->statement); (void)pysqlite_statement_reset(self->statement);
Py_DECREF(self->statement); Py_CLEAR(self->statement);
self->statement = NULL;
} }
return NULL; return NULL;
} }

View File

@ -693,8 +693,7 @@ typedef struct {
static void static void
path_cleanup(path_t *path) { path_cleanup(path_t *path) {
if (path->cleanup) { if (path->cleanup) {
Py_DECREF(path->cleanup); Py_CLEAR(path->cleanup);
path->cleanup = NULL;
} }
} }

View File

@ -314,8 +314,7 @@ call_with_frame(PyCodeObject *c, PyObject* func, PyObject* args,
} }
else { else {
if (trace_frame(tstate, f, PyTrace_RETURN, res) < 0) { if (trace_frame(tstate, f, PyTrace_RETURN, res) < 0) {
Py_XDECREF(res); Py_CLEAR(res);
res = NULL;
} }
} }
#else #else

View File

@ -231,8 +231,7 @@ set_hook(const char *funcname, PyObject **hook_var, PyObject *args)
if (!PyArg_ParseTuple(args, buf, &function)) if (!PyArg_ParseTuple(args, buf, &function))
return NULL; return NULL;
if (function == Py_None) { if (function == Py_None) {
Py_XDECREF(*hook_var); Py_CLEAR(*hook_var);
*hook_var = NULL;
} }
else if (PyCallable_Check(function)) { else if (PyCallable_Check(function)) {
PyObject *tmp = *hook_var; PyObject *tmp = *hook_var;
@ -827,7 +826,7 @@ on_completion_display_matches_hook(char **matches,
(r != Py_None && PyLong_AsLong(r) == -1 && PyErr_Occurred())) { (r != Py_None && PyLong_AsLong(r) == -1 && PyErr_Occurred())) {
goto error; goto error;
} }
Py_XDECREF(r); r=NULL; Py_CLEAR(r);
if (0) { if (0) {
error: error:

View File

@ -74,8 +74,7 @@ reap_obj(pylist fd2obj[FD_SETSIZE + 1])
{ {
int i; int i;
for (i = 0; i < FD_SETSIZE + 1 && fd2obj[i].sentinel >= 0; i++) { for (i = 0; i < FD_SETSIZE + 1 && fd2obj[i].sentinel >= 0; i++) {
Py_XDECREF(fd2obj[i].obj); Py_CLEAR(fd2obj[i].obj);
fd2obj[i].obj = NULL;
} }
fd2obj[0].sentinel = -1; fd2obj[0].sentinel = -1;
} }

View File

@ -1305,12 +1305,9 @@ finisignal(void)
Py_XDECREF(func); Py_XDECREF(func);
} }
Py_XDECREF(IntHandler); Py_CLEAR(IntHandler);
IntHandler = NULL; Py_CLEAR(DefaultHandler);
Py_XDECREF(DefaultHandler); Py_CLEAR(IgnoreHandler);
DefaultHandler = NULL;
Py_XDECREF(IgnoreHandler);
IgnoreHandler = NULL;
} }

View File

@ -197,8 +197,7 @@ syslog_closelog(PyObject *self, PyObject *unused)
{ {
if (S_log_open) { if (S_log_open) {
closelog(); closelog();
Py_XDECREF(S_ident_o); Py_CLEAR(S_ident_o);
S_ident_o = NULL;
S_log_open = 0; S_log_open = 0;
} }
Py_INCREF(Py_None); Py_INCREF(Py_None);

View File

@ -392,8 +392,7 @@ PyZlib_compressobj(PyObject *selfptr, PyObject *args, PyObject *kwargs)
} }
error: error:
Py_XDECREF(self); Py_CLEAR(self);
self = NULL;
success: success:
if (zdict.buf != NULL) if (zdict.buf != NULL)
PyBuffer_Release(&zdict); PyBuffer_Release(&zdict);

View File

@ -952,8 +952,7 @@ void
PyFrame_Fini(void) PyFrame_Fini(void)
{ {
(void)PyFrame_ClearFreeList(); (void)PyFrame_ClearFreeList();
Py_XDECREF(builtin_object); Py_CLEAR(builtin_object);
builtin_object = NULL;
} }
/* Print summary info about the state of the optimized allocator */ /* Print summary info about the state of the optimized allocator */

View File

@ -866,8 +866,7 @@ _PyTuple_Resize(PyObject **pv, Py_ssize_t newsize)
_Py_ForgetReference((PyObject *) v); _Py_ForgetReference((PyObject *) v);
/* DECREF items deleted by shrinkage */ /* DECREF items deleted by shrinkage */
for (i = newsize; i < oldsize; i++) { for (i = newsize; i < oldsize; i++) {
Py_XDECREF(v->ob_item[i]); Py_CLEAR(v->ob_item[i]);
v->ob_item[i] = NULL;
} }
sv = PyObject_GC_Resize(PyTupleObject, v, newsize); sv = PyObject_GC_Resize(PyTupleObject, v, newsize);
if (sv == NULL) { if (sv == NULL) {
@ -913,8 +912,7 @@ PyTuple_Fini(void)
#if PyTuple_MAXSAVESIZE > 0 #if PyTuple_MAXSAVESIZE > 0
/* empty tuples are used all over the place and applications may /* empty tuples are used all over the place and applications may
* rely on the fact that an empty tuple is a singleton. */ * rely on the fact that an empty tuple is a singleton. */
Py_XDECREF(free_list[0]); Py_CLEAR(free_list[0]);
free_list[0] = NULL;
(void)PyTuple_ClearFreeList(); (void)PyTuple_ClearFreeList();
#endif #endif

View File

@ -1846,8 +1846,7 @@ _PyUnicode_ClearStaticStrings()
{ {
_Py_Identifier *tmp, *s = static_strings; _Py_Identifier *tmp, *s = static_strings;
while (s) { while (s) {
Py_DECREF(s->object); Py_CLEAR(s->object);
s->object = NULL;
tmp = s->next; tmp = s->next;
s->next = NULL; s->next = NULL;
s = tmp; s = tmp;
@ -4082,8 +4081,7 @@ make_decode_exception(PyObject **exceptionObject,
return; return;
onError: onError:
Py_DECREF(*exceptionObject); Py_CLEAR(*exceptionObject);
*exceptionObject = NULL;
} }
/* error handling callback helper: /* error handling callback helper:
@ -6224,8 +6222,7 @@ make_encode_exception(PyObject **exceptionObject,
goto onError; goto onError;
return; return;
onError: onError:
Py_DECREF(*exceptionObject); Py_CLEAR(*exceptionObject);
*exceptionObject = NULL;
} }
} }
@ -8225,8 +8222,7 @@ make_translate_exception(PyObject **exceptionObject,
goto onError; goto onError;
return; return;
onError: onError:
Py_DECREF(*exceptionObject); Py_CLEAR(*exceptionObject);
*exceptionObject = NULL;
} }
} }

View File

@ -3049,8 +3049,7 @@ fast_yield:
if (call_trace(tstate->c_tracefunc, if (call_trace(tstate->c_tracefunc,
tstate->c_traceobj, f, tstate->c_traceobj, f,
PyTrace_RETURN, retval)) { PyTrace_RETURN, retval)) {
Py_XDECREF(retval); Py_CLEAR(retval);
retval = NULL;
why = WHY_EXCEPTION; why = WHY_EXCEPTION;
} }
} }
@ -3068,8 +3067,7 @@ fast_yield:
else if (call_trace(tstate->c_profilefunc, else if (call_trace(tstate->c_profilefunc,
tstate->c_profileobj, f, tstate->c_profileobj, f,
PyTrace_RETURN, retval)) { PyTrace_RETURN, retval)) {
Py_XDECREF(retval); Py_CLEAR(retval);
retval = NULL;
/* why = WHY_EXCEPTION; */ /* why = WHY_EXCEPTION; */
} }
} }
@ -3426,8 +3424,7 @@ PyEval_EvalCodeEx(PyObject *_co, PyObject *globals, PyObject *locals,
if (co->co_flags & CO_GENERATOR) { if (co->co_flags & CO_GENERATOR) {
/* Don't need to keep the reference to f_back, it will be set /* Don't need to keep the reference to f_back, it will be set
* when the generator is resumed. */ * when the generator is resumed. */
Py_XDECREF(f->f_back); Py_CLEAR(f->f_back);
f->f_back = NULL;
PCALL(PCALL_GENERATOR); PCALL(PCALL_GENERATOR);

View File

@ -253,8 +253,7 @@ imp_release_lock(PyObject *self, PyObject *noargs)
void void
_PyImport_Fini(void) _PyImport_Fini(void)
{ {
Py_XDECREF(extensions); Py_CLEAR(extensions);
extensions = NULL;
#ifdef WITH_THREAD #ifdef WITH_THREAD
if (import_lock != NULL) { if (import_lock != NULL) {
PyThread_free_lock(import_lock); PyThread_free_lock(import_lock);
@ -497,8 +496,7 @@ _PyImport_FixupExtensionObject(PyObject *mod, PyObject *name,
/* Somebody already imported the module, /* Somebody already imported the module,
likely under a different name. likely under a different name.
XXX this should really not happen. */ XXX this should really not happen. */
Py_DECREF(def->m_base.m_copy); Py_CLEAR(def->m_base.m_copy);
def->m_base.m_copy = NULL;
} }
dict = PyModule_GetDict(mod); dict = PyModule_GetDict(mod);
if (dict == NULL) if (dict == NULL)

View File

@ -395,8 +395,7 @@ trace_trampoline(PyObject *self, PyFrameObject *frame,
result = call_trampoline(tstate, callback, frame, what, arg); result = call_trampoline(tstate, callback, frame, what, arg);
if (result == NULL) { if (result == NULL) {
PyEval_SetTrace(NULL, NULL); PyEval_SetTrace(NULL, NULL);
Py_XDECREF(frame->f_trace); Py_CLEAR(frame->f_trace);
frame->f_trace = NULL;
return -1; return -1;
} }
if (result != Py_None) { if (result != Py_None) {