[Python-checkins] r43023 - in python/branches/release24-maint: Modules/xxmodule.c Objects/object.c

neal.norwitz python-checkins at python.org
Tue Mar 14 07:10:23 CET 2006


Author: neal.norwitz
Date: Tue Mar 14 07:10:22 2006
New Revision: 43023

Modified:
   python/branches/release24-maint/Modules/xxmodule.c
   python/branches/release24-maint/Objects/object.c
Log:
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.


Modified: python/branches/release24-maint/Modules/xxmodule.c
==============================================================================
--- python/branches/release24-maint/Modules/xxmodule.c	(original)
+++ python/branches/release24-maint/Modules/xxmodule.c	Tue Mar 14 07:10:22 2006
@@ -197,6 +197,18 @@
 	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 @@
 		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 */
 };
 

Modified: python/branches/release24-maint/Objects/object.c
==============================================================================
--- python/branches/release24-maint/Objects/object.c	(original)
+++ python/branches/release24-maint/Objects/object.c	Tue Mar 14 07:10:22 2006
@@ -373,9 +373,15 @@
 PyObject_Unicode(PyObject *v)
 {
 	PyObject *res;
+	PyObject *str;
 
 	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;
@@ -418,13 +424,9 @@
 	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;
 }


More information about the Python-checkins mailing list