From: Neal Norwitz Date: Tue, 14 Mar 2006 06:10:22 +0000 (+0000) Subject: Backport 43022: X-Git-Tag: v2.4.3c1~25 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=9165680203a10341e7e76c92d12c76f5ddd1f6e1;p=thirdparty%2FPython%2Fcpython.git Backport 43022: 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. --- diff --git a/Modules/xxmodule.c b/Modules/xxmodule.c index 5f75b6cf8f9d..44e5e09ff95f 100644 --- a/Modules/xxmodule.c +++ b/Modules/xxmodule.c @@ -197,6 +197,18 @@ xx_bug(PyObject *self, PyObject *args) return Py_None; } +/* Example passing NULLs to PyObject_Str(NULL) and PyObject_Unicode(NULL). */ + +static PyObject * +xx_null(PyObject *self, PyObject *noargs) +{ + PyObject *o1 = PyObject_Str(NULL), *o2 = PyObject_Unicode(NULL); + PyObject *tuple = PyTuple_Pack(2, o1, o2); + Py_XDECREF(o1); + Py_XDECREF(o2); + return tuple; +} + /* Test bad format character */ static PyObject * @@ -331,6 +343,8 @@ static PyMethodDef xx_methods[] = { PyDoc_STR("new() -> new Xx object")}, {"bug", xx_bug, METH_VARARGS, PyDoc_STR("bug(o) -> None")}, + {"null", xx_null, METH_NOARGS, + PyDoc_STR("null(o) -> ('NULL', u'NULL')")}, {NULL, NULL} /* sentinel */ }; diff --git a/Objects/object.c b/Objects/object.c index 87aa475a6092..7dbd554dffc4 100644 --- a/Objects/object.c +++ b/Objects/object.c @@ -373,9 +373,15 @@ PyObject * PyObject_Unicode(PyObject *v) { PyObject *res; + PyObject *str; if (v == NULL) { res = PyString_FromString(""); + 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; @@ -418,13 +424,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; }