]> git.eshelyaron.com Git - emacs.git/commitdiff
(mark_byte_stack): Use XMARKBIT and XMARK.
authorGerd Moellmann <gerd@gnu.org>
Sun, 7 Nov 1999 22:44:06 +0000 (22:44 +0000)
committerGerd Moellmann <gerd@gnu.org>
Sun, 7 Nov 1999 22:44:06 +0000 (22:44 +0000)
(unmark_byte_stack): Renamed from relocate_byte_pcs.  Use
XUNMARK.

src/bytecode.c

index 57639d9797239d9bfd613b6f272e8cfc7a622347..377d1a020b521276f6f2c04eab74370e0f4d8f75 100644 (file)
@@ -276,29 +276,51 @@ mark_byte_stack ()
        abort ();
       
       for (obj = stack->bottom; obj <= stack->top; ++obj)
-       mark_object (obj);
+       if (!XMARKBIT (*obj))
+         {
+           mark_object (obj);
+           XMARK (*obj);
+         }
+
+      if (!XMARKBIT (stack->byte_string))
+       {
+          mark_object (&stack->byte_string);
+         XMARK (stack->byte_string);
+       }
 
-      mark_object (&stack->byte_string);
-      mark_object (&stack->constants);
+      if (!XMARKBIT (stack->constants))
+       {
+         mark_object (&stack->constants);
+         XMARK (stack->constants);
+       }
     }
 }
 
 
-/* Relocate program counters in the stacks on byte_stack_list.  Called
-   when GC has completed.  */
+/* Unmark objects in the stacks on byte_stack_list.  Relocate program
+   counters.  Called when GC has completed.  */
 
 void 
-relocate_byte_pcs ()
+unmark_byte_stack ()
 {
   struct byte_stack *stack;
+  Lisp_Object *obj;
 
   for (stack = byte_stack_list; stack; stack = stack->next)
-    if (stack->byte_string_start != XSTRING (stack->byte_string)->data)
-      {
-       int offset = stack->pc - stack->byte_string_start;
-       stack->byte_string_start = XSTRING (stack->byte_string)->data;
-       stack->pc = stack->byte_string_start + offset;
-      }
+    {
+      for (obj = stack->bottom; obj <= stack->top; ++obj)
+       XUNMARK (*obj);
+
+      XUNMARK (stack->byte_string);
+      XUNMARK (stack->constants);
+
+      if (stack->byte_string_start != XSTRING (stack->byte_string)->data)
+       {
+         int offset = stack->pc - stack->byte_string_start;
+         stack->byte_string_start = XSTRING (stack->byte_string)->data;
+         stack->pc = stack->byte_string_start + offset;
+       }
+    }
 }
 
 \f