diff options
author | Ned Deily <nad@acm.org> | 2013-12-11 00:24:01 (GMT) |
---|---|---|
committer | Ned Deily <nad@acm.org> | 2013-12-11 00:24:01 (GMT) |
commit | f3c6589ea3890d10d6774ec7699a419313a6fb0f (patch) | |
tree | fff53be1ff2a02eb886efc558c4db29f0ec8b294 /Lib | |
parent | ea6854a9efe009201caea7ce7f05b0f21240b75a (diff) | |
download | cpython-f3c6589ea3890d10d6774ec7699a419313a6fb0f.zip cpython-f3c6589ea3890d10d6774ec7699a419313a6fb0f.tar.gz cpython-f3c6589ea3890d10d6774ec7699a419313a6fb0f.tar.bz2 |
Issue #18270: Prevent possible IDLE AttributeError on OS X when no initial
shell window is present. (Original patch by Terry Reedy)
Diffstat (limited to 'Lib')
-rwxr-xr-x[-rw-r--r--] | Lib/idlelib/PyShell.py | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/Lib/idlelib/PyShell.py b/Lib/idlelib/PyShell.py index f50ca28..6674f4e 100644..100755 --- a/Lib/idlelib/PyShell.py +++ b/Lib/idlelib/PyShell.py @@ -1534,20 +1534,22 @@ def main(): args.remove(filename) if not args: flist.new() + if enable_shell: shell = flist.open_shell() if not shell: return # couldn't open shell - if macosxSupport.runningAsOSXApp() and flist.dict: # On OSX: when the user has double-clicked on a file that causes # IDLE to be launched the shell window will open just in front of # the file she wants to see. Lower the interpreter window when # there are open files. shell.top.lower() + else: + shell = flist.pyshell - shell = flist.pyshell - # handle remaining options: + # Handle remaining options. If any of these are set, enable_shell + # was set also, so shell must be true to reach here. if debug: shell.open_debugger() if startup: @@ -1555,7 +1557,7 @@ def main(): os.environ.get("PYTHONSTARTUP") if filename and os.path.isfile(filename): shell.interp.execfile(filename) - if shell and cmd or script: + if cmd or script: shell.interp.runcommand("""if 1: import sys as _sys _sys.argv = %r @@ -1566,13 +1568,14 @@ def main(): elif script: shell.interp.prepend_syspath(script) shell.interp.execfile(script) - - # Check for problematic OS X Tk versions and print a warning message - # in the IDLE shell window; this is less intrusive than always opening - # a separate window. - tkversionwarning = macosxSupport.tkVersionWarning(root) - if tkversionwarning: - shell.interp.runcommand(''.join(("print('", tkversionwarning, "')"))) + elif shell: + # If there is a shell window and no cmd or script in progress, + # check for problematic OS X Tk versions and print a warning + # message in the IDLE shell window; this is less intrusive + # than always opening a separate window. + tkversionwarning = macosxSupport.tkVersionWarning(root) + if tkversionwarning: + shell.interp.runcommand("print('%s')" % tkversionwarning) while flist.inversedict: # keep IDLE running while files are open. root.mainloop() |