##// END OF EJS Templates
Add & improve docstrings following @willingc's review
Add & improve docstrings following @willingc's review

File last commit:

r24380:e5bc0bf2
r24407:1dfcd23a
Show More
prompts.py
83 lines | 2.4 KiB | text/x-python | PythonLexer
Thomas Kluyver
Add __future__ import for prompts module
r22428 """Terminal input and output prompts."""
Thomas Kluyver
New prompts class for terminal interface
r22421 from pygments.token import Token
Thomas Kluyver
Use new prompt machinery to generate Out prompts
r22422 import sys
from IPython.core.displayhook import DisplayHook
Thomas Kluyver
New prompts class for terminal interface
r22421
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 from prompt_toolkit.formatted_text import fragment_list_width, PygmentsTokens
from prompt_toolkit.shortcuts import print_formatted_text
Matthias Bussonnier
Don't compute length of ZeroWidthTokens....
r22471
Thomas Kluyver
New prompts class for terminal interface
r22421 class Prompts(object):
def __init__(self, shell):
self.shell = shell
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 def in_prompt_tokens(self):
Thomas Kluyver
New prompts class for terminal interface
r22421 return [
(Token.Prompt, 'In ['),
(Token.PromptNum, str(self.shell.execution_count)),
(Token.Prompt, ']: '),
]
def _width(self):
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 return fragment_list_width(self.in_prompt_tokens())
Thomas Kluyver
New prompts class for terminal interface
r22421
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 def continuation_prompt_tokens(self, width=None):
Thomas Kluyver
New prompts class for terminal interface
r22421 if width is None:
width = self._width()
return [
(Token.Prompt, (' ' * (width - 5)) + '...: '),
]
def rewrite_prompt_tokens(self):
width = self._width()
return [
(Token.Prompt, ('-' * (width - 2)) + '> '),
]
def out_prompt_tokens(self):
return [
(Token.OutPrompt, 'Out['),
(Token.OutPromptNum, str(self.shell.execution_count)),
(Token.OutPrompt, ']: '),
]
Thomas Kluyver
Use new prompt machinery to generate Out prompts
r22422
Thomas Kluyver
Switch prompts for doctest_mode
r22429 class ClassicPrompts(Prompts):
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 def in_prompt_tokens(self):
Thomas Kluyver
Switch prompts for doctest_mode
r22429 return [
(Token.Prompt, '>>> '),
]
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 def continuation_prompt_tokens(self, width=None):
Thomas Kluyver
Switch prompts for doctest_mode
r22429 return [
(Token.Prompt, '... ')
]
def rewrite_prompt_tokens(self):
return []
def out_prompt_tokens(self):
return []
Thomas Kluyver
Use new prompt machinery to generate Out prompts
r22422 class RichPromptDisplayHook(DisplayHook):
"""Subclass of base display hook using coloured prompt"""
def write_output_prompt(self):
sys.stdout.write(self.shell.separate_out)
Thomas Kluyver
Empty prompt effectively ends with newline...
r23131 # If we're not displaying a prompt, it effectively ends with a newline,
# because the output will be left-aligned.
self.prompt_end_newline = True
Thomas Kluyver
Use new prompt machinery to generate Out prompts
r22422 if self.do_full_cache:
tokens = self.shell.prompts.out_prompt_tokens()
Thomas Kluyver
Fix newline check when prompt consists of empty token
r23132 prompt_txt = ''.join(s for t, s in tokens)
if prompt_txt and not prompt_txt.endswith('\n'):
Thomas Kluyver
Empty prompt effectively ends with newline...
r23131 # Ask for a newline before multiline output
self.prompt_end_newline = False
Thomas Kluyver
Fix newline check when prompt consists of empty token
r23132
Jonathan Slenders
Upgrade to prompt_toolkit 2.0
r24376 if self.shell.pt_app:
Thomas Kluyver
No newline after output prompt
r24380 print_formatted_text(PygmentsTokens(tokens),
style=self.shell.pt_app.app.style, end='',
)
Thomas Kluyver
Use new prompt machinery to generate Out prompts
r22422 else:
Thomas Kluyver
Fix newline check when prompt consists of empty token
r23132 sys.stdout.write(prompt_txt)