]> granicus.if.org Git - python/commitdiff
Added PyOS_CheckStack call to PyObject_Compare
authorJack Jansen <jack.jansen@cwi.nl>
Tue, 22 Aug 2000 21:52:51 +0000 (21:52 +0000)
committerJack Jansen <jack.jansen@cwi.nl>
Tue, 22 Aug 2000 21:52:51 +0000 (21:52 +0000)
Lowered the recursion limit on compares to 60 (one recursion depth can
take a whopping 2K of stack space when running test_b1!)

Objects/object.c

index f61a1dda655aa5e09f3ca775af49ed23c8651296..1f02aaeef99ac909eb5a32c759e2783fea78ca66 100644 (file)
@@ -11,6 +11,9 @@ redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
 /* Generic object operations; and implementation of None (NoObject) */
 
 #include "Python.h"
+#ifdef HAVE_LIMITS_H
+#include <limits.h>
+#endif
 
 #ifdef macintosh
 #include "macglue.h"
@@ -339,7 +342,11 @@ PyObject *_PyCompareState_Key;
    some types) and decremented on exit.  If the count exceeds the
    nesting limit, enable code to detect circular data structures.
 */
+#ifdef macintosh
+#define NESTING_LIMIT 60
+#else
 #define NESTING_LIMIT 500
+#endif
 int _PyCompareState_nesting = 0;
 
 static PyObject*
@@ -394,6 +401,12 @@ PyObject_Compare(PyObject *v, PyObject *w)
        PyTypeObject *vtp, *wtp;
        int result;
 
+#if defined(USE_STACKCHECK)
+       if (PyOS_CheckStack() < 0) {
+               PyErr_SetString(PyExc_MemoryError, "Stack overflow");
+        return -1;
+       }
+#endif
        if (v == NULL || w == NULL) {
                PyErr_BadInternalCall();
                return -1;