5 template <typename TYPE>
6 struct gc_root : public tagged<TYPE>
10 void push() { parent_vm->check_tagged_pointer(tagged<TYPE>::value()); parent_vm->gc_locals.push_back((cell)this); }
12 explicit gc_root(cell value_,factor_vm *vm) : tagged<TYPE>(value_),parent_vm(vm) { push(); }
13 explicit gc_root(TYPE *value_, factor_vm *vm) : tagged<TYPE>(value_),parent_vm(vm) { push(); }
15 const gc_root<TYPE>& operator=(const TYPE *x) { tagged<TYPE>::operator=(x); return *this; }
16 const gc_root<TYPE>& operator=(const cell &x) { tagged<TYPE>::operator=(x); return *this; }
20 assert(myvm->gc_locals.back() == (cell)this);
22 parent_vm->gc_locals.pop_back();
26 /* A similar hack for the bignum implementation */
31 gc_bignum(bignum **addr_, factor_vm *vm) : addr(addr_), parent_vm(vm) {
33 parent_vm->check_data_pointer(*addr_);
34 parent_vm->gc_bignums.push_back((cell)addr);
39 assert(myvm->gc_bignums.back() == (cell)addr);
41 parent_vm->gc_bignums.pop_back();
45 #define GC_BIGNUM(x) gc_bignum x##__gc_root(&x,this)