summaryrefslogtreecommitdiffstats
path: root/Modules
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 /Modules
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 'Modules')
-rw-r--r--Modules/xxmodule.c14
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 */
};