From 5d7d05487e3c9a10baa64c6591bd9cff8545975e Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Fredrik=20H=C3=BCbinette=20=28Hubbe=29?= <hubbe@hubbe.net>
Date: Wed, 25 Sep 1996 03:38:54 +0200
Subject: [PATCH] bug in garbage collector fixed

Rev: src/mapping.c:1.4
---
 src/mapping.c | 18 ++++++++++++++++--
 1 file changed, 16 insertions(+), 2 deletions(-)

diff --git a/src/mapping.c b/src/mapping.c
index 0da050c3d4..9303695963 100644
--- a/src/mapping.c
+++ b/src/mapping.c
@@ -921,6 +921,13 @@ void gc_mark_mapping_as_referenced(struct mapping *m)
     {
       LOOP(m)
       {
+	/* We do not want to count this key:index pair if
+	 * the index is a destructed object or function
+	 */
+	if(((1 << k->ind.type) & (BIT_OBJECT | BIT_FUNCTION)) &&
+	   !(k->ind.u.object->prog))
+	  continue;
+	  
 	gc_mark_svalues(&k->ind, 1);
 	gc_mark_svalues(&k->val, 1);
       }
@@ -938,11 +945,17 @@ void gc_check_all_mappings()
   {
     if((m->ind_types | m->val_types) & BIT_COMPLEX)
     {
-      check_mapping_for_destruct(m);
       LOOP(m)
       {
+	/* We do not want to count this key:index pair if
+	 * the index is a destructed object or function
+	 */
+	if(((1 << k->ind.type) & (BIT_OBJECT | BIT_FUNCTION)) &&
+	   !(k->ind.u.object->prog))
+	  continue;
+	  
 	gc_check_svalues(&k->ind, 1);
-	gc_check_svalues(&k->val, 1);
+	m->val_types |= gc_check_svalues(&k->val, 1);
       }
 
 #ifdef DEBUG
@@ -969,6 +982,7 @@ void gc_free_all_unreferenced_mappings()
 
   for(m=first_mapping;m;m=next)
   {
+    check_mapping_for_destruct(m);
     if(gc_do_free(m))
     {
       m->refs++;
-- 
GitLab