aboutsummaryrefslogtreecommitdiff
path: root/gc.h
diff options
context:
space:
mode:
Diffstat (limited to 'gc.h')
-rw-r--r--gc.h17
1 files changed, 16 insertions, 1 deletions
diff --git a/gc.h b/gc.h
index e807048..d116a18 100644
--- a/gc.h
+++ b/gc.h
@@ -5,8 +5,23 @@
#include <map>
const int GC_QUEUE_SIZE = 262144;
+const size_t GC_CYC_THRESHOLD = 1000;
typedef std::map<EvalObj*, size_t> EvalObj2Int;
+typedef std::set<EvalObj*> EvalObjSet;
+
+#define GC_CYC_TRIGGER(ptr) \
+do { \
+ if ((ptr) && (ptr)->is_container() && !visited.count(ptr)) \
+ visited.insert(*tail++ = (ptr)); \
+} while (0)
+
+#define GC_CYC_DEC(ptr) \
+do { \
+ if ((ptr) && (ptr)->is_container()) \
+ static_cast<Container*>(ptr)->gc_refs--; \
+} while (0)
+
class GarbageCollector {
@@ -17,11 +32,11 @@ class GarbageCollector {
};
EvalObj2Int mapping;
- size_t pend_cnt;
PendingEntry *pending_list;
public:
GarbageCollector();
+ void cycle_resolve();
void force();
void expose(EvalObj *ptr);
EvalObj *attach(EvalObj *ptr);