summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorR David Murray <rdmurray@bitdance.com>2014-04-14 19:05:12 (GMT)
committerR David Murray <rdmurray@bitdance.com>2014-04-14 19:05:12 (GMT)
commit94255f3a803abbaa97f6c90266506bbdd7941fbb (patch)
treed6b0bcc4706a592e575d153572b5ce2d01773f46
parent327167b348630d1d01c85d77e5e08df55a6a029b (diff)
parent061cb3b04d77e490489f64f230fc4dd7a190de4d (diff)
downloadcpython-94255f3a803abbaa97f6c90266506bbdd7941fbb.zip
cpython-94255f3a803abbaa97f6c90266506bbdd7941fbb.tar.gz
cpython-94255f3a803abbaa97f6c90266506bbdd7941fbb.tar.bz2
Merge: #15104: improve the discussion of __main__.
-rw-r--r--Doc/library/__main__.rst16
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.