diff options
author | R David Murray <rdmurray@bitdance.com> | 2014-04-14 19:04:47 (GMT) |
---|---|---|
committer | R David Murray <rdmurray@bitdance.com> | 2014-04-14 19:04:47 (GMT) |
commit | 061cb3b04d77e490489f64f230fc4dd7a190de4d (patch) | |
tree | 38753722ce422c604cf57cfee4046f752683bac7 /Doc | |
parent | 1343b25fbad990afb9287875e097853edc8032fb (diff) | |
download | cpython-061cb3b04d77e490489f64f230fc4dd7a190de4d.zip cpython-061cb3b04d77e490489f64f230fc4dd7a190de4d.tar.gz cpython-061cb3b04d77e490489f64f230fc4dd7a190de4d.tar.bz2 |
#15104: improve the discussion of __main__.
Patch by Sam Lucidi.
Diffstat (limited to 'Doc')
-rw-r--r-- | Doc/library/__main__.rst | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/Doc/library/__main__.rst b/Doc/library/__main__.rst index a1d3c24..2415d3d 100644 --- a/Doc/library/__main__.rst +++ b/Doc/library/__main__.rst @@ -5,13 +5,19 @@ .. module:: __main__ :synopsis: The environment where the top-level script is run. +'__main__' is the name of the scope in which top-level code executes. +A module's __name__ is set equal to '__main__' when read from +standard input, a script, or from an interactive prompt. -This module represents the (otherwise anonymous) scope in which the -interpreter's main program executes --- commands read either from standard -input, from a script file, or from an interactive prompt. It is this -environment in which the idiomatic "conditional script" stanza causes a script -to run:: +A module can discover whether or not it is running in the main scope by +checking its own __name__, which allows a common idiom for conditionally +executing code in a module when it is run as a script or with `python +-m` but not when it is imported: if __name__ == "__main__": + # execute only if run as a script main() +For a package, the same effect can be achieved by including a +__main__.py module, the contents of which will be executed when the +module is run with -m. |