#ifndef COSMOPOLITAN_LIBC_MEM_GC_H_ #define COSMOPOLITAN_LIBC_MEM_GC_H_ #ifdef _COSMO_SOURCE COSMOPOLITAN_C_START_ void _gc_free(void *) libcesque; void __defer(void *, void *, void *) libcesque; void gclongjmp(void *, int) libcesque wontreturn; #define gc(THING) defer((void *)_gc_free, (void *)(THING)) #define _gc(THING) defer((void *)_gc_free, (void *)(THING)) #define defer(FN, ARG) \ ({ \ autotype(ARG) Arg = (ARG); \ /* prevent weird opts like tail call */ \ __asm__ volatile("" : "+g"(Arg) : : "memory"); \ __defer(__builtin_frame_address(0), FN, Arg); \ __asm__ volatile("" : "+g"(Arg) : : "memory"); \ Arg; \ }) COSMOPOLITAN_C_END_ #endif /* _COSMO_SOURCE */ #endif /* COSMOPOLITAN_LIBC_MEM_GC_H_ */