| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" | 
|  | 2 | "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | 
|  | 3 |  | 
|  | 4 |  | 
|  | 5 | <html xmlns="http://www.w3.org/1999/xhtml"> | 
|  | 6 | <head> | 
|  | 7 | <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 8 |  | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 9 | <title>25.5. IDLE — Python 3.7.0a0 documentation</title> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 10 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 11 | <link rel="stylesheet" href="../_static/pydoctheme.css" type="text/css" /> | 
|  | 12 | <link rel="stylesheet" href="../_static/pygments.css" type="text/css" /> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 13 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 14 | <script type="text/javascript"> | 
|  | 15 | var DOCUMENTATION_OPTIONS = { | 
|  | 16 | URL_ROOT:    '../', | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 17 | VERSION:     '3.7.0a0', | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 18 | COLLAPSE_INDEX: false, | 
|  | 19 | FILE_SUFFIX: '.html', | 
|  | 20 | HAS_SOURCE:  true | 
|  | 21 | }; | 
|  | 22 | </script> | 
|  | 23 | <script type="text/javascript" src="../_static/jquery.js"></script> | 
|  | 24 | <script type="text/javascript" src="../_static/underscore.js"></script> | 
|  | 25 | <script type="text/javascript" src="../_static/doctools.js"></script> | 
|  | 26 | <script type="text/javascript" src="../_static/sidebar.js"></script> | 
|  | 27 | <link rel="search" type="application/opensearchdescription+xml" | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 28 | title="Search within Python 3.7.0a0 documentation" | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 29 | href="../_static/opensearch.xml"/> | 
|  | 30 | <link rel="author" title="About these documents" href="../about.html" /> | 
|  | 31 | <link rel="copyright" title="Copyright" href="../copyright.html" /> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 32 | <link rel="top" title="Python 3.7.0a0 documentation" href="../contents.html" /> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 33 | <link rel="up" title="25. Graphical User Interfaces with Tk" href="tk.html" /> | 
|  | 34 | <link rel="next" title="25.6. Other Graphical User Interface Packages" href="othergui.html" /> | 
|  | 35 | <link rel="prev" title="25.4. tkinter.scrolledtext — Scrolled Text Widget" href="tkinter.scrolledtext.html" /> | 
|  | 36 | <link rel="shortcut icon" type="image/png" href="../_static/py.png" /> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 37 | <link rel="canonical" href="https://docs.python.org/3/library/idle.html" /> | 
|  | 38 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 39 | <script type="text/javascript" src="../_static/copybutton.js"></script> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 40 |  | 
|  | 41 |  | 
|  | 42 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 43 |  | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 44 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 45 | </head> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 46 | <body role="document"> | 
|  | 47 | <div class="related" role="navigation" aria-label="related navigation"> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 48 | <h3>Navigation</h3> | 
|  | 49 | <ul> | 
|  | 50 | <li class="right" style="margin-right: 10px"> | 
|  | 51 | <a href="../genindex.html" title="General Index" | 
|  | 52 | accesskey="I">index</a></li> | 
|  | 53 | <li class="right" > | 
|  | 54 | <a href="../py-modindex.html" title="Python Module Index" | 
|  | 55 | >modules</a> |</li> | 
|  | 56 | <li class="right" > | 
|  | 57 | <a href="othergui.html" title="25.6. Other Graphical User Interface Packages" | 
|  | 58 | accesskey="N">next</a> |</li> | 
|  | 59 | <li class="right" > | 
|  | 60 | <a href="tkinter.scrolledtext.html" title="25.4. tkinter.scrolledtext — Scrolled Text Widget" | 
|  | 61 | accesskey="P">previous</a> |</li> | 
|  | 62 | <li><img src="../_static/py.png" alt="" | 
|  | 63 | style="vertical-align: middle; margin-top: -1px"/></li> | 
| Terry Jan Reedy | 3399e1e | 2016-08-30 16:58:01 -0400 | [diff] [blame] | 64 | <li><a href="https://www.python.org/">Python</a> »</li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 65 | <li> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 66 | <a href="../index.html">3.7.0a0 Documentation</a> » | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 67 | </li> | 
|  | 68 |  | 
| Terry Jan Reedy | 3399e1e | 2016-08-30 16:58:01 -0400 | [diff] [blame] | 69 | <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> »</li> | 
|  | 70 | <li class="nav-item nav-item-2"><a href="tk.html" accesskey="U">25. Graphical User Interfaces with Tk</a> »</li> | 
| Terry Jan Reedy | 4b73676 | 2016-09-12 01:50:03 -0400 | [diff] [blame] | 71 | <li class="right"> | 
|  | 72 |  | 
|  | 73 |  | 
|  | 74 | <div class="inline-search" style="display: none" role="search"> | 
|  | 75 | <form class="inline-search" action="../search.html" method="get"> | 
|  | 76 | <input placeholder="Quick search" type="text" name="q" /> | 
|  | 77 | <input type="submit" value="Go" /> | 
|  | 78 | <input type="hidden" name="check_keywords" value="yes" /> | 
|  | 79 | <input type="hidden" name="area" value="default" /> | 
|  | 80 | </form> | 
|  | 81 | </div> | 
|  | 82 | <script type="text/javascript">$('.inline-search').show(0);</script> | 
|  | 83 | | | 
|  | 84 | </li> | 
|  | 85 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 86 | </ul> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 87 | </div> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 88 |  | 
|  | 89 | <div class="document"> | 
|  | 90 | <div class="documentwrapper"> | 
|  | 91 | <div class="bodywrapper"> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 92 | <div class="body" role="main"> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 93 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 94 | <div class="section" id="idle"> | 
|  | 95 | <span id="id1"></span><h1>25.5. IDLE<a class="headerlink" href="#idle" title="Permalink to this headline">¶</a></h1> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 96 | <p><strong>Source code:</strong> <a class="reference external" href="https://github.com/python/cpython/tree/master/Lib/idlelib/">Lib/idlelib/</a></p> | 
| Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame] | 97 | <hr class="docutils" id="index-0" /> | 
|  | 98 | <p>IDLE is Python’s Integrated Development and Learning Environment.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 99 | <p>IDLE has the following features:</p> | 
|  | 100 | <ul class="simple"> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 101 | <li>coded in 100% pure Python, using the <a class="reference internal" href="tkinter.html#module-tkinter" title="tkinter: Interface to Tcl/Tk for graphical user interfaces"><code class="xref py py-mod docutils literal"><span class="pre">tkinter</span></code></a> GUI toolkit</li> | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 102 | <li>cross-platform: works mostly the same on Windows, Unix, and Mac OS X</li> | 
| Terry Jan Reedy | 6e10ec5 | 2015-09-23 20:00:33 -0400 | [diff] [blame] | 103 | <li>Python shell window (interactive interpreter) with colorizing | 
|  | 104 | of code input, output, and error messages</li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 105 | <li>multi-window text editor with multiple undo, Python colorizing, | 
| Terry Jan Reedy | 6e10ec5 | 2015-09-23 20:00:33 -0400 | [diff] [blame] | 106 | smart indent, call tips, auto completion, and other features</li> | 
|  | 107 | <li>search within any window, replace within editor windows, and search | 
|  | 108 | through multiple files (grep)</li> | 
|  | 109 | <li>debugger with persistent breakpoints, stepping, and viewing | 
|  | 110 | of global and local namespaces</li> | 
|  | 111 | <li>configuration, browsers, and other dialogs</li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 112 | </ul> | 
|  | 113 | <div class="section" id="menus"> | 
|  | 114 | <h2>25.5.1. Menus<a class="headerlink" href="#menus" title="Permalink to this headline">¶</a></h2> | 
|  | 115 | <p>IDLE has two main window types, the Shell window and the Editor window.  It is | 
|  | 116 | possible to have multiple editor windows simultaneously.  Output windows, such | 
|  | 117 | as used for Edit / Find in Files, are a subtype of edit window.  They currently | 
|  | 118 | have the same top menu as Editor windows but a different default title and | 
|  | 119 | context menu.</p> | 
|  | 120 | <p>IDLE’s menus dynamically change based on which window is currently selected. | 
|  | 121 | Each menu documented below indicates which window type it is associated with.</p> | 
|  | 122 | <div class="section" id="file-menu-shell-and-editor"> | 
|  | 123 | <h3>25.5.1.1. File menu (Shell and Editor)<a class="headerlink" href="#file-menu-shell-and-editor" title="Permalink to this headline">¶</a></h3> | 
|  | 124 | <dl class="docutils"> | 
|  | 125 | <dt>New File</dt> | 
|  | 126 | <dd>Create a new file editing window.</dd> | 
|  | 127 | <dt>Open...</dt> | 
|  | 128 | <dd>Open an existing file with an Open dialog.</dd> | 
|  | 129 | <dt>Recent Files</dt> | 
|  | 130 | <dd>Open a list of recent files.  Click one to open it.</dd> | 
|  | 131 | <dt>Open Module...</dt> | 
|  | 132 | <dd>Open an existing module (searches sys.path).</dd> | 
|  | 133 | </dl> | 
|  | 134 | <dl class="docutils" id="index-1"> | 
|  | 135 | <dt>Class Browser</dt> | 
|  | 136 | <dd>Show functions, classes, and methods in the current Editor file in a | 
|  | 137 | tree structure.  In the shell, open a module first.</dd> | 
|  | 138 | <dt>Path Browser</dt> | 
|  | 139 | <dd>Show sys.path directories, modules, functions, classes and methods in a | 
|  | 140 | tree structure.</dd> | 
|  | 141 | <dt>Save</dt> | 
|  | 142 | <dd>Save the current window to the associated file, if there is one.  Windows | 
|  | 143 | that have been changed since being opened or last saved have a * before | 
|  | 144 | and after the window title.  If there is no associated file, | 
|  | 145 | do Save As instead.</dd> | 
|  | 146 | <dt>Save As...</dt> | 
|  | 147 | <dd>Save the current window with a Save As dialog.  The file saved becomes the | 
|  | 148 | new associated file for the window.</dd> | 
|  | 149 | <dt>Save Copy As...</dt> | 
|  | 150 | <dd>Save the current window to different file without changing the associated | 
|  | 151 | file.</dd> | 
|  | 152 | <dt>Print Window</dt> | 
|  | 153 | <dd>Print the current window to the default printer.</dd> | 
|  | 154 | <dt>Close</dt> | 
|  | 155 | <dd>Close the current window (ask to save if unsaved).</dd> | 
|  | 156 | <dt>Exit</dt> | 
|  | 157 | <dd>Close all windows and quit IDLE (ask to save unsaved windows).</dd> | 
|  | 158 | </dl> | 
|  | 159 | </div> | 
|  | 160 | <div class="section" id="edit-menu-shell-and-editor"> | 
|  | 161 | <h3>25.5.1.2. Edit menu (Shell and Editor)<a class="headerlink" href="#edit-menu-shell-and-editor" title="Permalink to this headline">¶</a></h3> | 
|  | 162 | <dl class="docutils"> | 
|  | 163 | <dt>Undo</dt> | 
|  | 164 | <dd>Undo the last change to the current window.  A maximum of 1000 changes may | 
|  | 165 | be undone.</dd> | 
|  | 166 | <dt>Redo</dt> | 
|  | 167 | <dd>Redo the last undone change to the current window.</dd> | 
|  | 168 | <dt>Cut</dt> | 
|  | 169 | <dd>Copy selection into the system-wide clipboard; then delete the selection.</dd> | 
|  | 170 | <dt>Copy</dt> | 
|  | 171 | <dd>Copy selection into the system-wide clipboard.</dd> | 
|  | 172 | <dt>Paste</dt> | 
|  | 173 | <dd>Insert contents of the system-wide clipboard into the current window.</dd> | 
|  | 174 | </dl> | 
|  | 175 | <p>The clipboard functions are also available in context menus.</p> | 
|  | 176 | <dl class="docutils"> | 
|  | 177 | <dt>Select All</dt> | 
|  | 178 | <dd>Select the entire contents of the current window.</dd> | 
|  | 179 | <dt>Find...</dt> | 
|  | 180 | <dd>Open a search dialog with many options</dd> | 
|  | 181 | <dt>Find Again</dt> | 
|  | 182 | <dd>Repeat the last search, if there is one.</dd> | 
|  | 183 | <dt>Find Selection</dt> | 
|  | 184 | <dd>Search for the currently selected string, if there is one.</dd> | 
|  | 185 | <dt>Find in Files...</dt> | 
| Terry Jan Reedy | 929d7f8 | 2016-05-02 18:30:02 -0400 | [diff] [blame] | 186 | <dd>Open a file search dialog.  Put results in a new output window.</dd> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 187 | <dt>Replace...</dt> | 
|  | 188 | <dd>Open a search-and-replace dialog.</dd> | 
|  | 189 | <dt>Go to Line</dt> | 
|  | 190 | <dd>Move cursor to the line number requested and make that line visible.</dd> | 
|  | 191 | <dt>Show Completions</dt> | 
|  | 192 | <dd>Open a scrollable list allowing selection of keywords and attributes. See | 
|  | 193 | Completions in the Tips sections below.</dd> | 
|  | 194 | <dt>Expand Word</dt> | 
|  | 195 | <dd>Expand a prefix you have typed to match a full word in the same window; | 
|  | 196 | repeat to get a different expansion.</dd> | 
|  | 197 | <dt>Show call tip</dt> | 
|  | 198 | <dd>After an unclosed parenthesis for a function, open a small window with | 
|  | 199 | function parameter hints.</dd> | 
|  | 200 | <dt>Show surrounding parens</dt> | 
|  | 201 | <dd>Highlight the surrounding parenthesis.</dd> | 
|  | 202 | </dl> | 
|  | 203 | </div> | 
|  | 204 | <div class="section" id="format-menu-editor-window-only"> | 
|  | 205 | <h3>25.5.1.3. Format menu (Editor window only)<a class="headerlink" href="#format-menu-editor-window-only" title="Permalink to this headline">¶</a></h3> | 
|  | 206 | <dl class="docutils"> | 
|  | 207 | <dt>Indent Region</dt> | 
|  | 208 | <dd>Shift selected lines right by the indent width (default 4 spaces).</dd> | 
|  | 209 | <dt>Dedent Region</dt> | 
|  | 210 | <dd>Shift selected lines left by the indent width (default 4 spaces).</dd> | 
|  | 211 | <dt>Comment Out Region</dt> | 
|  | 212 | <dd>Insert ## in front of selected lines.</dd> | 
|  | 213 | <dt>Uncomment Region</dt> | 
|  | 214 | <dd>Remove leading # or ## from selected lines.</dd> | 
|  | 215 | <dt>Tabify Region</dt> | 
|  | 216 | <dd>Turn <em>leading</em> stretches of spaces into tabs. (Note: We recommend using | 
|  | 217 | 4 space blocks to indent Python code.)</dd> | 
|  | 218 | <dt>Untabify Region</dt> | 
|  | 219 | <dd>Turn <em>all</em> tabs into the correct number of spaces.</dd> | 
|  | 220 | <dt>Toggle Tabs</dt> | 
|  | 221 | <dd>Open a dialog to switch between indenting with spaces and tabs.</dd> | 
|  | 222 | <dt>New Indent Width</dt> | 
|  | 223 | <dd>Open a dialog to change indent width. The accepted default by the Python | 
|  | 224 | community is 4 spaces.</dd> | 
|  | 225 | <dt>Format Paragraph</dt> | 
|  | 226 | <dd>Reformat the current blank-line-delimited paragraph in comment block or | 
|  | 227 | multiline string or selected line in a string.  All lines in the | 
|  | 228 | paragraph will be formatted to less than N columns, where N defaults to 72.</dd> | 
|  | 229 | <dt>Strip trailing whitespace</dt> | 
|  | 230 | <dd>Remove any space characters after the last non-space character of a line.</dd> | 
|  | 231 | </dl> | 
|  | 232 | </div> | 
|  | 233 | <div class="section" id="run-menu-editor-window-only"> | 
|  | 234 | <span id="index-2"></span><h3>25.5.1.4. Run menu (Editor window only)<a class="headerlink" href="#run-menu-editor-window-only" title="Permalink to this headline">¶</a></h3> | 
|  | 235 | <dl class="docutils"> | 
|  | 236 | <dt>Python Shell</dt> | 
|  | 237 | <dd>Open or wake up the Python Shell window.</dd> | 
|  | 238 | <dt>Check Module</dt> | 
|  | 239 | <dd>Check the syntax of the module currently open in the Editor window. If the | 
|  | 240 | module has not been saved IDLE will either prompt the user to save or | 
|  | 241 | autosave, as selected in the General tab of the Idle Settings dialog.  If | 
|  | 242 | there is a syntax error, the approximate location is indicated in the | 
|  | 243 | Editor window.</dd> | 
|  | 244 | <dt>Run Module</dt> | 
|  | 245 | <dd>Do Check Module (above).  If no error, restart the shell to clean the | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 246 | environment, then execute the module.  Output is displayed in the Shell | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 247 | window.  Note that output requires use of <code class="docutils literal"><span class="pre">print</span></code> or <code class="docutils literal"><span class="pre">write</span></code>. | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 248 | When execution is complete, the Shell retains focus and displays a prompt. | 
|  | 249 | At this point, one may interactively explore the result of execution. | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 250 | This is similar to executing a file with <code class="docutils literal"><span class="pre">python</span> <span class="pre">-i</span> <span class="pre">file</span></code> at a command | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 251 | line.</dd> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 252 | </dl> | 
|  | 253 | </div> | 
|  | 254 | <div class="section" id="shell-menu-shell-window-only"> | 
|  | 255 | <h3>25.5.1.5. Shell menu (Shell window only)<a class="headerlink" href="#shell-menu-shell-window-only" title="Permalink to this headline">¶</a></h3> | 
|  | 256 | <dl class="docutils"> | 
|  | 257 | <dt>View Last Restart</dt> | 
|  | 258 | <dd>Scroll the shell window to the last Shell restart.</dd> | 
|  | 259 | <dt>Restart Shell</dt> | 
|  | 260 | <dd>Restart the shell to clean the environment.</dd> | 
| Terry Jan Reedy | 4b73676 | 2016-09-12 01:50:03 -0400 | [diff] [blame] | 261 | <dt>Interrupt Execution</dt> | 
|  | 262 | <dd>Stop a running program.</dd> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 263 | </dl> | 
|  | 264 | </div> | 
|  | 265 | <div class="section" id="debug-menu-shell-window-only"> | 
|  | 266 | <h3>25.5.1.6. Debug menu (Shell window only)<a class="headerlink" href="#debug-menu-shell-window-only" title="Permalink to this headline">¶</a></h3> | 
|  | 267 | <dl class="docutils"> | 
|  | 268 | <dt>Go to File/Line</dt> | 
|  | 269 | <dd>Look on the current line. with the cursor, and the line above for a filename | 
|  | 270 | and line number.  If found, open the file if not already open, and show the | 
|  | 271 | line.  Use this to view source lines referenced in an exception traceback | 
|  | 272 | and lines found by Find in Files. Also available in the context menu of | 
|  | 273 | the Shell window and Output windows.</dd> | 
|  | 274 | </dl> | 
|  | 275 | <dl class="docutils" id="index-3"> | 
|  | 276 | <dt>Debugger (toggle)</dt> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 277 | <dd>When activated, code entered in the Shell or run from an Editor will run | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 278 | under the debugger.  In the Editor, breakpoints can be set with the context | 
|  | 279 | menu.  This feature is still incomplete and somewhat experimental.</dd> | 
|  | 280 | <dt>Stack Viewer</dt> | 
|  | 281 | <dd>Show the stack traceback of the last exception in a tree widget, with | 
|  | 282 | access to locals and globals.</dd> | 
|  | 283 | <dt>Auto-open Stack Viewer</dt> | 
|  | 284 | <dd>Toggle automatically opening the stack viewer on an unhandled exception.</dd> | 
|  | 285 | </dl> | 
|  | 286 | </div> | 
|  | 287 | <div class="section" id="options-menu-shell-and-editor"> | 
|  | 288 | <h3>25.5.1.7. Options menu (Shell and Editor)<a class="headerlink" href="#options-menu-shell-and-editor" title="Permalink to this headline">¶</a></h3> | 
|  | 289 | <dl class="docutils"> | 
|  | 290 | <dt>Configure IDLE</dt> | 
| Terry Jan Reedy | 93f3542 | 2015-10-13 22:03:51 -0400 | [diff] [blame] | 291 | <dd><p class="first">Open a configuration dialog and change preferences for the following: | 
|  | 292 | fonts, indentation, keybindings, text color themes, startup windows and | 
|  | 293 | size, additional help sources, and extensions (see below).  On OS X, | 
|  | 294 | open the configuration dialog by selecting Preferences in the application | 
|  | 295 | menu.  To use a new built-in color theme (IDLE Dark) with older IDLEs, | 
|  | 296 | save it as a new custom theme.</p> | 
|  | 297 | <p class="last">Non-default user settings are saved in a .idlerc directory in the user’s | 
|  | 298 | home directory.  Problems caused by bad user configuration files are solved | 
|  | 299 | by editing or deleting one or more of the files in .idlerc.</p> | 
|  | 300 | </dd> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 301 | <dt>Code Context (toggle)(Editor Window only)</dt> | 
|  | 302 | <dd>Open a pane at the top of the edit window which shows the block context | 
|  | 303 | of the code which has scrolled above the top of the window.</dd> | 
|  | 304 | </dl> | 
|  | 305 | </div> | 
|  | 306 | <div class="section" id="window-menu-shell-and-editor"> | 
|  | 307 | <h3>25.5.1.8. Window menu (Shell and Editor)<a class="headerlink" href="#window-menu-shell-and-editor" title="Permalink to this headline">¶</a></h3> | 
|  | 308 | <dl class="docutils"> | 
|  | 309 | <dt>Zoom Height</dt> | 
|  | 310 | <dd>Toggles the window between normal size and maximum height. The initial size | 
|  | 311 | defaults to 40 lines by 80 chars unless changed on the General tab of the | 
|  | 312 | Configure IDLE dialog.</dd> | 
|  | 313 | </dl> | 
|  | 314 | <p>The rest of this menu lists the names of all open windows; select one to bring | 
|  | 315 | it to the foreground (deiconifying it if necessary).</p> | 
|  | 316 | </div> | 
|  | 317 | <div class="section" id="help-menu-shell-and-editor"> | 
|  | 318 | <h3>25.5.1.9. Help menu (Shell and Editor)<a class="headerlink" href="#help-menu-shell-and-editor" title="Permalink to this headline">¶</a></h3> | 
|  | 319 | <dl class="docutils"> | 
|  | 320 | <dt>About IDLE</dt> | 
|  | 321 | <dd>Display version, copyright, license, credits, and more.</dd> | 
|  | 322 | <dt>IDLE Help</dt> | 
|  | 323 | <dd>Display a help file for IDLE detailing the menu options, basic editing and | 
|  | 324 | navigation, and other tips.</dd> | 
|  | 325 | <dt>Python Docs</dt> | 
|  | 326 | <dd>Access local Python documentation, if installed, or start a web browser | 
|  | 327 | and open docs.python.org showing the latest Python documentation.</dd> | 
|  | 328 | <dt>Turtle Demo</dt> | 
|  | 329 | <dd>Run the turtledemo module with example python code and turtle drawings.</dd> | 
|  | 330 | </dl> | 
|  | 331 | <p>Additional help sources may be added here with the Configure IDLE dialog under | 
|  | 332 | the General tab.</p> | 
|  | 333 | </div> | 
|  | 334 | <div class="section" id="context-menus"> | 
|  | 335 | <span id="index-4"></span><h3>25.5.1.10. Context Menus<a class="headerlink" href="#context-menus" title="Permalink to this headline">¶</a></h3> | 
|  | 336 | <p>Open a context menu by right-clicking in a window (Control-click on OS X). | 
|  | 337 | Context menus have the standard clipboard functions also on the Edit menu.</p> | 
|  | 338 | <dl class="docutils"> | 
|  | 339 | <dt>Cut</dt> | 
|  | 340 | <dd>Copy selection into the system-wide clipboard; then delete the selection.</dd> | 
|  | 341 | <dt>Copy</dt> | 
|  | 342 | <dd>Copy selection into the system-wide clipboard.</dd> | 
|  | 343 | <dt>Paste</dt> | 
|  | 344 | <dd>Insert contents of the system-wide clipboard into the current window.</dd> | 
|  | 345 | </dl> | 
|  | 346 | <p>Editor windows also have breakpoint functions.  Lines with a breakpoint set are | 
|  | 347 | specially marked.  Breakpoints only have an effect when running under the | 
|  | 348 | debugger.  Breakpoints for a file are saved in the user’s .idlerc directory.</p> | 
|  | 349 | <dl class="docutils"> | 
|  | 350 | <dt>Set Breakpoint</dt> | 
|  | 351 | <dd>Set a breakpoint on the current line.</dd> | 
|  | 352 | <dt>Clear Breakpoint</dt> | 
|  | 353 | <dd>Clear the breakpoint on that line.</dd> | 
|  | 354 | </dl> | 
|  | 355 | <p>Shell and Output windows have the following.</p> | 
|  | 356 | <dl class="docutils"> | 
|  | 357 | <dt>Go to file/line</dt> | 
|  | 358 | <dd>Same as in Debug menu.</dd> | 
|  | 359 | </dl> | 
|  | 360 | </div> | 
|  | 361 | </div> | 
|  | 362 | <div class="section" id="editing-and-navigation"> | 
|  | 363 | <h2>25.5.2. Editing and navigation<a class="headerlink" href="#editing-and-navigation" title="Permalink to this headline">¶</a></h2> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 364 | <p>In this section, ‘C’ refers to the <code class="kbd docutils literal"><span class="pre">Control</span></code> key on Windows and Unix and | 
|  | 365 | the <code class="kbd docutils literal"><span class="pre">Command</span></code> key on Mac OSX.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 366 | <ul> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 367 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">Backspace</span></code> deletes to the left; <code class="kbd docutils literal"><span class="pre">Del</span></code> deletes to the right</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 368 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 369 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">C-Backspace</span></code> delete word left; <code class="kbd docutils literal"><span class="pre">C-Del</span></code> delete word to the right</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 370 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 371 | <li><p class="first">Arrow keys and <code class="kbd docutils literal"><span class="pre">Page</span> <span class="pre">Up</span></code>/<code class="kbd docutils literal"><span class="pre">Page</span> <span class="pre">Down</span></code> to move around</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 372 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 373 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">C-LeftArrow</span></code> and <code class="kbd docutils literal"><span class="pre">C-RightArrow</span></code> moves by words</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 374 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 375 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">Home</span></code>/<code class="kbd docutils literal"><span class="pre">End</span></code> go to begin/end of line</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 376 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 377 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">C-Home</span></code>/<code class="kbd docutils literal"><span class="pre">C-End</span></code> go to begin/end of file</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 378 | </li> | 
|  | 379 | <li><p class="first">Some useful Emacs bindings are inherited from Tcl/Tk:</p> | 
|  | 380 | <blockquote> | 
|  | 381 | <div><ul class="simple"> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 382 | <li><code class="kbd docutils literal"><span class="pre">C-a</span></code> beginning of line</li> | 
|  | 383 | <li><code class="kbd docutils literal"><span class="pre">C-e</span></code> end of line</li> | 
|  | 384 | <li><code class="kbd docutils literal"><span class="pre">C-k</span></code> kill line (but doesn’t put it in clipboard)</li> | 
|  | 385 | <li><code class="kbd docutils literal"><span class="pre">C-l</span></code> center window around the insertion point</li> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 386 | <li><code class="kbd docutils literal"><span class="pre">C-b</span></code> go backward one character without deleting (usually you can | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 387 | also use the cursor key for this)</li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 388 | <li><code class="kbd docutils literal"><span class="pre">C-f</span></code> go forward one character without deleting (usually you can | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 389 | also use the cursor key for this)</li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 390 | <li><code class="kbd docutils literal"><span class="pre">C-p</span></code> go up one line (usually you can also use the cursor key for | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 391 | this)</li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 392 | <li><code class="kbd docutils literal"><span class="pre">C-d</span></code> delete next character</li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 393 | </ul> | 
|  | 394 | </div></blockquote> | 
|  | 395 | </li> | 
|  | 396 | </ul> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 397 | <p>Standard keybindings (like <code class="kbd docutils literal"><span class="pre">C-c</span></code> to copy and <code class="kbd docutils literal"><span class="pre">C-v</span></code> to paste) | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 398 | may work.  Keybindings are selected in the Configure IDLE dialog.</p> | 
|  | 399 | <div class="section" id="automatic-indentation"> | 
|  | 400 | <h3>25.5.2.1. Automatic indentation<a class="headerlink" href="#automatic-indentation" title="Permalink to this headline">¶</a></h3> | 
|  | 401 | <p>After a block-opening statement, the next line is indented by 4 spaces (in the | 
|  | 402 | Python Shell window by one tab).  After certain keywords (break, return etc.) | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 403 | the next line is dedented.  In leading indentation, <code class="kbd docutils literal"><span class="pre">Backspace</span></code> deletes up | 
|  | 404 | to 4 spaces if they are there. <code class="kbd docutils literal"><span class="pre">Tab</span></code> inserts spaces (in the Python | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 405 | Shell window one tab), number depends on Indent width. Currently, tabs | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 406 | are restricted to four spaces due to Tcl/Tk limitations.</p> | 
|  | 407 | <p>See also the indent/dedent region commands in the edit menu.</p> | 
|  | 408 | </div> | 
|  | 409 | <div class="section" id="completions"> | 
|  | 410 | <h3>25.5.2.2. Completions<a class="headerlink" href="#completions" title="Permalink to this headline">¶</a></h3> | 
|  | 411 | <p>Completions are supplied for functions, classes, and attributes of classes, | 
|  | 412 | both built-in and user-defined. Completions are also provided for | 
|  | 413 | filenames.</p> | 
|  | 414 | <p>The AutoCompleteWindow (ACW) will open after a predefined delay (default is | 
|  | 415 | two seconds) after a ‘.’ or (in a string) an os.sep is typed. If after one | 
|  | 416 | of those characters (plus zero or more other characters) a tab is typed | 
|  | 417 | the ACW will open immediately if a possible continuation is found.</p> | 
|  | 418 | <p>If there is only one possible completion for the characters entered, a | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 419 | <code class="kbd docutils literal"><span class="pre">Tab</span></code> will supply that completion without opening the ACW.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 420 | <p>‘Show Completions’ will force open a completions window, by default the | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 421 | <code class="kbd docutils literal"><span class="pre">C-space</span></code> will open a completions window. In an empty | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 422 | string, this will contain the files in the current directory. On a | 
|  | 423 | blank line, it will contain the built-in and user-defined functions and | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 424 | classes in the current namespaces, plus any modules imported. If some | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 425 | characters have been entered, the ACW will attempt to be more specific.</p> | 
|  | 426 | <p>If a string of characters is typed, the ACW selection will jump to the | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 427 | entry most closely matching those characters.  Entering a <code class="kbd docutils literal"><span class="pre">tab</span></code> will | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 428 | cause the longest non-ambiguous match to be entered in the Editor window or | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 429 | Shell.  Two <code class="kbd docutils literal"><span class="pre">tab</span></code> in a row will supply the current ACW selection, as | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 430 | will return or a double click.  Cursor keys, Page Up/Down, mouse selection, | 
|  | 431 | and the scroll wheel all operate on the ACW.</p> | 
|  | 432 | <p>“Hidden” attributes can be accessed by typing the beginning of hidden | 
|  | 433 | name after a ‘.’, e.g. ‘_’. This allows access to modules with | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 434 | <code class="docutils literal"><span class="pre">__all__</span></code> set, or to class-private attributes.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 435 | <p>Completions and the ‘Expand Word’ facility can save a lot of typing!</p> | 
|  | 436 | <p>Completions are currently limited to those in the namespaces. Names in | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 437 | an Editor window which are not via <code class="docutils literal"><span class="pre">__main__</span></code> and <a class="reference internal" href="sys.html#sys.modules" title="sys.modules"><code class="xref py py-data docutils literal"><span class="pre">sys.modules</span></code></a> will | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 438 | not be found.  Run the module once with your imports to correct this situation. | 
|  | 439 | Note that IDLE itself places quite a few modules in sys.modules, so | 
|  | 440 | much can be found by default, e.g. the re module.</p> | 
|  | 441 | <p>If you don’t like the ACW popping up unbidden, simply make the delay | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 442 | longer or disable the extension.</p> | 
|  | 443 | </div> | 
|  | 444 | <div class="section" id="calltips"> | 
|  | 445 | <h3>25.5.2.3. Calltips<a class="headerlink" href="#calltips" title="Permalink to this headline">¶</a></h3> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 446 | <p>A calltip is shown when one types <code class="kbd docutils literal"><span class="pre">(</span></code> after the name of an <em>accessible</em> | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 447 | function.  A name expression may include dots and subscripts.  A calltip | 
|  | 448 | remains until it is clicked, the cursor is moved out of the argument area, | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 449 | or <code class="kbd docutils literal"><span class="pre">)</span></code> is typed.  When the cursor is in the argument part of a definition, | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 450 | the menu or shortcut display a calltip.</p> | 
|  | 451 | <p>A calltip consists of the function signature and the first line of the | 
|  | 452 | docstring.  For builtins without an accessible signature, the calltip | 
|  | 453 | consists of all lines up the fifth line or the first blank line.  These | 
|  | 454 | details may change.</p> | 
|  | 455 | <p>The set of <em>accessible</em> functions depends on what modules have been imported | 
|  | 456 | into the user process, including those imported by Idle itself, | 
|  | 457 | and what definitions have been run, all since the last restart.</p> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 458 | <p>For example, restart the Shell and enter <code class="docutils literal"><span class="pre">itertools.count(</span></code>.  A calltip | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 459 | appears because Idle imports itertools into the user process for its own use. | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 460 | (This could change.)  Enter <code class="docutils literal"><span class="pre">turtle.write(</span></code> and nothing appears.  Idle does | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 461 | not import turtle.  The menu or shortcut do nothing either.  Enter | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 462 | <code class="docutils literal"><span class="pre">import</span> <span class="pre">turtle</span></code> and then <code class="docutils literal"><span class="pre">turtle.write(</span></code> will work.</p> | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 463 | <p>In an editor, import statements have no effect until one runs the file.  One | 
|  | 464 | might want to run a file after writing the import statements at the top, | 
|  | 465 | or immediately run an existing file before editing.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 466 | </div> | 
|  | 467 | <div class="section" id="python-shell-window"> | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 468 | <h3>25.5.2.4. Python Shell window<a class="headerlink" href="#python-shell-window" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 469 | <ul> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 470 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">C-c</span></code> interrupts executing command</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 471 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 472 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">C-d</span></code> sends end-of-file; closes window if typed at a <code class="docutils literal"><span class="pre">>>></span></code> prompt</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 473 | </li> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 474 | <li><p class="first"><code class="kbd docutils literal"><span class="pre">Alt-/</span></code> (Expand word) is also useful to reduce typing</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 475 | <p>Command history</p> | 
|  | 476 | <ul class="simple"> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 477 | <li><code class="kbd docutils literal"><span class="pre">Alt-p</span></code> retrieves previous command matching what you have typed. On | 
|  | 478 | OS X use <code class="kbd docutils literal"><span class="pre">C-p</span></code>.</li> | 
|  | 479 | <li><code class="kbd docutils literal"><span class="pre">Alt-n</span></code> retrieves next. On OS X use <code class="kbd docutils literal"><span class="pre">C-n</span></code>.</li> | 
|  | 480 | <li><code class="kbd docutils literal"><span class="pre">Return</span></code> while on any previous command retrieves that command</li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 481 | </ul> | 
|  | 482 | </li> | 
|  | 483 | </ul> | 
|  | 484 | </div> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 485 | <div class="section" id="text-colors"> | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 486 | <h3>25.5.2.5. Text colors<a class="headerlink" href="#text-colors" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 487 | <p>Idle defaults to black on white text, but colors text with special meanings. | 
|  | 488 | For the shell, these are shell output, shell error, user output, and | 
|  | 489 | user error.  For Python code, at the shell prompt or in an editor, these are | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 490 | keywords, builtin class and function names, names following <code class="docutils literal"><span class="pre">class</span></code> and | 
|  | 491 | <code class="docutils literal"><span class="pre">def</span></code>, strings, and comments. For any text window, these are the cursor (when | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 492 | present), found text (when possible), and selected text.</p> | 
|  | 493 | <p>Text coloring is done in the background, so uncolorized text is occasionally | 
|  | 494 | visible.  To change the color scheme, use the Configure IDLE dialog | 
|  | 495 | Highlighting tab.  The marking of debugger breakpoint lines in the editor and | 
|  | 496 | text in popups and dialogs is not user-configurable.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 497 | </div> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 498 | </div> | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 499 | <div class="section" id="startup-and-code-execution"> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 500 | <h2>25.5.3. Startup and code execution<a class="headerlink" href="#startup-and-code-execution" title="Permalink to this headline">¶</a></h2> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 501 | <p>Upon startup with the <code class="docutils literal"><span class="pre">-s</span></code> option, IDLE will execute the file referenced by | 
|  | 502 | the environment variables <span class="target" id="index-5"></span><code class="xref std std-envvar docutils literal"><span class="pre">IDLESTARTUP</span></code> or <span class="target" id="index-6"></span><a class="reference internal" href="../using/cmdline.html#envvar-PYTHONSTARTUP"><code class="xref std std-envvar docutils literal"><span class="pre">PYTHONSTARTUP</span></code></a>. | 
|  | 503 | IDLE first checks for <code class="docutils literal"><span class="pre">IDLESTARTUP</span></code>; if <code class="docutils literal"><span class="pre">IDLESTARTUP</span></code> is present the file | 
|  | 504 | referenced is run.  If <code class="docutils literal"><span class="pre">IDLESTARTUP</span></code> is not present, IDLE checks for | 
|  | 505 | <code class="docutils literal"><span class="pre">PYTHONSTARTUP</span></code>.  Files referenced by these environment variables are | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 506 | convenient places to store functions that are used frequently from the IDLE | 
|  | 507 | shell, or for executing import statements to import common modules.</p> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 508 | <p>In addition, <code class="docutils literal"><span class="pre">Tk</span></code> also loads a startup file if it is present.  Note that the | 
|  | 509 | Tk file is loaded unconditionally.  This additional file is <code class="docutils literal"><span class="pre">.Idle.py</span></code> and is | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 510 | looked for in the user’s home directory.  Statements in this file will be | 
|  | 511 | executed in the Tk namespace, so this file is not useful for importing | 
|  | 512 | functions to be used from IDLE’s Python shell.</p> | 
|  | 513 | <div class="section" id="command-line-usage"> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 514 | <h3>25.5.3.1. Command line usage<a class="headerlink" href="#command-line-usage" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | 1f8cc33 | 2016-08-25 01:22:30 -0400 | [diff] [blame] | 515 | <div class="highlight-none"><div class="highlight"><pre><span></span>idle.py [-c command] [-d] [-e] [-h] [-i] [-r file] [-s] [-t title] [-] [arg] ... | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 516 |  | 
| Terry Jan Reedy | 968e285 | 2015-09-23 03:52:23 -0400 | [diff] [blame] | 517 | -c command  run command in the shell window | 
|  | 518 | -d          enable debugger and open shell window | 
|  | 519 | -e          open editor window | 
| Terry Jan Reedy | 3399e1e | 2016-08-30 16:58:01 -0400 | [diff] [blame] | 520 | -h          print help message with legal combinations and exit | 
| Terry Jan Reedy | 968e285 | 2015-09-23 03:52:23 -0400 | [diff] [blame] | 521 | -i          open shell window | 
|  | 522 | -r file     run file in shell window | 
|  | 523 | -s          run $IDLESTARTUP or $PYTHONSTARTUP first, in shell window | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 524 | -t title    set title of shell window | 
| Terry Jan Reedy | 968e285 | 2015-09-23 03:52:23 -0400 | [diff] [blame] | 525 | -           run stdin in shell (- must be last option before args) | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 526 | </pre></div> | 
|  | 527 | </div> | 
|  | 528 | <p>If there are arguments:</p> | 
| Terry Jan Reedy | 968e285 | 2015-09-23 03:52:23 -0400 | [diff] [blame] | 529 | <ul class="simple"> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 530 | <li>If <code class="docutils literal"><span class="pre">-</span></code>, <code class="docutils literal"><span class="pre">-c</span></code>, or <code class="docutils literal"><span class="pre">r</span></code> is used, all arguments are placed in | 
|  | 531 | <code class="docutils literal"><span class="pre">sys.argv[1:...]</span></code> and <code class="docutils literal"><span class="pre">sys.argv[0]</span></code> is set to <code class="docutils literal"><span class="pre">''</span></code>, <code class="docutils literal"><span class="pre">'-c'</span></code>, | 
|  | 532 | or <code class="docutils literal"><span class="pre">'-r'</span></code>.  No editor window is opened, even if that is the default | 
| Terry Jan Reedy | 968e285 | 2015-09-23 03:52:23 -0400 | [diff] [blame] | 533 | set in the Options dialog.</li> | 
|  | 534 | <li>Otherwise, arguments are files opened for editing and | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 535 | <code class="docutils literal"><span class="pre">sys.argv</span></code> reflects the arguments passed to IDLE itself.</li> | 
| Terry Jan Reedy | 968e285 | 2015-09-23 03:52:23 -0400 | [diff] [blame] | 536 | </ul> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 537 | </div> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 538 | <div class="section" id="startup-failure"> | 
|  | 539 | <h3>25.5.3.2. Startup failure<a class="headerlink" href="#startup-failure" title="Permalink to this headline">¶</a></h3> | 
|  | 540 | <p>IDLE uses a socket to communicate between the IDLE GUI process and the user | 
|  | 541 | code execution process.  A connection must be established whenever the Shell | 
|  | 542 | starts or restarts.  (The latter is indicated by a divider line that says | 
|  | 543 | ‘RESTART’). If the user process fails to connect to the GUI process, it | 
|  | 544 | displays a <code class="docutils literal"><span class="pre">Tk</span></code> error box with a ‘cannot connect’ message that directs the | 
|  | 545 | user here.  It then exits.</p> | 
|  | 546 | <p>A common cause of failure is a user-written file with the same name as a | 
|  | 547 | standard library module, such as <em>random.py</em> and <em>tkinter.py</em>. When such a | 
|  | 548 | file is located in the same directory as a file that is about to be run, | 
|  | 549 | IDLE cannot import the stdlib file.  The current fix is to rename the | 
|  | 550 | user file.</p> | 
|  | 551 | <p>Though less common than in the past, an antivirus or firewall program may | 
|  | 552 | stop the connection.  If the program cannot be taught to allow the | 
|  | 553 | connection, then it must be turned off for IDLE to work.  It is safe to | 
|  | 554 | allow this internal connection because no data is visible on external | 
|  | 555 | ports.  A similar problem is a network mis-configuration that blocks | 
|  | 556 | connections.</p> | 
|  | 557 | <p>Python installation issues occasionally stop IDLE: multiple versions can | 
|  | 558 | clash, or a single installation might need admin access.  If one undo the | 
|  | 559 | clash, or cannot or does not want to run as admin, it might be easiest to | 
|  | 560 | completely remove Python and start over.</p> | 
|  | 561 | <p>A zombie pythonw.exe process could be a problem.  On Windows, use Task | 
|  | 562 | Manager to detect and stop one.  Sometimes a restart initiated by a program | 
|  | 563 | crash or Keyboard Interrupt (control-C) may fail to connect.  Dismissing | 
|  | 564 | the error box or Restart Shell on the Shell menu may fix a temporary problem.</p> | 
|  | 565 | <p>When IDLE first starts, it attempts to read user configuration files in | 
|  | 566 | ~/.idlerc/ (~ is one’s home directory).  If there is a problem, an error | 
|  | 567 | message should be displayed.  Leaving aside random disk glitches, this can | 
|  | 568 | be prevented by never editing the files by hand, using the configuration | 
|  | 569 | dialog, under Options, instead Options.  Once it happens, the solution may | 
|  | 570 | be to delete one or more of the configuration files.</p> | 
|  | 571 | <p>If IDLE quits with no message, and it was not started from a console, try | 
|  | 572 | starting from a console (<code class="docutils literal"><span class="pre">python</span> <span class="pre">-m</span> <span class="pre">idlelib)</span></code> and see if a message appears.</p> | 
|  | 573 | </div> | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 574 | <div class="section" id="idle-console-differences"> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 575 | <h3>25.5.3.3. IDLE-console differences<a class="headerlink" href="#idle-console-differences" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | 98758bc | 2017-09-12 09:05:16 -0400 | [diff] [blame^] | 576 | <p>With rare exceptions, the result of executing Python code with IDLE is | 
|  | 577 | intended to be the same as executing the same code in a console window. | 
|  | 578 | However, the different interface and operation occasionally affect | 
|  | 579 | visible results.  For instance, <code class="docutils literal"><span class="pre">sys.modules</span></code> starts with more entries.</p> | 
| Terry Jan Reedy | 929d7f8 | 2016-05-02 18:30:02 -0400 | [diff] [blame] | 580 | <p>IDLE also replaces <code class="docutils literal"><span class="pre">sys.stdin</span></code>, <code class="docutils literal"><span class="pre">sys.stdout</span></code>, and <code class="docutils literal"><span class="pre">sys.stderr</span></code> with | 
|  | 581 | objects that get input from and send output to the Shell window. | 
| Terry Jan Reedy | 98758bc | 2017-09-12 09:05:16 -0400 | [diff] [blame^] | 582 | When Shell has the focus, it controls the keyboard and screen.  This is | 
|  | 583 | normally transparent, but functions that directly access the keyboard | 
| Terry Jan Reedy | 929d7f8 | 2016-05-02 18:30:02 -0400 | [diff] [blame] | 584 | and screen will not work.  If <code class="docutils literal"><span class="pre">sys</span></code> is reset with <code class="docutils literal"><span class="pre">importlib.reload(sys)</span></code>, | 
| Terry Jan Reedy | 1f8cc33 | 2016-08-25 01:22:30 -0400 | [diff] [blame] | 585 | IDLE’s changes are lost and things like <code class="docutils literal"><span class="pre">input</span></code>, <code class="docutils literal"><span class="pre">raw_input</span></code>, and | 
| Terry Jan Reedy | 929d7f8 | 2016-05-02 18:30:02 -0400 | [diff] [blame] | 586 | <code class="docutils literal"><span class="pre">print</span></code> will not work correctly.</p> | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 587 | <p>With IDLE’s Shell, one enters, edits, and recalls complete statements. | 
| Terry Jan Reedy | 1f8cc33 | 2016-08-25 01:22:30 -0400 | [diff] [blame] | 588 | Some consoles only work with a single physical line at a time.  IDLE uses | 
|  | 589 | <code class="docutils literal"><span class="pre">exec</span></code> to run each statement.  As a result, <code class="docutils literal"><span class="pre">'__builtins__'</span></code> is always | 
|  | 590 | defined for each statement.</p> | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 591 | </div> | 
| Terry Jan Reedy | 98758bc | 2017-09-12 09:05:16 -0400 | [diff] [blame^] | 592 | <div class="section" id="developing-tkinter-applications"> | 
|  | 593 | <h3>25.5.3.4. Developing tkinter applications<a class="headerlink" href="#developing-tkinter-applications" title="Permalink to this headline">¶</a></h3> | 
|  | 594 | <p>IDLE is intentionally different from standard Python in order to | 
|  | 595 | facilitate development of tkinter programs.  Enter <code class="docutils literal"><span class="pre">import</span> <span class="pre">tkinter</span> <span class="pre">as</span> <span class="pre">tk;</span> | 
|  | 596 | <span class="pre">root</span> <span class="pre">=</span> <span class="pre">tk.Tk()</span></code> in standard Python and nothing appears.  Enter the same | 
|  | 597 | in IDLE and a tk window appears.  In standard Python, one must also enter | 
|  | 598 | <code class="docutils literal"><span class="pre">root.update()</span></code> to see the window.  IDLE does the equivalent in the | 
|  | 599 | background, about 20 times a second, which is about every 50 milleseconds. | 
|  | 600 | Next enter <code class="docutils literal"><span class="pre">b</span> <span class="pre">=</span> <span class="pre">tk.Button(root,</span> <span class="pre">text='button');</span> <span class="pre">b.pack()</span></code>.  Again, | 
|  | 601 | nothing visibly changes in standard Python until one enters <code class="docutils literal"><span class="pre">root.update()</span></code>.</p> | 
|  | 602 | <p>Most tkinter programs run <code class="docutils literal"><span class="pre">root.mainloop()</span></code>, which usually does not | 
|  | 603 | return until the tk app is destroyed.  If the program is run with | 
|  | 604 | <code class="docutils literal"><span class="pre">python</span> <span class="pre">-i</span></code> or from an IDLE editor, a <code class="docutils literal"><span class="pre">>>></span></code> shell prompt does not | 
|  | 605 | appear until <code class="docutils literal"><span class="pre">mainloop()</span></code> returns, at which time there is nothing left | 
|  | 606 | to interact with.</p> | 
|  | 607 | <p>When running a tkinter program from an IDLE editor, one can comment out | 
|  | 608 | the mainloop call.  One then gets a shell prompt immediately and can | 
|  | 609 | interact with the live application.  One just has to remember to | 
|  | 610 | re-enable the mainloop call when running in standard Python.</p> | 
|  | 611 | </div> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 612 | <div class="section" id="running-without-a-subprocess"> | 
| Terry Jan Reedy | 98758bc | 2017-09-12 09:05:16 -0400 | [diff] [blame^] | 613 | <h3>25.5.3.5. Running without a subprocess<a class="headerlink" href="#running-without-a-subprocess" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | 0053c47 | 2015-09-24 03:09:43 -0400 | [diff] [blame] | 614 | <p>By default, IDLE executes user code in a separate subprocess via a socket, | 
| Terry Jan Reedy | 6e10ec5 | 2015-09-23 20:00:33 -0400 | [diff] [blame] | 615 | which uses the internal loopback interface.  This connection is not | 
|  | 616 | externally visible and no data is sent to or received from the Internet. | 
|  | 617 | If firewall software complains anyway, you can ignore it.</p> | 
|  | 618 | <p>If the attempt to make the socket connection fails, Idle will notify you. | 
|  | 619 | Such failures are sometimes transient, but if persistent, the problem | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 620 | may be either a firewall blocking the connection or misconfiguration of | 
| Terry Jan Reedy | 6e10ec5 | 2015-09-23 20:00:33 -0400 | [diff] [blame] | 621 | a particular system.  Until the problem is fixed, one can run Idle with | 
|  | 622 | the -n command line switch.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 623 | <p>If IDLE is started with the -n command line switch it will run in a | 
|  | 624 | single process and will not create the subprocess which runs the RPC | 
|  | 625 | Python execution server.  This can be useful if Python cannot create | 
|  | 626 | the subprocess or the RPC socket interface on your platform.  However, | 
|  | 627 | in this mode user code is not isolated from IDLE itself.  Also, the | 
|  | 628 | environment is not restarted when Run/Run Module (F5) is selected.  If | 
|  | 629 | your code has been modified, you must reload() the affected modules and | 
|  | 630 | re-import any specific items (e.g. from foo import baz) if the changes | 
|  | 631 | are to take effect.  For these reasons, it is preferable to run IDLE | 
|  | 632 | with the default subprocess if at all possible.</p> | 
|  | 633 | <div class="deprecated"> | 
|  | 634 | <p><span class="versionmodified">Deprecated since version 3.4.</span></p> | 
|  | 635 | </div> | 
|  | 636 | </div> | 
|  | 637 | </div> | 
|  | 638 | <div class="section" id="help-and-preferences"> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 639 | <h2>25.5.4. Help and preferences<a class="headerlink" href="#help-and-preferences" title="Permalink to this headline">¶</a></h2> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 640 | <div class="section" id="additional-help-sources"> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 641 | <h3>25.5.4.1. Additional help sources<a class="headerlink" href="#additional-help-sources" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 642 | <p>IDLE includes a help menu entry called “Python Docs” that will open the | 
|  | 643 | extensive sources of help, including tutorials, available at docs.python.org. | 
|  | 644 | Selected URLs can be added or removed from the help menu at any time using the | 
|  | 645 | Configure IDLE dialog. See the IDLE help option in the help menu of IDLE for | 
|  | 646 | more information.</p> | 
|  | 647 | </div> | 
|  | 648 | <div class="section" id="setting-preferences"> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 649 | <h3>25.5.4.2. Setting preferences<a class="headerlink" href="#setting-preferences" title="Permalink to this headline">¶</a></h3> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 650 | <p>The font preferences, highlighting, keys, and general preferences can be | 
|  | 651 | changed via Configure IDLE on the Option menu.  Keys can be user defined; | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 652 | IDLE ships with four built-in key sets. In addition, a user can create a | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 653 | custom key set in the Configure IDLE dialog under the keys tab.</p> | 
|  | 654 | </div> | 
|  | 655 | <div class="section" id="extensions"> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 656 | <h3>25.5.4.3. Extensions<a class="headerlink" href="#extensions" title="Permalink to this headline">¶</a></h3> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 657 | <p>IDLE contains an extension facility.  Preferences for extensions can be | 
| Terry Jan Reedy | adb4cd2 | 2017-09-12 07:45:15 -0400 | [diff] [blame] | 658 | changed with the Extensions tab of the preferences dialog. See the | 
|  | 659 | beginning of config-extensions.def in the idlelib directory for further | 
|  | 660 | information.  The only current default extension is zzdummy, an example | 
| Terry Jan Reedy | 98758bc | 2017-09-12 09:05:16 -0400 | [diff] [blame^] | 661 | also used for testing.</p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 662 | </div> | 
|  | 663 | </div> | 
|  | 664 | </div> | 
|  | 665 |  | 
|  | 666 |  | 
|  | 667 | </div> | 
|  | 668 | </div> | 
|  | 669 | </div> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 670 | <div class="sphinxsidebar" role="navigation" aria-label="main navigation"> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 671 | <div class="sphinxsidebarwrapper"> | 
|  | 672 | <h3><a href="../contents.html">Table Of Contents</a></h3> | 
|  | 673 | <ul> | 
|  | 674 | <li><a class="reference internal" href="#">25.5. IDLE</a><ul> | 
|  | 675 | <li><a class="reference internal" href="#menus">25.5.1. Menus</a><ul> | 
|  | 676 | <li><a class="reference internal" href="#file-menu-shell-and-editor">25.5.1.1. File menu (Shell and Editor)</a></li> | 
|  | 677 | <li><a class="reference internal" href="#edit-menu-shell-and-editor">25.5.1.2. Edit menu (Shell and Editor)</a></li> | 
|  | 678 | <li><a class="reference internal" href="#format-menu-editor-window-only">25.5.1.3. Format menu (Editor window only)</a></li> | 
|  | 679 | <li><a class="reference internal" href="#run-menu-editor-window-only">25.5.1.4. Run menu (Editor window only)</a></li> | 
|  | 680 | <li><a class="reference internal" href="#shell-menu-shell-window-only">25.5.1.5. Shell menu (Shell window only)</a></li> | 
|  | 681 | <li><a class="reference internal" href="#debug-menu-shell-window-only">25.5.1.6. Debug menu (Shell window only)</a></li> | 
|  | 682 | <li><a class="reference internal" href="#options-menu-shell-and-editor">25.5.1.7. Options menu (Shell and Editor)</a></li> | 
|  | 683 | <li><a class="reference internal" href="#window-menu-shell-and-editor">25.5.1.8. Window menu (Shell and Editor)</a></li> | 
|  | 684 | <li><a class="reference internal" href="#help-menu-shell-and-editor">25.5.1.9. Help menu (Shell and Editor)</a></li> | 
|  | 685 | <li><a class="reference internal" href="#context-menus">25.5.1.10. Context Menus</a></li> | 
|  | 686 | </ul> | 
|  | 687 | </li> | 
|  | 688 | <li><a class="reference internal" href="#editing-and-navigation">25.5.2. Editing and navigation</a><ul> | 
|  | 689 | <li><a class="reference internal" href="#automatic-indentation">25.5.2.1. Automatic indentation</a></li> | 
|  | 690 | <li><a class="reference internal" href="#completions">25.5.2.2. Completions</a></li> | 
| Terry Jan Reedy | 37f8135 | 2015-09-29 01:55:57 -0400 | [diff] [blame] | 691 | <li><a class="reference internal" href="#calltips">25.5.2.3. Calltips</a></li> | 
|  | 692 | <li><a class="reference internal" href="#python-shell-window">25.5.2.4. Python Shell window</a></li> | 
|  | 693 | <li><a class="reference internal" href="#text-colors">25.5.2.5. Text colors</a></li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 694 | </ul> | 
|  | 695 | </li> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 696 | <li><a class="reference internal" href="#startup-and-code-execution">25.5.3. Startup and code execution</a><ul> | 
|  | 697 | <li><a class="reference internal" href="#command-line-usage">25.5.3.1. Command line usage</a></li> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 698 | <li><a class="reference internal" href="#startup-failure">25.5.3.2. Startup failure</a></li> | 
|  | 699 | <li><a class="reference internal" href="#idle-console-differences">25.5.3.3. IDLE-console differences</a></li> | 
| Terry Jan Reedy | 98758bc | 2017-09-12 09:05:16 -0400 | [diff] [blame^] | 700 | <li><a class="reference internal" href="#developing-tkinter-applications">25.5.3.4. Developing tkinter applications</a></li> | 
|  | 701 | <li><a class="reference internal" href="#running-without-a-subprocess">25.5.3.5. Running without a subprocess</a></li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 702 | </ul> | 
|  | 703 | </li> | 
| Terry Jan Reedy | ce021db | 2015-09-24 23:18:57 -0400 | [diff] [blame] | 704 | <li><a class="reference internal" href="#help-and-preferences">25.5.4. Help and preferences</a><ul> | 
|  | 705 | <li><a class="reference internal" href="#additional-help-sources">25.5.4.1. Additional help sources</a></li> | 
|  | 706 | <li><a class="reference internal" href="#setting-preferences">25.5.4.2. Setting preferences</a></li> | 
|  | 707 | <li><a class="reference internal" href="#extensions">25.5.4.3. Extensions</a></li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 708 | </ul> | 
|  | 709 | </li> | 
|  | 710 | </ul> | 
|  | 711 | </li> | 
|  | 712 | </ul> | 
|  | 713 |  | 
|  | 714 | <h4>Previous topic</h4> | 
|  | 715 | <p class="topless"><a href="tkinter.scrolledtext.html" | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 716 | title="previous chapter">25.4. <code class="docutils literal"><span class="pre">tkinter.scrolledtext</span></code> — Scrolled Text Widget</a></p> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 717 | <h4>Next topic</h4> | 
|  | 718 | <p class="topless"><a href="othergui.html" | 
|  | 719 | title="next chapter">25.6. Other Graphical User Interface Packages</a></p> | 
| Terry Jan Reedy | 4b73676 | 2016-09-12 01:50:03 -0400 | [diff] [blame] | 720 | <div role="note" aria-label="source link"> | 
|  | 721 | <h3>This Page</h3> | 
|  | 722 | <ul class="this-page-menu"> | 
|  | 723 | <li><a href="../bugs.html">Report a Bug</a></li> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 724 | <li> | 
| Terry Jan Reedy | adb4cd2 | 2017-09-12 07:45:15 -0400 | [diff] [blame] | 725 | <a href="https://github.com/python/cpython/blob/master/Doc/library/idle.txt" | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 726 | rel="nofollow">Show Source | 
|  | 727 | </a> | 
|  | 728 | </li> | 
| Terry Jan Reedy | 4b73676 | 2016-09-12 01:50:03 -0400 | [diff] [blame] | 729 | </ul> | 
|  | 730 | </div> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 731 | </div> | 
|  | 732 | </div> | 
|  | 733 | <div class="clearer"></div> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 734 | </div> | 
| Terry Jan Reedy | f8cd02d | 2016-03-01 00:29:57 -0500 | [diff] [blame] | 735 | <div class="related" role="navigation" aria-label="related navigation"> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 736 | <h3>Navigation</h3> | 
|  | 737 | <ul> | 
|  | 738 | <li class="right" style="margin-right: 10px"> | 
|  | 739 | <a href="../genindex.html" title="General Index" | 
|  | 740 | >index</a></li> | 
|  | 741 | <li class="right" > | 
|  | 742 | <a href="../py-modindex.html" title="Python Module Index" | 
|  | 743 | >modules</a> |</li> | 
|  | 744 | <li class="right" > | 
|  | 745 | <a href="othergui.html" title="25.6. Other Graphical User Interface Packages" | 
|  | 746 | >next</a> |</li> | 
|  | 747 | <li class="right" > | 
|  | 748 | <a href="tkinter.scrolledtext.html" title="25.4. tkinter.scrolledtext — Scrolled Text Widget" | 
|  | 749 | >previous</a> |</li> | 
|  | 750 | <li><img src="../_static/py.png" alt="" | 
|  | 751 | style="vertical-align: middle; margin-top: -1px"/></li> | 
| Terry Jan Reedy | 3399e1e | 2016-08-30 16:58:01 -0400 | [diff] [blame] | 752 | <li><a href="https://www.python.org/">Python</a> »</li> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 753 | <li> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 754 | <a href="../index.html">3.7.0a0 Documentation</a> » | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 755 | </li> | 
|  | 756 |  | 
| Terry Jan Reedy | 3399e1e | 2016-08-30 16:58:01 -0400 | [diff] [blame] | 757 | <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> »</li> | 
|  | 758 | <li class="nav-item nav-item-2"><a href="tk.html" >25. Graphical User Interfaces with Tk</a> »</li> | 
| Terry Jan Reedy | 4b73676 | 2016-09-12 01:50:03 -0400 | [diff] [blame] | 759 | <li class="right"> | 
|  | 760 |  | 
|  | 761 |  | 
|  | 762 | <div class="inline-search" style="display: none" role="search"> | 
|  | 763 | <form class="inline-search" action="../search.html" method="get"> | 
|  | 764 | <input placeholder="Quick search" type="text" name="q" /> | 
|  | 765 | <input type="submit" value="Go" /> | 
|  | 766 | <input type="hidden" name="check_keywords" value="yes" /> | 
|  | 767 | <input type="hidden" name="area" value="default" /> | 
|  | 768 | </form> | 
|  | 769 | </div> | 
|  | 770 | <script type="text/javascript">$('.inline-search').show(0);</script> | 
|  | 771 | | | 
|  | 772 | </li> | 
|  | 773 |  | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 774 | </ul> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 775 | </div> | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 776 | <div class="footer"> | 
| terryjreedy | 188aedf | 2017-06-13 21:32:16 -0400 | [diff] [blame] | 777 | © <a href="../copyright.html">Copyright</a> 2001-2017, Python Software Foundation. | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 778 | <br /> | 
|  | 779 | The Python Software Foundation is a non-profit corporation. | 
|  | 780 | <a href="https://www.python.org/psf/donations/">Please donate.</a> | 
|  | 781 | <br /> | 
| Terry Jan Reedy | adb4cd2 | 2017-09-12 07:45:15 -0400 | [diff] [blame] | 782 | Last updated on Sep 12, 2017. | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 783 | <a href="../bugs.html">Found a bug</a>? | 
|  | 784 | <br /> | 
| Terry Jan Reedy | 3399e1e | 2016-08-30 16:58:01 -0400 | [diff] [blame] | 785 | Created using <a href="http://sphinx.pocoo.org/">Sphinx</a> 1.3.6. | 
| Terry Jan Reedy | 5d46ab1 | 2015-09-20 19:57:13 -0400 | [diff] [blame] | 786 | </div> | 
|  | 787 |  | 
|  | 788 | </body> | 
| Terry Jan Reedy | 963a38b | 2015-09-20 20:03:01 -0400 | [diff] [blame] | 789 | </html> |