##// END OF EJS Templates
Merge pull request #13891 from garlandz-db/main...
Merge pull request #13891 from garlandz-db/main Handle non utf-8 characters during decoding for %%bash

File last commit:

r27858:5ab1ecc6
r28026:5d26cb25 merge
Show More
interactiveshell.py
773 lines | 27.6 KiB | text/x-python | PythonLexer
Matthias Bussonnier
Remove readline mention, fit IPython typo.
r22557 """IPython terminal interface using prompt_toolkit"""
Thomas Kluyver
Move most readline code from InteractiveShell to terminal subclass...
r21846
Jonathan Slenders
Run the prompt in a separate asyncio loop....
r25276 import asyncio
Min RK
undeprecate terminal.interactiveshell...
r22549 import os
import sys
Pierre Gerold
Replace all import of IPython.utils.warn module
r22092 from warnings import warn
Brian Granger
Complete reorganization of InteractiveShell....
r2761
Min RK
avoid deprecated get_event_loop...
r27387 from IPython.core.async_helpers import get_asyncio_loop
Min RK
undeprecate terminal.interactiveshell...
r22549 from IPython.core.interactiveshell import InteractiveShell, InteractiveShellABC
Hugo
Remove redundant Python 2 code
r24010 from IPython.utils.py3compat import input
Георгий Фролов
restore terminal title on exit (xterm)
r25194 from IPython.utils.terminal import toggle_set_term_title, set_term_title, restore_term_title
Min RK
undeprecate terminal.interactiveshell...
r22549 from IPython.utils.process import abbrev_cwd
Thomas Kluyver
Allow configuring a function to handle return in the terminal...
r23580 from traitlets import (
Martin Skarzynski
cursor shape changes with vi editing mode
r26113 Bool,
Unicode,
Dict,
Integer,
observe,
Instance,
Type,
default,
Enum,
Union,
Any,
validate,
Float,
Thomas Kluyver
Allow configuring a function to handle return in the terminal...
r23580 )
Min RK
undeprecate terminal.interactiveshell...
r22549
Martin Skarzynski
enable autosuggestion
r26102 from prompt_toolkit.auto_suggest import AutoSuggestFromHistory
Thomas Kluyver
Pull shortcut definitions out to a separate module
r22642 from prompt_toolkit.enums import DEFAULT_BUFFER, EditingMode
from prompt_toolkit.filters import (HasFocus, Condition, IsDone)
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 from prompt_toolkit.formatted_text import PygmentsTokens
Matthias Bussonnier
Get history from sql....
r27595 from prompt_toolkit.history import History
Min RK
undeprecate terminal.interactiveshell...
r22549 from prompt_toolkit.layout.processors import ConditionalProcessor, HighlightMatchingBracketProcessor
Thomas Kluyver
Arrange imports, add missing, remove unused
r24377 from prompt_toolkit.output import ColorDepth
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 from prompt_toolkit.patch_stdout import patch_stdout
Thomas Kluyver
Fix input rewrite prompt
r24379 from prompt_toolkit.shortcuts import PromptSession, CompleteStyle, print_formatted_text
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 from prompt_toolkit.styles import DynamicStyle, merge_styles
from prompt_toolkit.styles.pygments import style_from_pygments_cls, style_from_pygments_dict
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268 from prompt_toolkit import __version__ as ptk_version
Min RK
undeprecate terminal.interactiveshell...
r22549
Thomas Kluyver
Remove unused import
r23995 from pygments.styles import get_style_by_name
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 from pygments.style import Style
Min RK
undeprecate terminal.interactiveshell...
r22549 from pygments.token import Token
from .debugger import TerminalPdb, Pdb
from .magics import TerminalMagics
Thomas Kluyver
Let IPython.lib.guisupport detect terminal-integrated event loops...
r22913 from .pt_inputhooks import get_inputhook_name_and_func
Min RK
undeprecate terminal.interactiveshell...
r22549 from .prompts import Prompts, ClassicPrompts, RichPromptDisplayHook
from .ptutils import IPythonPTCompleter, IPythonPTLexer
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 from .shortcuts import create_ipython_shortcuts
Min RK
undeprecate terminal.interactiveshell...
r22549
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268 PTK3 = ptk_version.startswith('3.')
Matthias Bussonnier
Fix interact() and mainloop() for backward compat.
r22562
Min RK
undeprecate terminal.interactiveshell...
r22549
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 class _NoStyle(Style): pass
_style_overrides_light_bg = {
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.Prompt: '#ansibrightblue',
Token.PromptNum: '#ansiblue bold',
Token.OutPrompt: '#ansibrightred',
Token.OutPromptNum: '#ansired bold',
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 }
_style_overrides_linux = {
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.Prompt: '#ansibrightgreen',
Token.PromptNum: '#ansigreen bold',
Token.OutPrompt: '#ansibrightred',
Token.OutPromptNum: '#ansired bold',
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 }
Min RK
undeprecate terminal.interactiveshell...
r22549 def get_default_editor():
try:
Srinivas Reddy Thatiparthy
remove PY3
r23085 return os.environ['EDITOR']
Min RK
undeprecate terminal.interactiveshell...
r22549 except KeyError:
pass
except UnicodeError:
warn("$EDITOR environment variable is not pure ASCII. Using platform "
"default editor.")
if os.name == 'posix':
return 'vi' # the only one guaranteed to be there!
else:
return 'notepad' # same in Windows!
Min RK
safer check for isatty...
r22758 # conservatively check for tty
# overridden streams can result in things like:
# - sys.stdin = None
# - no isatty method
for _name in ('stdin', 'stdout', 'stderr'):
_stream = getattr(sys, _name)
Jacob Hall
terminal interface: catch exception when standard stream is closed...
r27749 try:
if not _stream or not hasattr(_stream, "isatty") or not _stream.isatty():
_is_tty = False
break
except ValueError:
# stream is closed
Min RK
safer check for isatty...
r22758 _is_tty = False
break
Min RK
undeprecate terminal.interactiveshell...
r22549 else:
Min RK
safer check for isatty...
r22758 _is_tty = True
Min RK
undeprecate terminal.interactiveshell...
r22549
_use_simple_prompt = ('IPY_TEST_SIMPLE_PROMPT' in os.environ) or (not _is_tty)
Matthias Bussonnier
some more work
r25142 def black_reformat_handler(text_before_cursor):
Matthias Bussonnier
enable formatting by default
r27324 """
We do not need to protect against error,
this is taken care at a higher level where any reformat error is ignored.
Indeed we may call reformatting on incomplete code.
"""
Matthias Bussonnier
some more work
r25142 import black
Matthias Bussonnier
enable formatting by default
r27324
Matthias Bussonnier
some more work
r25142 formatted_text = black.format_str(text_before_cursor, mode=black.FileMode())
Matthias Bussonnier
enable formatting by default
r27324 if not text_before_cursor.endswith("\n") and formatted_text.endswith("\n"):
formatted_text = formatted_text[:-1]
Matthias Bussonnier
some more work
r25142 return formatted_text
Anton Älgmyr
Add support for autoformatting using yapf
r27523 def yapf_reformat_handler(text_before_cursor):
from yapf.yapflib import file_resources
from yapf.yapflib import yapf_api
style_config = file_resources.GetDefaultStyleForDir(os.getcwd())
Anton Älgmyr
Fix some formatting
r27524 formatted_text, was_formatted = yapf_api.FormatCode(
text_before_cursor, style_config=style_config
)
Anton Älgmyr
Add support for autoformatting using yapf
r27523 if was_formatted:
if not text_before_cursor.endswith("\n") and formatted_text.endswith("\n"):
formatted_text = formatted_text[:-1]
return formatted_text
else:
return text_before_cursor
Matthias Bussonnier
Get history from sql....
r27595 class PtkHistoryAdapter(History):
"""
Prompt toolkit has it's own way of handling history, Where it assumes it can
Push/pull from history.
"""
def __init__(self, shell):
super().__init__()
self.shell = shell
self._refresh()
def append_string(self, string):
# we rely on sql for that.
self._loaded = False
self._refresh()
def _refresh(self):
if not self._loaded:
self._loaded_strings = list(self.load_history_strings())
def load_history_strings(self):
last_cell = ""
res = []
for __, ___, cell in self.shell.history_manager.get_tail(
self.shell.history_load_length, include_latest=True
):
# Ignore blank lines and consecutive duplicates
cell = cell.rstrip()
if cell and (cell != last_cell):
res.append(cell)
last_cell = cell
yield from res[::-1]
def store_string(self, string: str) -> None:
pass
Min RK
undeprecate terminal.interactiveshell...
r22549 class TerminalInteractiveShell(InteractiveShell):
Matthias Bussonnier
Provide hooks for arbitrary mimetypes handling....
r25164 mime_renderers = Dict().tag(config=True)
Min RK
undeprecate terminal.interactiveshell...
r22549 space_for_menu = Integer(6, help='Number of line at the bottom of the screen '
Matthias Bussonnier
Better documentation for `space_for_menu`.
r25752 'to reserve for the tab completion menu, '
'search history, ...etc, the height of '
'these menus will at most this value. '
'Increase it is you prefer long and skinny '
'menus, decrease for short and wide.'
Min RK
undeprecate terminal.interactiveshell...
r22549 ).tag(config=True)
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 pt_app = None
Min RK
undeprecate terminal.interactiveshell...
r22549 debugger_history = None
Matthias Bussonnier
Add history file to debugger....
r26809 debugger_history_file = Unicode(
"~/.pdbhistory", help="File in which to store and read history"
).tag(config=True)
Min RK
undeprecate terminal.interactiveshell...
r22549 simple_prompt = Bool(_use_simple_prompt,
Ximin Luo
Support multiline input in --simple-prompt (fixes: #9816)
r23704 help="""Use `raw_input` for the REPL, without completion and prompt colors.
Min RK
undeprecate terminal.interactiveshell...
r22549
Useful when controlling IPython as a subprocess, and piping STDIN/OUT/ERR. Known usage are:
IPython own testing machinery, and emacs inferior-shell integration through elpy.
This mode default to `True` if the `IPY_TEST_SIMPLE_PROMPT`
Matthias Bussonnier
Fix a couple of warnings/errors in doc builds.
r23477 environment variable is set, or the current terminal is not a tty."""
Min RK
undeprecate terminal.interactiveshell...
r22549 ).tag(config=True)
@property
def debugger_cls(self):
return Pdb if self.simple_prompt else TerminalPdb
confirm_exit = Bool(True,
help="""
Set to confirm when you try to exit IPython with an EOF (Control-D
in Unix, Control-Z/Enter in Windows). By typing 'exit' or 'quit',
you can force a direct exit without any confirmation.""",
).tag(config=True)
editing_mode = Unicode('emacs',
help="Shortcut style to use at the prompt. 'vi' or 'emacs'.",
).tag(config=True)
Matthias Bussonnier
reformat with darker
r26091 emacs_bindings_in_vi_insert_mode = Bool(
True,
Martin Skarzynski
add emacs keybindings to vi insert mode
r26067 help="Add shortcuts from 'emacs' insert mode to 'vi' insert mode.",
).tag(config=True)
Martin Skarzynski
cursor shape changes with vi editing mode
r26113 modal_cursor = Bool(
True,
help="""
Cursor shape changes depending on vi mode: beam in vi insert mode,
block in nav mode, underscore in replace mode.""",
).tag(config=True)
ttimeoutlen = Float(
0.01,
help="""The time in milliseconds that is waited for a key code
to complete.""",
).tag(config=True)
timeoutlen = Float(
0.5,
help="""The time in milliseconds that is waited for a mapped key
sequence to complete.""",
).tag(config=True)
Matthias Bussonnier
enable formatting by default
r27324 autoformatter = Unicode(
Adam Johnson
Revert "enable formatting by default"...
r27543 None,
Anton Älgmyr
Add support for autoformatting using yapf
r27523 help="Autoformatter to reformat Terminal code. Can be `'black'`, `'yapf'` or `None`",
Matthias Bussonnier
some more work
r25142 allow_none=True
).tag(config=True)
Martin Skarzynski
Add setting to toggle auto_match feature
r27375 auto_match = Bool(
False,
help="""
Automatically add/delete closing bracket or quote when opening bracket or quote is entered/deleted.
Brackets: (), [], {}
Quotes: '', \"\"
""",
).tag(config=True)
Min RK
undeprecate terminal.interactiveshell...
r22549 mouse_support = Bool(False,
ormung
Add note to config option...
r23846 help="Enable mouse support in the prompt\n(Note: prevents selecting text with the mouse)"
Min RK
undeprecate terminal.interactiveshell...
r22549 ).tag(config=True)
Thomas Kluyver
Don't list pygments styles on import...
r23994 # We don't load the list of styles for the help string, because loading
# Pygments plugins takes time and can cause unexpected errors.
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 highlighting_style = Union([Unicode('legacy'), Type(klass=Style)],
help="""The name or class of a Pygments style to use for syntax
Thomas Kluyver
Don't list pygments styles on import...
r23994 highlighting. To see available styles, run `pygmentize -L styles`."""
Min RK
undeprecate terminal.interactiveshell...
r22549 ).tag(config=True)
Matthias Bussonnier
Give some love to the VI mode....
r24684 @validate('editing_mode')
def _validate_editing_mode(self, proposal):
if proposal['value'].lower() == 'vim':
proposal['value']= 'vi'
elif proposal['value'].lower() == 'default':
proposal['value']= 'emacs'
if hasattr(EditingMode, proposal['value'].upper()):
return proposal['value'].lower()
return self.editing_mode
Artur Svistunov
User `EditingMode` instance instead of upper-cased name of a mode
r26746
@observe('editing_mode')
Artur Svistunov
Revert method name to minimize possible impact of the fix
r26747 def _editing_mode(self, change):
Matthias Bussonnier
Fix starting IPython in vi editing mode...
r24718 if self.pt_app:
Artur Svistunov
Simplify a bit, remove preliminary computation of mode
r26748 self.pt_app.editing_mode = getattr(EditingMode, change.new.upper())
Jamshed Vesuna
Only track unique history of commands
r22859
Matthias Bussonnier
enable formatting by default
r27324 def _set_formatter(self, formatter):
Matthias Bussonnier
some more work
r25142 if formatter is None:
self.reformat_handler = lambda x:x
elif formatter == 'black':
self.reformat_handler = black_reformat_handler
Anton Älgmyr
Fix darker complaint, even though inconsistent
r27525 elif formatter == "yapf":
Anton Älgmyr
Add support for autoformatting using yapf
r27523 self.reformat_handler = yapf_reformat_handler
Matthias Bussonnier
some more work
r25142 else:
raise ValueError
Matthias Bussonnier
enable formatting by default
r27324 @observe("autoformatter")
def _autoformatter_changed(self, change):
formatter = change.new
self._set_formatter(formatter)
Min RK
undeprecate terminal.interactiveshell...
r22549 @observe('highlighting_style')
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 @observe('colors')
Min RK
undeprecate terminal.interactiveshell...
r22549 def _highlighting_style_changed(self, change):
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 self.refresh_style()
def refresh_style(self):
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 self._style = self._make_style_from_name_or_cls(self.highlighting_style)
Min RK
undeprecate terminal.interactiveshell...
r22549
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578
Min RK
undeprecate terminal.interactiveshell...
r22549 highlighting_style_overrides = Dict(
help="Override highlighting format for specific tokens"
).tag(config=True)
Jacob Niehus
Add true_color option for prompt_toolkit
r22682 true_color = Bool(False,
Reilly Tucker Siemens
Fix TerminalInteractiveShell.true_color docs
r26122 help="""Use 24bit colors instead of 256 colors in prompt highlighting.
If your terminal supports true color, the following command should
print ``TRUECOLOR`` in orange::
printf \"\\x1b[38;2;255;100;0mTRUECOLOR\\x1b[0m\\n\"
""",
Jacob Niehus
Add true_color option for prompt_toolkit
r22682 ).tag(config=True)
Min RK
undeprecate terminal.interactiveshell...
r22549 editor = Unicode(get_default_editor(),
help="Set the editor used by IPython (default to $EDITOR/vi/notepad)."
).tag(config=True)
prompts_class = Type(Prompts, help='Class used to generate Prompt token for prompt_toolkit').tag(config=True)
prompts = Instance(Prompts)
@default('prompts')
def _prompts_default(self):
return self.prompts_class(self)
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 # @observe('prompts')
# def _(self, change):
# self._update_layout()
Min RK
undeprecate terminal.interactiveshell...
r22549
@default('displayhook_class')
def _displayhook_class_default(self):
return RichPromptDisplayHook
term_title = Bool(True,
help="Automatically set the terminal title"
).tag(config=True)
Tory Haavik
Add --term-title-format flag to customize terminal title format
r23623 term_title_format = Unicode("IPython: {cwd}",
help="Customize the terminal title format. This is a python format string. " +
"Available substitutions are: {cwd}."
).tag(config=True)
Jamshed Vesuna
Only track unique history of commands
r22859 display_completions = Enum(('column', 'multicolumn','readlinelike'),
michaelpacer
Fixed formatting at end of lines
r22726 help= ( "Options for displaying tab completions, 'column', 'multicolumn', and "
"'readlinelike'. These options are for `prompt_toolkit`, see "
"`prompt_toolkit` documentation for more information."
michaelpacer
added help line tointeractiveshell.py
r22720 ),
default_value='multicolumn').tag(config=True)
Matthias Bussonnier
Extend the completion layout to use a third readlinelike option....
r22554
Min RK
undeprecate terminal.interactiveshell...
r22549 highlight_matching_brackets = Bool(True,
Thomas Kluyver
Add config option for vi/emacs style open-editor shortcuts...
r23409 help="Highlight matching brackets.",
).tag(config=True)
extra_open_editor_shortcuts = Bool(False,
help="Enable vi (v) or Emacs (C-X C-E) shortcuts to open an external editor. "
"This is in addition to the F2 binding, which is always enabled."
Min RK
undeprecate terminal.interactiveshell...
r22549 ).tag(config=True)
Thomas Kluyver
Allow configuring a function to handle return in the terminal...
r23580 handle_return = Any(None,
help="Provide an alternative handler to be called when the user presses "
"Return. This is an advanced option intended for debugging, which "
"may be changed or removed in later releases."
).tag(config=True)
Shailyn javier Ortiz jimenez
Applying feedbacks - changing enable_history_search from an envvar to a configurable
r24147 enable_history_search = Bool(True,
help="Allows to enable/disable the prompt toolkit history search"
).tag(config=True)
Alexander Steppke
Add configurable providers for autosuggestions
r27454 autosuggestions_provider = Unicode(
"AutoSuggestFromHistory",
help="Specifies from which source automatic suggestions are provided. "
"Can be set to `'AutoSuggestFromHistory`' or `None` to disable"
"automatic suggestions. Default is `'AutoSuggestFromHistory`'.",
allow_none=True,
Alexander Steppke
Allow autosuggestions to be configurable.
r27433 ).tag(config=True)
Alexander Steppke
Add configurable providers for autosuggestions
r27454 def _set_autosuggestions(self, provider):
if provider is None:
self.auto_suggest = None
elif provider == "AutoSuggestFromHistory":
self.auto_suggest = AutoSuggestFromHistory()
else:
raise ValueError("No valid provider.")
if self.pt_app:
self.pt_app.auto_suggest = self.auto_suggest
@observe("autosuggestions_provider")
def _autosuggestions_provider_changed(self, change):
provider = change.new
self._set_autosuggestions(provider)
Antony Lee
Make inclusion of vi mode in prompt togglable.
r24832 prompt_includes_vi_mode = Bool(True,
help="Display the current vi mode (when using vi editing mode)."
).tag(config=True)
Min RK
undeprecate terminal.interactiveshell...
r22549 @observe('term_title')
def init_term_title(self, change=None):
# Enable or disable the terminal title.
Maciej Goszczycki
Prevent the terminal title from being set if the output is not a tty...
r27830 if self.term_title and _is_tty:
Min RK
undeprecate terminal.interactiveshell...
r22549 toggle_set_term_title(True)
Tory Haavik
Add --term-title-format flag to customize terminal title format
r23623 set_term_title(self.term_title_format.format(cwd=abbrev_cwd()))
Min RK
undeprecate terminal.interactiveshell...
r22549 else:
toggle_set_term_title(False)
Георгий Фролов
restore terminal title on exit (xterm)
r25194 def restore_term_title(self):
Maciej Goszczycki
Prevent the terminal title from being set if the output is not a tty...
r27830 if self.term_title and _is_tty:
Георгий Фролов
restore terminal title on exit (xterm)
r25194 restore_term_title()
Min RK
undeprecate terminal.interactiveshell...
r22549 def init_display_formatter(self):
super(TerminalInteractiveShell, self).init_display_formatter()
# terminal only supports plain text
Matthias Bussonnier
Update IPython/terminal/interactiveshell.py...
r25819 self.display_formatter.active_types = ["text/plain"]
Min RK
undeprecate terminal.interactiveshell...
r22549
def init_prompt_toolkit_cli(self):
if self.simple_prompt:
# Fall back to plain non-interactive output for tests.
Thomas Kluyver
Fix fallback prompt & improve info on test failure
r24167 # This is very limited.
Min RK
undeprecate terminal.interactiveshell...
r22549 def prompt():
Ximin Luo
simple-prompt: use prompts from self.prompts...
r23705 prompt_text = "".join(x[1] for x in self.prompts.in_prompt_tokens())
Thomas Kluyver
Fix fallback prompt & improve info on test failure
r24167 lines = [input(prompt_text)]
Ximin Luo
simple-prompt: use prompts from self.prompts...
r23705 prompt_continuation = "".join(x[1] for x in self.prompts.continuation_prompt_tokens())
Thomas Kluyver
Add shell.check_complete() method...
r24180 while self.check_complete('\n'.join(lines))[0] == 'incomplete':
Thomas Kluyver
Fix fallback prompt & improve info on test failure
r24167 lines.append( input(prompt_continuation) )
return '\n'.join(lines)
Min RK
undeprecate terminal.interactiveshell...
r22549 self.prompt_for_code = prompt
return
Thomas Kluyver
Pull shortcut definitions out to a separate module
r22642 # Set up keyboard shortcuts
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 key_bindings = create_ipython_shortcuts(self)
Min RK
undeprecate terminal.interactiveshell...
r22549
Matthias Bussonnier
Get history from sql....
r27595
Min RK
undeprecate terminal.interactiveshell...
r22549 # Pre-populate history from IPython's history database
Matthias Bussonnier
Get history from sql....
r27595 history = PtkHistoryAdapter(self)
Min RK
undeprecate terminal.interactiveshell...
r22549
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 self._style = self._make_style_from_name_or_cls(self.highlighting_style)
memeplex
Make pdb use pt style. Fixes #10478
r23571 self.style = DynamicStyle(lambda: self._style)
Min RK
undeprecate terminal.interactiveshell...
r22549
editing_mode = getattr(EditingMode, self.editing_mode.upper())
Jonathan Slenders
Run the prompt in a separate asyncio loop....
r25276 self.pt_loop = asyncio.new_event_loop()
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 self.pt_app = PromptSession(
Alexander Steppke
Add configurable providers for autosuggestions
r27454 auto_suggest=self.auto_suggest,
Matthias Bussonnier
autoreformat with darker
r26104 editing_mode=editing_mode,
key_bindings=key_bindings,
history=history,
completer=IPythonPTCompleter(shell=self),
enable_history_search=self.enable_history_search,
style=self.style,
include_default_pygments_style=False,
mouse_support=self.mouse_support,
enable_open_in_editor=self.extra_open_editor_shortcuts,
color_depth=self.color_depth,
tempfile_suffix=".py",
**self._extra_prompt_options()
)
Min RK
undeprecate terminal.interactiveshell...
r22549
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 def _make_style_from_name_or_cls(self, name_or_cls):
Min RK
undeprecate terminal.interactiveshell...
r22549 """
Small wrapper that make an IPython compatible style from a style name
Jamshed Vesuna
Only track unique history of commands
r22859 We need that to add style for prompt ... etc.
Min RK
undeprecate terminal.interactiveshell...
r22549 """
Matthias Bussonnier
Make everyone happy with a neutral colortheme by default.
r22609 style_overrides = {}
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 if name_or_cls == 'legacy':
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 legacy = self.colors.lower()
if legacy == 'linux':
style_cls = get_style_by_name('monokai')
style_overrides = _style_overrides_linux
elif legacy == 'lightbg':
style_overrides = _style_overrides_light_bg
Matthias Bussonnier
Make everyone happy with a neutral colortheme by default.
r22609 style_cls = get_style_by_name('pastie')
elif legacy == 'neutral':
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 # The default theme needs to be visible on both a dark background
# and a light background, because we can't tell what the terminal
# looks like. These tweaks to the default theme help with that.
Matthias Bussonnier
Make everyone happy with a neutral colortheme by default.
r22609 style_cls = get_style_by_name('default')
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 style_overrides.update({
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.Number: '#ansigreen',
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 Token.Operator: 'noinherit',
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.String: '#ansiyellow',
Token.Name.Function: '#ansiblue',
Token.Name.Class: 'bold #ansiblue',
Token.Name.Namespace: 'bold #ansiblue',
Matthias Bussonnier
Make `x.__doc__` a reasonable default color.
r25896 Token.Name.Variable.Magic: '#ansiblue',
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.Prompt: '#ansigreen',
Matthias Bussonnier
Use ansi code for soon-to-be released prompt_toolkit....
r24680 Token.PromptNum: '#ansibrightgreen bold',
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.OutPrompt: '#ansired',
Matthias Bussonnier
Use ansi code for soon-to-be released prompt_toolkit....
r24680 Token.OutPromptNum: '#ansibrightred bold',
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 })
Segev Finer
Fix the rest of the colors used on Windows so they are more visible...
r23317
# Hack: Due to limited color support on the Windows console
# the prompt colors will be wrong without this
if os.name == 'nt':
style_overrides.update({
Token.Prompt: '#ansidarkgreen',
Token.PromptNum: '#ansigreen bold',
Token.OutPrompt: '#ansidarkred',
Token.OutPromptNum: '#ansired bold',
})
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 elif legacy =='nocolor':
style_cls=_NoStyle
style_overrides = {}
else :
raise ValueError('Got unknown colors: ', legacy)
else :
Srinivas Reddy Thatiparthy
convert string_types to str
r23037 if isinstance(name_or_cls, str):
memeplex
Allow to pass a pygments class to highlighting_style....
r22766 style_cls = get_style_by_name(name_or_cls)
else:
style_cls = name_or_cls
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 style_overrides = {
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.Prompt: '#ansigreen',
Matthias Bussonnier
Use ansi code for soon-to-be released prompt_toolkit....
r24680 Token.PromptNum: '#ansibrightgreen bold',
Tobias Bengfort
replace hardcoded colors by ANSI colors...
r25894 Token.OutPrompt: '#ansired',
Matthias Bussonnier
Use ansi code for soon-to-be released prompt_toolkit....
r24680 Token.OutPromptNum: '#ansibrightred bold',
Matthias Bussonnier
Restore the ability to use %colors to switch terminal theme....
r22578 }
Min RK
undeprecate terminal.interactiveshell...
r22549 style_overrides.update(self.highlighting_style_overrides)
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 style = merge_styles([
style_from_pygments_cls(style_cls),
style_from_pygments_dict(style_overrides),
])
Min RK
undeprecate terminal.interactiveshell...
r22549
return style
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 @property
def pt_complete_style(self):
return {
'multicolumn': CompleteStyle.MULTI_COLUMN,
'column': CompleteStyle.COLUMN,
'readlinelike': CompleteStyle.READLINE_LIKE,
Yutao Yuan
Fix config option TerminalInteractiveShell.display_completions...
r24397 }[self.display_completions]
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376
Kyungdahm Yun
Make color_depth property for reuse
r24902 @property
def color_depth(self):
return (ColorDepth.TRUE_COLOR if self.true_color else None)
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 def _extra_prompt_options(self):
Min RK
undeprecate terminal.interactiveshell...
r22549 """
Return the current layout option for the current Terminal InteractiveShell
"""
Matthias Bussonnier
Do no precompute when using vi mode.
r25219 def get_message():
return PygmentsTokens(self.prompts.in_prompt_tokens())
if self.editing_mode == 'emacs':
# with emacs mode the prompt is (usually) static, so we call only
# the function once. With VI mode it can toggle between [ins] and
# [nor] so we can't precompute.
# here I'm going to favor the default keybinding which almost
# everybody uses to decrease CPU usage.
# if we have issues with users with custom Prompts we can see how to
# work around this.
get_message = get_message()
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268 options = {
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 'complete_in_thread': False,
Min RK
undeprecate terminal.interactiveshell...
r22549 'lexer':IPythonPTLexer(),
'reserve_space_for_menu':self.space_for_menu,
Matthias Bussonnier
Do no precompute when using vi mode.
r25219 'message': get_message,
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 'prompt_continuation': (
lambda width, lineno, is_soft_wrap:
PygmentsTokens(self.prompts.continuation_prompt_tokens(width))),
'multiline': True,
'complete_style': self.pt_complete_style,
Min RK
undeprecate terminal.interactiveshell...
r22549
# Highlight matching brackets, but only when this setting is
# enabled, and only when the DEFAULT_BUFFER has the focus.
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 'input_processors': [ConditionalProcessor(
Min RK
undeprecate terminal.interactiveshell...
r22549 processor=HighlightMatchingBracketProcessor(chars='[](){}'),
filter=HasFocus(DEFAULT_BUFFER) & ~IsDone() &
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 Condition(lambda: self.highlight_matching_brackets))],
Min RK
undeprecate terminal.interactiveshell...
r22549 }
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268 if not PTK3:
Matthias Bussonnier
Fix the right inputhook...
r25325 options['inputhook'] = self.inputhook
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268
return options
Min RK
undeprecate terminal.interactiveshell...
r22549
def prompt_for_code(self):
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 if self.rl_next_input:
default = self.rl_next_input
self.rl_next_input = None
else:
default = ''
Jonathan Slenders
Handle situation where the user used 'asyncio.run' and clears the event loop.
r25309 # In order to make sure that asyncio code written in the
# interactive shell doesn't interfere with the prompt, we run the
# prompt in a different event loop.
# If we don't do this, people could spawn coroutine with a
# while/true inside which will freeze the prompt.
Jonathan Slenders
Run the prompt in a separate asyncio loop....
r25276
Min RK
avoid deprecated asyncio.get_event_loop...
r27192 policy = asyncio.get_event_loop_policy()
Min RK
avoid deprecated get_event_loop...
r27387 old_loop = get_asyncio_loop()
# FIXME: prompt_toolkit is using the deprecated `asyncio.get_event_loop`
# to get the current event loop.
# This will probably be replaced by an attribute or input argument,
# at which point we can stop calling the soon-to-be-deprecated `set_event_loop` here.
if old_loop is not self.pt_loop:
policy.set_event_loop(self.pt_loop)
Jonathan Slenders
Handle situation where the user used 'asyncio.run' and clears the event loop.
r25309 try:
with patch_stdout(raw=True):
Jonathan Slenders
Run the prompt in a separate asyncio loop....
r25276 text = self.pt_app.prompt(
default=default,
**self._extra_prompt_options())
Jonathan Slenders
Handle situation where the user used 'asyncio.run' and clears the event loop.
r25309 finally:
# Restore the original event loop.
Min RK
avoid deprecated get_event_loop...
r27387 if old_loop is not None and old_loop is not self.pt_loop:
Min RK
avoid deprecated asyncio.get_event_loop...
r27192 policy.set_event_loop(old_loop)
Jonathan Slenders
Handle situation where the user used 'asyncio.run' and clears the event loop.
r25309
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 return text
Min RK
undeprecate terminal.interactiveshell...
r22549
kousik
Added deprecation warning for enable_win_unicode_console #11953
r25247 def enable_win_unicode_console(self):
# Since IPython 7.10 doesn't support python < 3.6 and PEP 528, Python uses the unicode APIs for the Windows
# console by default, so WUC shouldn't be needed.
warn("`enable_win_unicode_console` is deprecated since IPython 7.10, does not do anything and will be removed in the future",
DeprecationWarning,
stacklevel=2)
Min RK
undeprecate terminal.interactiveshell...
r22549 def init_io(self):
if sys.platform not in {'win32', 'cli'}:
return
Thomas Kluyver
Be more lenient when bytes are sent to stdout/stderr on Py2+Windows...
r22701 import colorama
Min RK
undeprecate terminal.interactiveshell...
r22549 colorama.init()
def init_magics(self):
super(TerminalInteractiveShell, self).init_magics()
self.register_magics(TerminalMagics)
def init_alias(self):
# The parent class defines aliases that can be safely used with any
# frontend.
super(TerminalInteractiveShell, self).init_alias()
# Now define aliases that only make sense on the terminal, because they
# need direct access to the console in a way that we can't emulate in
# GUI or web frontend
if os.name == 'posix':
Jesse Widner
Adds posix aliases after a %reset....
r24889 for cmd in ('clear', 'more', 'less', 'man'):
Min RK
undeprecate terminal.interactiveshell...
r22549 self.alias_manager.soft_define_alias(cmd, cmd)
Fernando Perez
Fix paste/cpaste bug and refactor/cleanup that code a lot....
r5435
Matthias Bussonnier
Improve deprecation warning....
r22442
Thomas Kluyver
Remove the readline shell machinery...
r22436 def __init__(self, *args, **kwargs):
Min RK
undeprecate terminal.interactiveshell...
r22549 super(TerminalInteractiveShell, self).__init__(*args, **kwargs)
Alexander Steppke
Add configurable providers for autosuggestions
r27454 self._set_autosuggestions(self.autosuggestions_provider)
Min RK
undeprecate terminal.interactiveshell...
r22549 self.init_prompt_toolkit_cli()
self.init_term_title()
self.keep_running = True
Matthias Bussonnier
enable formatting by default
r27324 self._set_formatter(self.autoformatter)
Min RK
undeprecate terminal.interactiveshell...
r22549
def ask_exit(self):
self.keep_running = False
rl_next_input = None
Matthias Bussonnier
Remove deprecated banner parameter...
r27216 def interact(self):
Min RK
Allow starting TerminalInteractiveShell more than once...
r22764 self.keep_running = True
Min RK
undeprecate terminal.interactiveshell...
r22549 while self.keep_running:
print(self.separate_in, end='')
try:
code = self.prompt_for_code()
except EOFError:
if (not self.confirm_exit) \
or self.ask_yes_no('Do you really want to exit ([y]/n)?','y','n'):
self.ask_exit()
else:
if code:
self.run_cell(code, store_history=True)
Matthias Bussonnier
Remove deprecated banner parameter...
r27216 def mainloop(self):
Min RK
undeprecate terminal.interactiveshell...
r22549 # An extra layer of protection in case someone mashing Ctrl-C breaks
# out of our internal code.
while True:
try:
self.interact()
break
Jeroen Demeyer
Better support for KeyboardInterrupt during prompt
r23258 except KeyboardInterrupt as e:
print("\n%s escaped interact()\n" % type(e).__name__)
Thomas Kluyver
Put cleanup in finally block...
r23259 finally:
Jeroen Demeyer
Better support for KeyboardInterrupt during prompt
r23258 # An interrupt during the eventloop will mess up the
# internal state of the prompt_toolkit library.
# Stopping the eventloop fixes this, see
# https://github.com/ipython/ipython/pull/9867
if hasattr(self, '_eventloop'):
self._eventloop.stop()
Min RK
undeprecate terminal.interactiveshell...
r22549
Георгий Фролов
restore terminal title on exit (xterm)
r25194 self.restore_term_title()
Matthias Bussonnier
Finish fixing the at-exit spurious failures....
r26428 # try to call some at-exit operation optimistically as some things can't
# be done during interpreter shutdown. this is technically inaccurate as
# this make mainlool not re-callable, but that should be a rare if not
# in existent use case.
self._atexit_once()
Георгий Фролов
restore terminal title on exit (xterm)
r25194
Min RK
undeprecate terminal.interactiveshell...
r22549 _inputhook = None
def inputhook(self, context):
if self._inputhook is not None:
self._inputhook(context)
Thomas Kluyver
Let IPython.lib.guisupport detect terminal-integrated event loops...
r22913 active_eventloop = None
Min RK
undeprecate terminal.interactiveshell...
r22549 def enable_gui(self, gui=None):
Matthias Bussonnier
please formatter
r27858 if gui and (gui not in {"inline", "webagg"}):
self.active_eventloop, self._inputhook = get_inputhook_name_and_func(gui)
Min RK
undeprecate terminal.interactiveshell...
r22549 else:
Thomas Kluyver
Let IPython.lib.guisupport detect terminal-integrated event loops...
r22913 self.active_eventloop = self._inputhook = None
Min RK
undeprecate terminal.interactiveshell...
r22549
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268 # For prompt_toolkit 3.0. We have to create an asyncio event loop with
# this inputhook.
if PTK3:
Jonathan Slenders
Don't nest asyncio input hooks....
r25308 import asyncio
from prompt_toolkit.eventloop import new_eventloop_with_inputhook
if gui == 'asyncio':
# When we integrate the asyncio event loop, run the UI in the
# same event loop as the rest of the code. don't use an actual
# input hook. (Asyncio is not made for nesting event loops.)
Min RK
avoid deprecated get_event_loop...
r27387 self.pt_loop = get_asyncio_loop()
Jonathan Slenders
Don't nest asyncio input hooks....
r25308
elif self._inputhook:
# If an inputhook was set, create a new asyncio event loop with
# this inputhook for the prompt.
Jonathan Slenders
Run the prompt in a separate asyncio loop....
r25276 self.pt_loop = new_eventloop_with_inputhook(self._inputhook)
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268 else:
Jonathan Slenders
Don't nest asyncio input hooks....
r25308 # When there's no inputhook, run the prompt in a separate
# asyncio event loop.
Jonathan Slenders
Run the prompt in a separate asyncio loop....
r25276 self.pt_loop = asyncio.new_event_loop()
Jonathan Slenders
Support prompt_toolkit 3.0 as well.
r25268
Min RK
undeprecate terminal.interactiveshell...
r22549 # Run !system commands directly, not through pipes, so terminal programs
# work correctly.
system = InteractiveShell.system_raw
def auto_rewrite_input(self, cmd):
"""Overridden from the parent class to use fancy rewriting prompt"""
if not self.show_rewritten_input:
return
tokens = self.prompts.rewrite_prompt_tokens()
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 if self.pt_app:
Thomas Kluyver
Fix input rewrite prompt
r24379 print_formatted_text(PygmentsTokens(tokens), end='',
style=self.pt_app.app.style)
Min RK
undeprecate terminal.interactiveshell...
r22549 print(cmd)
else:
prompt = ''.join(s for t, s in tokens)
print(prompt, cmd, sep='')
_prompts_before = None
def switch_doctest_mode(self, mode):
"""Switch prompts to classic for %doctest_mode"""
if mode:
self._prompts_before = self.prompts
self.prompts = ClassicPrompts(self)
elif self._prompts_before:
self.prompts = self._prompts_before
self._prompts_before = None
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 # self._update_layout()
Min RK
undeprecate terminal.interactiveshell...
r22549
InteractiveShellABC.register(TerminalInteractiveShell)
if __name__ == '__main__':
TerminalInteractiveShell.instance().interact()