本文整理匯總了Python中prompt_toolkit.application.get_app方法的典型用法代碼示例。如果您正苦於以下問題:Python application.get_app方法的具體用法?Python application.get_app怎麽用?Python application.get_app使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類prompt_toolkit.application
的用法示例。
在下文中一共展示了application.get_app方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: enter_history
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def enter_history(self) -> None:
"""
Display the history.
"""
app = get_app()
app.vi_state.input_mode = InputMode.NAVIGATION
history = PythonHistory(self, self.default_buffer.document)
from prompt_toolkit.application import in_terminal
import asyncio
async def do_in_terminal() -> None:
async with in_terminal():
result = await history.app.run_async()
if result is not None:
self.default_buffer.text = result
app.vi_state.input_mode = InputMode.INSERT
asyncio.ensure_future(do_in_terminal())
示例2: buffer_should_be_handled
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def buffer_should_be_handled(pgcli):
@Condition
def cond():
if not pgcli.multi_line:
_logger.debug("Not in multi-line mode. Handle the buffer.")
return True
if pgcli.multiline_mode == "safe":
_logger.debug("Multi-line mode is set to 'safe'. Do NOT handle the buffer.")
return False
doc = get_app().layout.get_buffer_by_name(DEFAULT_BUFFER).document
text = doc.text.strip()
return (
text.startswith("\\") # Special Command
or text.endswith(r"\e") # Special Command
or text.endswith(r"\G") # Ended with \e which should launch the editor
or _is_complete(text) # A complete SQL command
or (text == "exit") # Exit doesn't need semi-colon
or (text == "quit") # Quit doesn't need semi-colon
or (text == ":q") # To all the vim fans out there
or (text == "") # Just a plain enter without any text
)
return cond
示例3: _get_vi_mode
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def _get_vi_mode():
return {
InputMode.INSERT: "I",
InputMode.NAVIGATION: "N",
InputMode.REPLACE: "R",
InputMode.INSERT_MULTIPLE: "M",
}[get_app().vi_state.input_mode]
示例4: is_multiline
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def is_multiline() -> bool:
doc = pt_app.get_app().layout.get_buffer_by_name(
pt_enums.DEFAULT_BUFFER).document
if (doc.cursor_position and doc.text[doc.cursor_position:].strip()):
return True
return is_multiline_text(doc.text)
示例5: tab_should_insert_whitespace
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def tab_should_insert_whitespace():
"""
When the 'tab' key is pressed with only whitespace character before the
cursor, do autocompletion. Otherwise, insert indentation.
Except for the first character at the first line. Then always do a
completion. It doesn't make sense to start the first line with
indentation.
"""
b = get_app().current_buffer
before_cursor = b.document.current_line_before_cursor
return bool(b.text and (not before_cursor or before_cursor.isspace()))
示例6: _accept_handler
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def _accept_handler(self, buff: Buffer) -> bool:
app = get_app()
app.exit(result=buff.text)
app.pre_run_callables.append(buff.reset)
return True # Keep text, we call 'reset' later on.
示例7: _get_vi_mode
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def _get_vi_mode():
"""Get the current vi mode for display."""
return {
InputMode.INSERT: "I",
InputMode.NAVIGATION: "N",
InputMode.REPLACE: "R",
InputMode.INSERT_MULTIPLE: "M",
}[get_app().vi_state.input_mode]
示例8: cli_is_multiline
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def cli_is_multiline(cli):
@Condition
def cond():
doc = get_app().layout.get_buffer_by_name(DEFAULT_BUFFER).document
if not cli.multi_line:
return False
else:
return not _multiline_exception(doc.text)
return cond
示例9: _get_vi_mode
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def _get_vi_mode():
"""Get the current vi mode for display."""
return {
InputMode.INSERT: 'I',
InputMode.NAVIGATION: 'N',
InputMode.REPLACE: 'R',
InputMode.INSERT_MULTIPLE: 'M',
}[get_app().vi_state.input_mode]
示例10: cli_is_multiline
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def cli_is_multiline(cli):
@Condition
def cond():
doc = get_app().layout.get_buffer_by_name(DEFAULT_BUFFER).document
if not cli.multi_line:
return False
else:
return not _multiline_exception(doc.text)
return cond
示例11: get_prompt
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def get_prompt() -> HTML:
"""
Build the prompt dynamically every time its rendered.
"""
left_part = HTML(
"<left-part>"
" <username>root</username> "
" abc "
"<path>~/.oh-my-zsh/themes</path>"
"</left-part>"
)
right_part = HTML(
"<right-part> "
"<branch> master<exclamation-mark>!</exclamation-mark> </branch> "
" <env> py36 </env> "
" <time>%s</time> "
"</right-part>"
) % (datetime.datetime.now().isoformat(),)
used_width = sum(
[
fragment_list_width(to_formatted_text(left_part)),
fragment_list_width(to_formatted_text(right_part)),
]
)
total_width = get_app().output.get_size().columns
padding_size = total_width - used_width
padding = HTML("<padding>%s</padding>") % (" " * padding_size,)
return merge_formatted_text([left_part, padding, right_part, "\n", "# "])
示例12: has_selected_completion
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def has_selected_completion():
"""Enable when the current buffer has a selected completion."""
complete_state = get_app().current_buffer.complete_state
return (complete_state is not None and
complete_state.current_completion is not None)
示例13: mssql_is_multiline
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def mssql_is_multiline(mssql_cli):
@Condition
def cond():
doc = get_app().layout.get_buffer_by_name(DEFAULT_BUFFER).document
if not mssql_cli.multiline:
return False
if mssql_cli.multiline_mode == 'safe':
return True
return not _multiline_exception(doc.text)
return cond
示例14: _get_vi_mode
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def _get_vi_mode():
return {
InputMode.INSERT: 'I',
InputMode.NAVIGATION: 'N',
InputMode.REPLACE: 'R',
InputMode.INSERT_MULTIPLE: 'M',
}[get_app().vi_state.input_mode]
示例15: whitespace_before_cursor_on_line
# 需要導入模塊: from prompt_toolkit import application [as 別名]
# 或者: from prompt_toolkit.application import get_app [as 別名]
def whitespace_before_cursor_on_line():
"""
Filter which evaluates to True when the characters before the cursor are
whitespace, or we are at the start of te line.
"""
b = get_app().current_buffer
before_cursor = b.document.current_line_before_cursor
return bool(not before_cursor or before_cursor[-1].isspace())