[Python-checkins] r62281 - in python/branches/release25-maint: Misc/NEWS Objects/object.c Objects/tupleobject.c

guido.van.rossum python-checkins at python.org
Fri Apr 11 00:43:59 CEST 2008


Author: guido.van.rossum
Date: Fri Apr 11 00:43:58 2008
New Revision: 62281
Modified:
 python/branches/release25-maint/Misc/NEWS
 python/branches/release25-maint/Objects/object.c
 python/branches/release25-maint/Objects/tupleobject.c
Log:
- Issue #1686386: Tuple's tp_repr did not take into account the possibility of
 having a self-referential tuple, which is possible from C code. Nor did
 object's tp_str consider that a type's tp_str could do something that could
 lead to an inifinite recursion. Py_ReprEnter() and Py_EnterRecursiveCall(),
 respectively, fixed the issues. (Backport of r58288 from trunk to 2.5.)
Modified: python/branches/release25-maint/Misc/NEWS
==============================================================================
--- python/branches/release25-maint/Misc/NEWS	(original)
+++ python/branches/release25-maint/Misc/NEWS	Fri Apr 11 00:43:58 2008
@@ -12,6 +12,12 @@
 Core and builtins
 -----------------
 
+- Issue #1686386: Tuple's tp_repr did not take into account the possibility of
+ having a self-referential tuple, which is possible from C code. Nor did
+ object's tp_str consider that a type's tp_str could do something that could
+ lead to an inifinite recursion. Py_ReprEnter() and Py_EnterRecursiveCall(),
+ respectively, fixed the issues. (Backport of r58288 from trunk.)
+
 - Patch #1442: properly report exceptions when the PYTHONSTARTUP file
 cannot be executed.
 
Modified: python/branches/release25-maint/Objects/object.c
==============================================================================
--- python/branches/release25-maint/Objects/object.c	(original)
+++ python/branches/release25-maint/Objects/object.c	Fri Apr 11 00:43:58 2008
@@ -403,7 +403,12 @@
 	if (v->ob_type->tp_str == NULL)
 		return PyObject_Repr(v);
 
+	/* It is possible for a type to have a tp_str representation that loops
+	 infinitely. */
+	if (Py_EnterRecursiveCall(" while getting the str of an object"))
+		return NULL;
 	res = (*v->ob_type->tp_str)(v);
+	Py_LeaveRecursiveCall();
 	if (res == NULL)
 		return NULL;
 	type_ok = PyString_Check(res);
@@ -2141,4 +2146,3 @@
 #ifdef __cplusplus
 }
 #endif
-
Modified: python/branches/release25-maint/Objects/tupleobject.c
==============================================================================
--- python/branches/release25-maint/Objects/tupleobject.c	(original)
+++ python/branches/release25-maint/Objects/tupleobject.c	Fri Apr 11 00:43:58 2008
@@ -208,6 +208,15 @@
 	PyObject *s, *temp;
 	PyObject *pieces, *result = NULL;
 
+	/* While not mutable, it is still possible to end up with a cycle in a
+	 tuple through an object that stores itself within a tuple (and thus
+	 infinitely asks for the repr of itself). This should only be
+	 possible within a type. */
+	i = Py_ReprEnter((PyObject *)v);
+	if (i != 0) {
+		return i > 0 ? PyString_FromString("(...)") : NULL;
+	}
+
 	n = v->ob_size;
 	if (n == 0)
 		return PyString_FromString("()");
@@ -218,7 +227,10 @@
 
 	/* Do repr() on each element. */
 	for (i = 0; i < n; ++i) {
+		if (Py_EnterRecursiveCall(" while getting the repr of a tuple"))
+			goto Done;
 		s = PyObject_Repr(v->ob_item[i]);
+		Py_LeaveRecursiveCall();
 		if (s == NULL)
 			goto Done;
 		PyTuple_SET_ITEM(pieces, i, s);
@@ -253,6 +265,7 @@
 
 Done:
 	Py_DECREF(pieces);
+	Py_ReprLeave((PyObject *)v);
 	return result;
 }
 


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /