diff options
author | Fred Drake <fdrake@acm.org> | 2000-06-28 15:07:31 (GMT) |
---|---|---|
committer | Fred Drake <fdrake@acm.org> | 2000-06-28 15:07:31 (GMT) |
commit | c19425d520527d93b82755cc8a9854388306515a (patch) | |
tree | 58f691fea63fde7ef3d055a8fad41bb6344ed4bc /Doc/lib/libatexit.tex | |
parent | a05e293a219f0fbaf4301fa7a292b9578a523675 (diff) | |
download | cpython-c19425d520527d93b82755cc8a9854388306515a.zip cpython-c19425d520527d93b82755cc8a9854388306515a.tar.gz cpython-c19425d520527d93b82755cc8a9854388306515a.tar.bz2 |
Added the atexit module and documentation from Skip Montanaro
<skip@mojam.com>. Revisions to the markup to make it pass LaTeX, added
an index entry and a reference from the sys.exitfunc documentation.
This closes SourceForge patch #100620.
Diffstat (limited to 'Doc/lib/libatexit.tex')
-rw-r--r-- | Doc/lib/libatexit.tex | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/Doc/lib/libatexit.tex b/Doc/lib/libatexit.tex new file mode 100644 index 0000000..9d0b48c --- /dev/null +++ b/Doc/lib/libatexit.tex @@ -0,0 +1,59 @@ +\section{\module{atexit} --- + exit handlers} + +\declaremodule{standard}{atexit} +\moduleauthor{Skip Montanaro}{skip@mojam.com} +\sectionauthor{Skip Montanaro}{skip@mojam.com} +\modulesynopsis{Register and execute cleanup functions.} + +The \module{atexit} module defines a single function to register +cleanup functions. Functions thus registered are automatically +executed upon normal interpreter termination. + +Note: the functions registered via this module are not called when the program is killed by a +signal, when a Python fatal internal error is detected, or when +\code{os._exit()} is called. + +This is an alternate interface to the functionality provided by the +\code{sys.exitfunc} variable. +\withsubitem{(in sys)}{\ttindex{exitfunc}} + +\begin{funcdesc}{register}{func\optional{, *args\optional{, **kargs}}} +Register \var{func} as a function to be executed at termination. Any +optional arguments that are to be passed to \var{func} must be passed +as arguments to \function{register()}. + +At normal program termination (for instance, if +\function{sys.exit()} is called or the main module's execution +completes), all functions registered are called in last in, first out +order. The assumption is that lower level modules will normally be +imported before higher level modules and thus must be cleaned up +later. +\end{funcdesc} + + +\subsection{\module{atexit} Example \label{atexit-example}} + +The following simple example demonstrates how a module can initialize +a counter from a file when it is imported and save the counter's +updated value automatically when the program terminates without +relying on the application making an explicit call into this module at +termination. + +\begin{verbatim} +try: + _count = int(open("/tmp/counter").read()) +except IOError: + _count = 0 + +def incrcounter(n): + global _count + _count = _count + n + +def savecounter(): + open("/tmp/counter", "w").write("%d" % _count) + +import atexit +atexit.register(savecounter) +\end{verbatim} + |