Staging
v0.5.1
v0.5.1
https://github.com/python/cpython
Revision 317acd0308a4f539add7660b376b44554af7e28f authored by Jeremy Hylton on 18 December 2001, 00:00:15 UTC, committed by Jeremy Hylton on 18 December 2001, 00:00:15 UTC
Fix for sibling nodes that define the same free variable, rev. 1.6. Handle private names, rev. 1.7. Fix bug in handling of statements like "l[x:y] = 2", reb. 1.8. Fix symbol problem with slice assignment, rev. 1.9.
1 parent 2dfc9a3
Tip revision: 317acd0308a4f539add7660b376b44554af7e28f authored by Jeremy Hylton on 18 December 2001, 00:00:15 UTC
Backport bugfixes since rev 1.5 from the trunk.
Backport bugfixes since rev 1.5 from the trunk.
Tip revision: 317acd0
atexit.py
"""
atexit.py - allow programmer to define multiple exit functions to be executed
upon normal program termination.
One public function, register, is defined.
"""
__all__ = ["register"]
_exithandlers = []
def _run_exitfuncs():
"""run any registered exit functions
_exithandlers is traversed in reverse order so functions are executed
last in, first out.
"""
while _exithandlers:
func, targs, kargs = _exithandlers.pop()
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")
Computing file changes ...