diff options
| author | Roger Serwy <roger.serwy@gmail.com> | 2013-04-03 00:42:24 -0500 | 
|---|---|---|
| committer | Roger Serwy <roger.serwy@gmail.com> | 2013-04-03 00:42:24 -0500 | 
| commit | 6b7a5ae2c100d9a28cc1879b7325dc0e615a3a10 (patch) | |
| tree | 249082bfb934eae6d8111e1337bdd7b5aaeb7b7c /Lib/idlelib/PyShell.py | |
| parent | 0d28a61d233c02c458c8b4a25613be2f4979331e (diff) | |
| download | cpython-git-6b7a5ae2c100d9a28cc1879b7325dc0e615a3a10.tar.gz | |
#14254: IDLE now handles readline correctly across shell restarts.
Diffstat (limited to 'Lib/idlelib/PyShell.py')
| -rw-r--r-- | Lib/idlelib/PyShell.py | 14 | 
1 files changed, 12 insertions, 2 deletions
| diff --git a/Lib/idlelib/PyShell.py b/Lib/idlelib/PyShell.py index 41e746d78c..c381f23b1e 100644 --- a/Lib/idlelib/PyShell.py +++ b/Lib/idlelib/PyShell.py @@ -458,6 +458,7 @@ class ModifiedInterpreter(InteractiveInterpreter):              self.display_no_subprocess_error()              return None          self.transfer_path(with_cwd=with_cwd) +        console.stop_readline()          # annotate restart in shell window and mark it          console.text.delete("iomark", "end-1c")          if was_executing: @@ -896,6 +897,7 @@ class PyShell(OutputWindow):      canceled = False      endoffile = False      closing = False +    _stop_readline_flag = False      def set_warning_stream(self, stream):          global warning_stream @@ -971,8 +973,7 @@ class PyShell(OutputWindow):                  parent=self.text)              if response is False:                  return "cancel" -        if self.reading: -            self.top.quit() +        self.stop_readline()          self.canceled = True          self.closing = True          # Wait for poll_subprocess() rescheduling to stop @@ -1027,6 +1028,12 @@ class PyShell(OutputWindow):          tkinter._default_root = None # 03Jan04 KBK What's this?          return True +    def stop_readline(self): +        if not self.reading:  # no nested mainloop to exit. +            return +        self._stop_readline_flag = True +        self.top.quit() +      def readline(self):          save = self.reading          try: @@ -1034,6 +1041,9 @@ class PyShell(OutputWindow):              self.top.mainloop()  # nested mainloop()          finally:              self.reading = save +        if self._stop_readline_flag: +            self._stop_readline_flag = False +            return ""          line = self.text.get("iomark", "end-1c")          if len(line) == 0:  # may be EOF if we quit our mainloop with Ctrl-C              line = "\n" | 
