diff options
author | Neal Norwitz <nnorwitz@gmail.com> | 2006-03-14 06:02:16 (GMT) |
---|---|---|
committer | Neal Norwitz <nnorwitz@gmail.com> | 2006-03-14 06:02:16 (GMT) |
commit | 7580146b5c7025976f0907a9893e01dc3d3d3457 (patch) | |
tree | 5fc360f070f4af4b48a31610ab0b239b8cf2ff57 /Objects/object.c | |
parent | 3daf75878df471bafb3c454c8f216fe7cbcb80ee (diff) | |
download | cpython-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/object.c')
-rw-r--r-- | Objects/object.c | 12 |
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; } |