Show More
@@ -1,6 +1,7 b'' | |||||
1 | import asyncio |
|
1 | import asyncio | |
2 | import signal |
|
2 | import signal | |
3 | import sys |
|
3 | import sys | |
|
4 | import threading | |||
4 |
|
5 | |||
5 | from IPython.core.debugger import Pdb |
|
6 | from IPython.core.debugger import Pdb | |
6 |
|
7 | |||
@@ -70,18 +71,11 b' class TerminalPdb(Pdb):' | |||||
70 | if not self.use_rawinput: |
|
71 | if not self.use_rawinput: | |
71 | raise ValueError('Sorry ipdb does not support use_rawinput=False') |
|
72 | raise ValueError('Sorry ipdb does not support use_rawinput=False') | |
72 |
|
73 | |||
73 |
# In order to make sure that asyncio |
|
74 | # In order to make sure that prompt, which uses asyncio doesn't | |
74 | # interactive shell doesn't interfere with the prompt, we run the |
|
75 | # interfere with applications in which it's used, we always run the | |
75 |
# prompt in a different event loop |
|
76 | # prompt itself in a different thread (we can't start an event loop | |
76 | # If we don't do this, people could spawn coroutine with a |
|
77 | # within an event loop). This new thread won't have any event loop | |
77 | # while/true inside which will freeze the prompt. |
|
78 | # running, and here we run our prompt-loop. | |
78 |
|
||||
79 | try: |
|
|||
80 | old_loop = asyncio.get_event_loop() |
|
|||
81 | except RuntimeError: |
|
|||
82 | # This happens when the user used `asyncio.run()`. |
|
|||
83 | old_loop = None |
|
|||
84 |
|
||||
85 |
|
79 | |||
86 | self.preloop() |
|
80 | self.preloop() | |
87 |
|
81 | |||
@@ -98,14 +92,25 b' class TerminalPdb(Pdb):' | |||||
98 | self._ptcomp.ipy_completer.namespace = self.curframe_locals |
|
92 | self._ptcomp.ipy_completer.namespace = self.curframe_locals | |
99 | self._ptcomp.ipy_completer.global_namespace = self.curframe.f_globals |
|
93 | self._ptcomp.ipy_completer.global_namespace = self.curframe.f_globals | |
100 |
|
94 | |||
101 | asyncio.set_event_loop(self.pt_loop) |
|
95 | # Run the prompt in a different thread. | |
|
96 | line = '' | |||
|
97 | keyboard_interrupt = False | |||
|
98 | ||||
|
99 | def in_thread(): | |||
|
100 | nonlocal line, keyboard_interrupt | |||
102 | try: |
|
101 | try: | |
103 | line = self.pt_app.prompt() |
|
102 | line = self.pt_app.prompt() | |
104 | except EOFError: |
|
103 | except EOFError: | |
105 | line = 'EOF' |
|
104 | line = 'EOF' | |
106 | finally: |
|
105 | except KeyboardInterrupt: | |
107 | # Restore the original event loop. |
|
106 | keyboard_interrupt = True | |
108 | asyncio.set_event_loop(old_loop) |
|
107 | ||
|
108 | th = threading.Thread(target=in_thread) | |||
|
109 | th.start() | |||
|
110 | th.join() | |||
|
111 | ||||
|
112 | if keyboard_interrupt: | |||
|
113 | raise KeyboardInterrupt | |||
109 |
|
114 | |||
110 | line = self.precmd(line) |
|
115 | line = self.precmd(line) | |
111 | stop = self.onecmd(line) |
|
116 | stop = self.onecmd(line) |
General Comments 0
You need to be logged in to leave comments.
Login now