summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorNeal Norwitz <nnorwitz@gmail.com>2006-03-14 06:02:16 (GMT)
committerNeal Norwitz <nnorwitz@gmail.com>2006-03-14 06:02:16 (GMT)
commit7580146b5c7025976f0907a9893e01dc3d3d3457 (patch)
tree5fc360f070f4af4b48a31610ab0b239b8cf2ff57 /Objects
parent3daf75878df471bafb3c454c8f216fe7cbcb80ee (diff)
downloadcpython-7580146b5c7025976f0907a9893e01dc3d3d3457.zip
cpython-7580146b5c7025976f0907a9893e01dc3d3d3457.tar.gz
cpython-7580146b5c7025976f0907a9893e01dc3d3d3457.tar.bz2
Fix and test (manually w/xx module) passing NULLs to PyObject_Str() and
PyObject_Unicode(). This problem was originally reported from Coverity and addresses mail on python-dev "checkin r43015". This inlines the conversion of the string to unicode and cleans up/simplifies some code at the end of the PyObject_Unicode(). We really need a complete C API test module for all public APIs and passing good and bad parameter values. Will backport.
Diffstat (limited to 'Objects')
-rw-r--r--Objects/object.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/Objects/object.c b/Objects/object.c
index c4634f7..9b6a30a 100644
--- a/Objects/object.c
+++ b/Objects/object.c
@@ -400,10 +400,16 @@ PyObject_Unicode(PyObject *v)
{
PyObject *res;
PyObject *func;
+ PyObject *str;
static PyObject *unicodestr;
if (v == NULL) {
res = PyString_FromString("<NULL>");
+ if (res == NULL)
+ return NULL;
+ str = PyUnicode_FromEncodedObject(res, NULL, "strict");
+ Py_DECREF(res);
+ return str;
} else if (PyUnicode_CheckExact(v)) {
Py_INCREF(v);
return v;
@@ -443,13 +449,9 @@ PyObject_Unicode(PyObject *v)
if (res == NULL)
return NULL;
if (!PyUnicode_Check(res)) {
- PyObject *str;
str = PyUnicode_FromEncodedObject(res, NULL, "strict");
Py_DECREF(res);
- if (str)
- res = str;
- else
- return NULL;
+ res = str;
}
return res;
}