summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlastair Stanley <alastairstanley@ntlworld.com>2024-05-21 16:17:41 (GMT)
committerGitHub <noreply@github.com>2024-05-21 16:17:41 (GMT)
commit0398d9339217aa0710c0de45a7e9b587136e7129 (patch)
treefa10d4b5ea88cb1f3907caf3ad91832a77657cd4
parentc4722cd0573c83aaa52b63a27022b9048a949f54 (diff)
downloadcpython-0398d9339217aa0710c0de45a7e9b587136e7129.zip
cpython-0398d9339217aa0710c0de45a7e9b587136e7129.tar.gz
cpython-0398d9339217aa0710c0de45a7e9b587136e7129.tar.bz2
gh-119035: Add Ctrl+← and Ctrl+→ word-skipping keybindings to new repl (#119248)
add word-skipping ctrl keybindings to new repl
-rw-r--r--Lib/_pyrepl/keymap.py9
-rw-r--r--Lib/_pyrepl/reader.py2
2 files changed, 8 insertions, 3 deletions
diff --git a/Lib/_pyrepl/keymap.py b/Lib/_pyrepl/keymap.py
index e142173..a303589 100644
--- a/Lib/_pyrepl/keymap.py
+++ b/Lib/_pyrepl/keymap.py
@@ -177,9 +177,12 @@ def _parse_key1(key, s):
ret = key[s]
s += 1
if ctrl:
- if len(ret) > 1:
- raise KeySpecError("\\C- must be followed by a character")
- ret = chr(ord(ret) & 0x1F) # curses.ascii.ctrl()
+ if len(ret) == 1:
+ ret = chr(ord(ret) & 0x1F) # curses.ascii.ctrl()
+ elif ret in {"left", "right"}:
+ ret = f"ctrl {ret}"
+ else:
+ raise KeySpecError("\\C- followed by invalid key")
if meta:
ret = ["\033", ret]
else:
diff --git a/Lib/_pyrepl/reader.py b/Lib/_pyrepl/reader.py
index d15a150..2c8c9e7 100644
--- a/Lib/_pyrepl/reader.py
+++ b/Lib/_pyrepl/reader.py
@@ -136,7 +136,9 @@ default_keymap: tuple[tuple[KeySpec, CommandName], ...] = tuple(
(r"\<up>", "up"),
(r"\<down>", "down"),
(r"\<left>", "left"),
+ (r"\C-\<left>", "backward-word"),
(r"\<right>", "right"),
+ (r"\C-\<right>", "forward-word"),
(r"\<delete>", "delete"),
(r"\<backspace>", "backspace"),
(r"\M-\<backspace>", "backward-kill-word"),