| 
									
										
										
										
											2000-06-28 15:07:31 +00:00
										 |  |  | """
 | 
					
						
							|  |  |  | atexit.py - allow programmer to define multiple exit functions to be executed | 
					
						
							|  |  |  | upon normal program termination. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-01-14 18:09:23 +00:00
										 |  |  | One public function, register, is defined. | 
					
						
							| 
									
										
										
										
											2000-06-28 15:07:31 +00:00
										 |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-01-20 19:54:20 +00:00
										 |  |  | __all__ = ["register"] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-06-28 15:07:31 +00:00
										 |  |  | _exithandlers = [] | 
					
						
							|  |  |  | def _run_exitfuncs(): | 
					
						
							|  |  |  |     """run any registered exit functions
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     _exithandlers is traversed in reverse order so functions are executed | 
					
						
							|  |  |  |     last in, first out. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2001-01-14 18:09:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-06-28 15:07:31 +00:00
										 |  |  |     while _exithandlers: | 
					
						
							| 
									
										
										
										
											2001-01-21 03:40:37 +00:00
										 |  |  |         func, targs, kargs = _exithandlers.pop() | 
					
						
							| 
									
										
										
										
											2000-06-28 15:07:31 +00:00
										 |  |  |         apply(func, targs, kargs) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def register(func, *targs, **kargs): | 
					
						
							|  |  |  |     """register a function to be executed upon normal program termination
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     func - function to be called at exit | 
					
						
							|  |  |  |     targs - optional arguments to pass to func | 
					
						
							|  |  |  |     kargs - optional keyword arguments to pass to func | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     _exithandlers.append((func, targs, kargs)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import sys | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     x = sys.exitfunc | 
					
						
							|  |  |  | except AttributeError: | 
					
						
							|  |  |  |     sys.exitfunc = _run_exitfuncs | 
					
						
							|  |  |  | else: | 
					
						
							|  |  |  |     # if x isn't our own exit func executive, assume it's another | 
					
						
							|  |  |  |     # registered exit function - append it to our list... | 
					
						
							|  |  |  |     if x != _run_exitfuncs: | 
					
						
							|  |  |  |         register(x) | 
					
						
							|  |  |  | del sys | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if __name__ == "__main__": | 
					
						
							|  |  |  |     def x1(): | 
					
						
							|  |  |  |         print "running x1" | 
					
						
							|  |  |  |     def x2(n): | 
					
						
							|  |  |  |         print "running x2(%s)" % `n` | 
					
						
							|  |  |  |     def x3(n, kwd=None): | 
					
						
							|  |  |  |         print "running x3(%s, kwd=%s)" % (`n`, `kwd`) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     register(x1) | 
					
						
							|  |  |  |     register(x2, 12) | 
					
						
							|  |  |  |     register(x3, 5, "bar") | 
					
						
							|  |  |  |     register(x3, "no kwd args") |