# ifndef GC_H # include "gc.h" # endif /* * Invoke all remaining finalizers that haven't yet been run. * This is needed for strict compliance with the Java standard, * which can make the runtime guarantee that all finalizers are run. * This is problematic for several reasons: * 1) It means that finalizers, and all methods calle by them, * must be prepared to deal with objects that have been finalized in * spite of the fact that they are still referenced by statically * allocated pointer variables. * 1) It may mean that we get stuck in an infinite loop running * finalizers which create new finalizable objects, though that's * probably unlikely. * Thus this is not recommended for general use. */ void GC_finalize_all(); /* * A version of GC_register_finalizer that allows the object to be * finalized before the objects it references. This is again error * prone, in that it makes it easy to accidentally reference finalized * objects. Again, recommended only for JVM implementors. */ void GC_register_finalizer_no_order(GC_PTR obj, GC_finalization_proc fn, GC_PTR cd, GC_finalization_proc *ofn, GC_PTR * ocd); void GC_debug_register_finalizer_no_order(GC_PTR obj, GC_finalization_proc fn, GC_PTR cd, GC_finalization_proc *ofn, GC_PTR * ocd); #ifdef GC_DEBUG # define GC_REGISTER_FINALIZER(p, f, d, of, od) \ GC_debug_register_finalizer_no_order(p, f, d, of, od) #else # define GC_REGISTER_FINALIZER(p, f, d, of, od) \ GC_register_finalizer_no_order(p, f, d, of, od) #endif