-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[IPython] Source inspection dispatcher for better IDLE compatibility (#…
…1222) * [Misc] Use 'dill.source' of 'inspect' to run codes in interactive shell * [skip ci] Add dill to CI * _ShellInspectorWrapper * Hack IDLE to make it happy * Fix IDLE * [skip ci] cache: we do care user experience!! * improve stability * [skip ci] fix example exit * [skip ci] fix exit in IPython * [skip ci] improve comment * fix exec risk in ti debug (@rexwangcc) * [skip ci] Fix ti debug too verbose * Better line * fix test_cli * [skip ci] idle_hacker.py * fix typo and improve hacker * [skip ci] reimprov * improve idle inspector * [skip ci] add tag [IPython] * revert idle * [skip ci] revert off-topic cuda debug * [skip ci] clean * [skip ci] enforce code format * [skip ci] no atexit * fix * [skip ci] Update python/taichi/lang/shell.py Co-authored-by: Yuanming Hu <[email protected]> * add dill to jenkins Co-authored-by: Taichi Gardener <[email protected]> Co-authored-by: Yuanming Hu <[email protected]> Co-authored-by: Yuanming Hu <[email protected]>
- Loading branch information
1 parent
e8d8735
commit 37976e7
Showing
12 changed files
with
128 additions
and
31 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,98 @@ | ||
import sys, os | ||
|
||
|
||
class ShellType: | ||
NATIVE = 'Python shell' | ||
IPYTHON = 'IPython TerminalInteractiveShell' | ||
JUPYTER = 'IPython ZMQInteractiveShell' | ||
IPYBASED = 'IPython Based Shell' | ||
SCRIPT = None | ||
|
||
|
||
def get_shell_name(): | ||
""" | ||
Detect which type of shell is using. | ||
Can be IPython, IDLE, Python native, or none. | ||
""" | ||
shell = os.environ.get('TI_SHELL_TYPE') | ||
if shell is not None: | ||
return getattr(ShellType, shell.upper()) | ||
|
||
try: | ||
import __main__ as main | ||
if hasattr(main, '__file__'): # Called from a script? | ||
return ShellType.SCRIPT | ||
except: | ||
pass | ||
|
||
# Let's detect which type of interactive shell is being used. | ||
# As you can see, huge engineering efforts are done here just to | ||
# make IDLE and IPython happy. Hope our users really love them :) | ||
|
||
try: # IPython / Jupyter? | ||
return 'IPython ' + get_ipython().__class__.__name__ | ||
except: | ||
# Note that we can't simply do `'IPython' in sys.modules`, | ||
# since it seems `torch` will import IPython on it's own too.. | ||
if hasattr(__builtins__, '__IPYTHON__'): | ||
return ShellType.IPYBASED | ||
|
||
try: | ||
if getattr(sys, 'ps1', sys.flags.interactive): | ||
return ShellType.NATIVE | ||
except: | ||
pass | ||
|
||
return ShellType.SCRIPT | ||
|
||
|
||
class ShellInspectorWrapper: | ||
""" | ||
Wrapper of the `inspect` module. When interactive shell detected, | ||
we will redirect getsource() calls to the corresponding inspector | ||
provided by / suitable for each type of shell. | ||
""" | ||
def __init__(self): | ||
self.name = get_shell_name() | ||
|
||
if self.name is not None: | ||
print('[Taichi] Interactive shell detected:', self.name) | ||
|
||
if self.name is None: | ||
# `inspect` for "Python script" | ||
import inspect | ||
self.getsource = inspect.getsource | ||
self.getsourcelines = inspect.getsourcelines | ||
self.getsourcefile = inspect.getsourcefile | ||
|
||
elif self.name == ShellType.NATIVE: | ||
# `dill.source` for "Python native shell" | ||
import dill | ||
self.getsource = dill.source.getsource | ||
self.getsourcelines = dill.source.getsourcelines | ||
self.getsourcefile = dill.source.getsourcefile | ||
|
||
elif self.name.startswith('IPython'): | ||
# `IPython.core.oinspect` for "IPython advanced shell" | ||
def getsource(o): | ||
import IPython | ||
return IPython.core.oinspect.getsource(o) | ||
|
||
def getsourcelines(o): | ||
import IPython | ||
lineno = IPython.core.oinspect.find_source_lines(o) | ||
lines = IPython.core.oinspect.getsource(o).split('\n') | ||
return lines, lineno | ||
|
||
def getsourcefile(o): | ||
return '<IPython>' | ||
|
||
self.getsource = getsource | ||
self.getsourcelines = getsourcelines | ||
self.getsourcefile = getsourcefile | ||
|
||
else: | ||
raise RuntimeError(f'Shell type "{self.name}" not supported') | ||
|
||
|
||
oinspect = ShellInspectorWrapper() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -33,6 +33,7 @@ | |
'colorama', | ||
'setuptools', | ||
'astor', | ||
'dill', | ||
# For testing: | ||
'pytest', | ||
'pytest-xdist', | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters