42 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| # 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
 |