2005-12-17 Chong Yidong <cyd@stupidchicken.com>
authorChong Yidong <cyd@stupidchicken.com>
Sat, 17 Dec 2005 15:55:29 +0000 (15:55 +0000)
committerChong Yidong <cyd@stupidchicken.com>
Sat, 17 Dec 2005 15:55:29 +0000 (15:55 +0000)
* print.c (print_preprocess): Just signal an error if print_depth
is exceeded.

src/ChangeLog
src/print.c

index d3fb401..97c5195 100644 (file)
@@ -1,3 +1,8 @@
+2005-12-17  Chong Yidong  <cyd@stupidchicken.com>
+
+       * print.c (print_preprocess): Just signal an error if print_depth
+       is exceeded.
+
 2005-12-17  Eli Zaretskii  <eliz@gnu.org>
 
        * .gdbinit: Set a breakpoint on w32_abort.
index ed6b402..20c359f 100644 (file)
@@ -1313,14 +1313,8 @@ print_preprocess (obj)
 
   /* Give up if we go so deep that print_object will get an error.  */
   /* See similar code in print_object.  */
-  /* Because print_preprocess "follows" nested lists in a slightly
-     different order from print_object, there is a risk of giving up
-     too soon.  In that case, a deeply nested circular list may cause
-     print_object to loop.  Using 3 * PRINT_CIRCLE should make this
-     possibility negligible, but at some point someone will have to
-     sit down and do a more careful analysis. -- cyd */
-  if (print_depth >= 3 * PRINT_CIRCLE)
-    return;
+  if (print_depth >= PRINT_CIRCLE)
+    error ("Apparently circular structure being printed");
 
   /* Avoid infinite recursion for circular nested structure
      in the case where Vprint_circle is nil.  */