From: Thomas Wouters Date: Tue, 7 Mar 2006 14:16:02 +0000 (+0000) Subject: Backport trunk's r42890 (thomas.wouters): X-Git-Tag: v2.4.3c1~46 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=82735da0165cc8b0b080d7e28d4123c3168c4cf7;p=thirdparty%2FPython%2Fcpython.git Backport trunk's r42890 (thomas.wouters): Coverity found bug: test result of PyTuple_New() against NULL before use. and r42891 (thomas.wouters): Fix gcc 4.0.x warning about use of uninitialized value. --- diff --git a/Modules/_bsddb.c b/Modules/_bsddb.c index 07c56cdd66b2..de072b07af79 100644 --- a/Modules/_bsddb.c +++ b/Modules/_bsddb.c @@ -1063,7 +1063,7 @@ _db_associateCallback(DB* db, const DBT* priKey, const DBT* priData, PyObject* key; PyObject* data; PyObject* args; - PyObject* result; + PyObject* result = NULL; if (callback != NULL) { @@ -1077,12 +1077,12 @@ _db_associateCallback(DB* db, const DBT* priKey, const DBT* priData, } data = PyString_FromStringAndSize(priData->data, priData->size); args = PyTuple_New(2); - PyTuple_SET_ITEM(args, 0, key); /* steals reference */ - PyTuple_SET_ITEM(args, 1, data); /* steals reference */ - - result = PyEval_CallObject(callback, args); - - if (result == NULL) { + if (args != NULL) { + PyTuple_SET_ITEM(args, 0, key); /* steals reference */ + PyTuple_SET_ITEM(args, 1, data); /* steals reference */ + result = PyEval_CallObject(callback, args); + } + if (args == NULL || result == NULL) { PyErr_Print(); } else if (result == Py_None) {