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 /Modules/xxmodule.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 'Modules/xxmodule.c')
-rw-r--r-- | Modules/xxmodule.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/Modules/xxmodule.c b/Modules/xxmodule.c index ea66eef..df312eb 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 */ }; |